mirror of
https://github.com/zitadel/zitadel.git
synced 2025-01-10 13:03:41 +00:00
128 lines
2.5 KiB
Go
128 lines
2.5 KiB
Go
|
package databases
|
||
|
|
||
|
import (
|
||
|
"github.com/caos/orbos/mntr"
|
||
|
"github.com/caos/orbos/pkg/git"
|
||
|
"github.com/caos/orbos/pkg/kubernetes"
|
||
|
"github.com/caos/orbos/pkg/tree"
|
||
|
"github.com/caos/zitadel/operator/api"
|
||
|
coredb "github.com/caos/zitadel/operator/database/kinds/databases/core"
|
||
|
orbdb "github.com/caos/zitadel/operator/database/kinds/orb"
|
||
|
)
|
||
|
|
||
|
func ListUsers(
|
||
|
monitor mntr.Monitor,
|
||
|
k8sClient kubernetes.ClientInt,
|
||
|
gitClient *git.Client,
|
||
|
) ([]string, error) {
|
||
|
desired, err := api.ReadDatabaseYml(gitClient)
|
||
|
if err != nil {
|
||
|
monitor.Error(err)
|
||
|
return nil, err
|
||
|
}
|
||
|
current := &tree.Tree{}
|
||
|
|
||
|
query, _, _, err := orbdb.AdaptFunc("", nil)(monitor, desired, current)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
queried := map[string]interface{}{}
|
||
|
_, err = query(k8sClient, queried)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
currentDB, err := coredb.ParseQueriedForDatabase(queried)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
list, err := currentDB.GetListUsersFunc()(k8sClient)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
users := []string{}
|
||
|
for _, listedUser := range list {
|
||
|
if listedUser != "root" {
|
||
|
users = append(users, listedUser)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return users, nil
|
||
|
}
|
||
|
|
||
|
func AddUser(
|
||
|
monitor mntr.Monitor,
|
||
|
user string,
|
||
|
k8sClient kubernetes.ClientInt,
|
||
|
gitClient *git.Client,
|
||
|
) error {
|
||
|
desired, err := api.ReadDatabaseYml(gitClient)
|
||
|
if err != nil {
|
||
|
monitor.Error(err)
|
||
|
return err
|
||
|
}
|
||
|
current := &tree.Tree{}
|
||
|
|
||
|
query, _, _, err := orbdb.AdaptFunc("", nil)(monitor, desired, current)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
queried := map[string]interface{}{}
|
||
|
_, err = query(k8sClient, queried)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
currentDB, err := coredb.ParseQueriedForDatabase(queried)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
queryUser, err := currentDB.GetAddUserFunc()(user)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
ensureUser, err := queryUser(k8sClient, queried)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return ensureUser(k8sClient)
|
||
|
}
|
||
|
|
||
|
func DeleteUser(
|
||
|
monitor mntr.Monitor,
|
||
|
user string,
|
||
|
k8sClient kubernetes.ClientInt,
|
||
|
gitClient *git.Client,
|
||
|
) error {
|
||
|
desired, err := api.ReadDatabaseYml(gitClient)
|
||
|
if err != nil {
|
||
|
monitor.Error(err)
|
||
|
return err
|
||
|
}
|
||
|
current := &tree.Tree{}
|
||
|
|
||
|
query, _, _, err := orbdb.AdaptFunc("", nil)(monitor, desired, current)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
queried := map[string]interface{}{}
|
||
|
_, err = query(k8sClient, queried)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
currentDB, err := coredb.ParseQueriedForDatabase(queried)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
deleteUser, err := currentDB.GetDeleteUserFunc()(user)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
return deleteUser(k8sClient)
|
||
|
}
|