summaryrefslogtreecommitdiffstats
path: root/cmd/mattermost/commands/roles.go
diff options
context:
space:
mode:
authorGeorge Goldberg <george@gberg.me>2018-05-31 10:25:31 +0100
committerGeorge Goldberg <george@gberg.me>2018-05-31 10:25:31 +0100
commit27e7841a734e9c3ed71f988a653f5865d2ef6f91 (patch)
tree1ccc65246fb166c25a9923f4e05ad7d6223892d1 /cmd/mattermost/commands/roles.go
parente39f5f46f3f6cdcb7ab8aeef8c601047f5942f85 (diff)
parent994ccf475f96bcad668269fe25b0d22e975bc222 (diff)
downloadchat-27e7841a734e9c3ed71f988a653f5865d2ef6f91.tar.gz
chat-27e7841a734e9c3ed71f988a653f5865d2ef6f91.tar.bz2
chat-27e7841a734e9c3ed71f988a653f5865d2ef6f91.zip
Merge branch 'advanced-permissions-phase-2'
Diffstat (limited to 'cmd/mattermost/commands/roles.go')
-rw-r--r--cmd/mattermost/commands/roles.go46
1 files changed, 44 insertions, 2 deletions
diff --git a/cmd/mattermost/commands/roles.go b/cmd/mattermost/commands/roles.go
index b8fdcdba2..f1c9d34c8 100644
--- a/cmd/mattermost/commands/roles.go
+++ b/cmd/mattermost/commands/roles.go
@@ -5,8 +5,11 @@ package commands
import (
"errors"
+ "strings"
"github.com/spf13/cobra"
+
+ "github.com/mattermost/mattermost-server/model"
)
var RolesCmd = &cobra.Command{
@@ -55,7 +58,27 @@ func makeSystemAdminCmdF(command *cobra.Command, args []string) error {
return errors.New("Unable to find user '" + args[i] + "'")
}
- if _, err := a.UpdateUserRoles(user.Id, "system_admin system_user", true); err != nil {
+ systemAdmin := false
+ systemUser := false
+
+ roles := strings.Fields(user.Roles)
+ for _, role := range roles {
+ switch role {
+ case model.SYSTEM_ADMIN_ROLE_ID:
+ systemAdmin = true
+ case model.SYSTEM_USER_ROLE_ID:
+ systemUser = true
+ }
+ }
+
+ if !systemUser {
+ roles = append(roles, model.SYSTEM_USER_ROLE_ID)
+ }
+ if !systemAdmin {
+ roles = append(roles, model.SYSTEM_ADMIN_ROLE_ID)
+ }
+
+ if _, err := a.UpdateUserRoles(user.Id, strings.Join(roles, " "), true); err != nil {
return err
}
}
@@ -80,7 +103,26 @@ func makeMemberCmdF(command *cobra.Command, args []string) error {
return errors.New("Unable to find user '" + args[i] + "'")
}
- if _, err := a.UpdateUserRoles(user.Id, "system_user", true); err != nil {
+ systemUser := false
+ var newRoles []string
+
+ roles := strings.Fields(user.Roles)
+ for _, role := range roles {
+ switch role {
+ case model.SYSTEM_ADMIN_ROLE_ID:
+ default:
+ if role == model.SYSTEM_USER_ROLE_ID {
+ systemUser = true
+ }
+ newRoles = append(newRoles, role)
+ }
+ }
+
+ if !systemUser {
+ newRoles = append(roles, model.SYSTEM_USER_ROLE_ID)
+ }
+
+ if _, err := a.UpdateUserRoles(user.Id, strings.Join(newRoles, " "), true); err != nil {
return err
}
}