github.com/jenspinney/cli@v6.42.1-0.20190207184520-7450c600020e+incompatible/cf/commands/user/set_org_role.go (about) 1 package user 2 3 import ( 4 "fmt" 5 6 "code.cloudfoundry.org/cli/cf/api" 7 "code.cloudfoundry.org/cli/cf/api/featureflags" 8 "code.cloudfoundry.org/cli/cf/commandregistry" 9 "code.cloudfoundry.org/cli/cf/configuration/coreconfig" 10 "code.cloudfoundry.org/cli/cf/flags" 11 . "code.cloudfoundry.org/cli/cf/i18n" 12 "code.cloudfoundry.org/cli/cf/models" 13 "code.cloudfoundry.org/cli/cf/requirements" 14 "code.cloudfoundry.org/cli/cf/terminal" 15 ) 16 17 //go:generate counterfeiter . OrgRoleSetter 18 19 type OrgRoleSetter interface { 20 commandregistry.Command 21 SetOrgRole(orgGUID string, role models.Role, userGUID, userName string) error 22 } 23 24 type SetOrgRole struct { 25 ui terminal.UI 26 config coreconfig.Reader 27 flagRepo featureflags.FeatureFlagRepository 28 userRepo api.UserRepository 29 userReq requirements.UserRequirement 30 orgReq requirements.OrganizationRequirement 31 } 32 33 func init() { 34 commandregistry.Register(&SetOrgRole{}) 35 } 36 37 func (cmd *SetOrgRole) MetaData() commandregistry.CommandMetadata { 38 return commandregistry.CommandMetadata{ 39 Name: "set-org-role", 40 Description: T("Assign an org role to a user"), 41 Usage: []string{ 42 T("CF_NAME set-org-role USERNAME ORG ROLE\n\n"), 43 T("ROLES:\n"), 44 fmt.Sprintf(" 'OrgManager' - %s", T("Invite and manage users, select and change plans, and set spending limits\n")), 45 fmt.Sprintf(" 'BillingManager' - %s", T("Create and manage the billing account and payment info\n")), 46 fmt.Sprintf(" 'OrgAuditor' - %s", T("Read-only access to org info and reports\n")), 47 }, 48 } 49 } 50 51 func (cmd *SetOrgRole) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) ([]requirements.Requirement, error) { 52 if len(fc.Args()) != 3 { 53 cmd.ui.Failed(T("Incorrect Usage. Requires USERNAME, ORG, ROLE as arguments\n\n") + commandregistry.Commands.CommandUsage("set-org-role")) 54 return nil, fmt.Errorf("Incorrect usage: %d arguments of %d required", len(fc.Args()), 3) 55 } 56 57 setRolesByUsernameFlag, err := cmd.flagRepo.FindByName("set_roles_by_username") 58 wantGUID := (err != nil || !setRolesByUsernameFlag.Enabled) 59 60 cmd.userReq = requirementsFactory.NewUserRequirement(fc.Args()[0], wantGUID) 61 cmd.orgReq = requirementsFactory.NewOrganizationRequirement(fc.Args()[1]) 62 63 reqs := []requirements.Requirement{ 64 requirementsFactory.NewLoginRequirement(), 65 cmd.userReq, 66 cmd.orgReq, 67 } 68 69 return reqs, nil 70 } 71 72 func (cmd *SetOrgRole) SetDependency(deps commandregistry.Dependency, pluginCall bool) commandregistry.Command { 73 cmd.ui = deps.UI 74 cmd.config = deps.Config 75 cmd.userRepo = deps.RepoLocator.GetUserRepository() 76 cmd.flagRepo = deps.RepoLocator.GetFeatureFlagRepository() 77 return cmd 78 } 79 80 func (cmd *SetOrgRole) Execute(c flags.FlagContext) error { 81 user := cmd.userReq.GetUser() 82 org := cmd.orgReq.GetOrganization() 83 roleStr := c.Args()[2] 84 role, err := models.RoleFromString(roleStr) 85 if err != nil { 86 return err 87 } 88 89 cmd.ui.Say(T("Assigning role {{.Role}} to user {{.TargetUser}} in org {{.TargetOrg}} as {{.CurrentUser}}...", 90 map[string]interface{}{ 91 "Role": terminal.EntityNameColor(roleStr), 92 "TargetUser": terminal.EntityNameColor(user.Username), 93 "TargetOrg": terminal.EntityNameColor(org.Name), 94 "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), 95 })) 96 97 err = cmd.SetOrgRole(org.GUID, role, user.GUID, user.Username) 98 if err != nil { 99 return err 100 } 101 102 cmd.ui.Ok() 103 return nil 104 } 105 106 func (cmd *SetOrgRole) SetOrgRole(orgGUID string, role models.Role, userGUID, userName string) error { 107 if len(userGUID) > 0 { 108 return cmd.userRepo.SetOrgRoleByGUID(userGUID, orgGUID, role) 109 } 110 111 return cmd.userRepo.SetOrgRoleByUsername(userName, orgGUID, role) 112 }