3
0
Files
corteza/server/pkg/provision/users.go
Tomaž Jerman 462619f2b9 Change logs to encode uint64 values as strings
This is due to us introducing the web console and the uints needing
to be string encoded (because of JavaScript).
2023-05-24 12:26:01 +02:00

104 lines
2.5 KiB
Go

package provision
import (
"context"
"fmt"
"github.com/cortezaproject/corteza/server/pkg/auth"
"github.com/cortezaproject/corteza/server/pkg/filter"
"github.com/cortezaproject/corteza/server/pkg/id"
"github.com/cortezaproject/corteza/server/pkg/logger"
"github.com/cortezaproject/corteza/server/store"
"github.com/cortezaproject/corteza/server/system/types"
"go.uber.org/zap"
)
// SystemUsers creates or updates system users
func SystemUsers(ctx context.Context, log *zap.Logger, s store.Users) (uu []*types.User, err error) {
uu = types.UserSet{
&types.User{
Email: "provision@corteza.local",
Name: "Corteza Provisioner",
Handle: auth.ProvisionUserHandle,
Kind: types.SystemUser,
},
&types.User{
Email: "service@corteza.local",
Name: "Corteza Service",
Handle: auth.ServiceUserHandle,
Kind: types.SystemUser,
},
&types.User{
Email: "federation@corteza.local",
Name: "Corteza Federation",
Handle: auth.FederationUserHandle,
Kind: types.SystemUser,
},
}
m, err := loadSystemUsers(ctx, s)
if err != nil {
return
}
for i := range uu {
u := uu[i]
if m[u.Handle] == nil {
// this is a new user
u.ID = id.Next()
u.CreatedAt = *now()
if err := store.UpsertUser(ctx, s, u); err != nil {
return nil, fmt.Errorf("failed to provision system user %s: %w", u.Handle, err)
}
log.Info("creating system user", zap.String("handle", u.Handle), logger.Uint64("ID", u.ID))
} else {
u.ID = m[u.Handle].ID
// There is no need to update system users if they are unchanged
if m[u.Handle].UpdatedAt == nil &&
m[u.Handle].SuspendedAt == nil &&
m[u.Handle].DeletedAt == nil {
continue
}
// Make sure all values are as they should be
u.CreatedAt = m[u.Handle].CreatedAt
u.Email = m[u.Handle].Email
u.Name = m[u.Handle].Name
u.UpdatedAt = nil
u.SuspendedAt = nil
u.DeletedAt = nil
if err := store.UpsertUser(ctx, s, u); err != nil {
return nil, fmt.Errorf("failed to provision system user %s: %w", u.Handle, err)
}
log.Info("updating system user", zap.String("handle", u.Handle), logger.Uint64("ID", u.ID))
}
}
return
}
func loadSystemUsers(ctx context.Context, s store.Users) (m map[string]*types.User, err error) {
var (
f = types.UserFilter{
Suspended: filter.StateInclusive,
Deleted: filter.StateInclusive,
Kind: types.SystemUser,
}
)
m = make(map[string]*types.User)
if set, _, err := store.SearchUsers(ctx, s, f); err == nil {
for _, r := range set {
m[r.Handle] = r
}
}
return
}