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  }