github.com/jenspinney/cli@v6.42.1-0.20190207184520-7450c600020e+incompatible/cf/commands/user/set_space_role.go (about)

     1  package user
     2  
     3  import (
     4  	"fmt"
     5  
     6  	"code.cloudfoundry.org/cli/cf/flags"
     7  	. "code.cloudfoundry.org/cli/cf/i18n"
     8  
     9  	"code.cloudfoundry.org/cli/cf/api"
    10  	"code.cloudfoundry.org/cli/cf/api/featureflags"
    11  	"code.cloudfoundry.org/cli/cf/api/spaces"
    12  	"code.cloudfoundry.org/cli/cf/commandregistry"
    13  	"code.cloudfoundry.org/cli/cf/configuration/coreconfig"
    14  	"code.cloudfoundry.org/cli/cf/models"
    15  	"code.cloudfoundry.org/cli/cf/requirements"
    16  	"code.cloudfoundry.org/cli/cf/terminal"
    17  )
    18  
    19  //go:generate counterfeiter . SpaceRoleSetter
    20  
    21  type SpaceRoleSetter interface {
    22  	commandregistry.Command
    23  	SetSpaceRole(space models.Space, orgGUID, orgName string, role models.Role, userGUID, userName string) (err error)
    24  }
    25  
    26  type SetSpaceRole struct {
    27  	ui        terminal.UI
    28  	config    coreconfig.Reader
    29  	spaceRepo spaces.SpaceRepository
    30  	flagRepo  featureflags.FeatureFlagRepository
    31  	userRepo  api.UserRepository
    32  	userReq   requirements.UserRequirement
    33  	orgReq    requirements.OrganizationRequirement
    34  }
    35  
    36  func init() {
    37  	commandregistry.Register(&SetSpaceRole{})
    38  }
    39  
    40  func (cmd *SetSpaceRole) MetaData() commandregistry.CommandMetadata {
    41  	return commandregistry.CommandMetadata{
    42  		Name:        "set-space-role",
    43  		Description: T("Assign a space role to a user"),
    44  		Usage: []string{
    45  			T("CF_NAME set-space-role USERNAME ORG SPACE ROLE\n\n"),
    46  			T("ROLES:\n"),
    47  			fmt.Sprintf("   'SpaceManager' - %s", T("Invite and manage users, and enable features for a given space\n")),
    48  			fmt.Sprintf("   'SpaceDeveloper' - %s", T("Create and manage apps and services, and see logs and reports\n")),
    49  			fmt.Sprintf("   'SpaceAuditor' - %s", T("View logs, reports, and settings on this space\n")),
    50  		},
    51  	}
    52  }
    53  
    54  func (cmd *SetSpaceRole) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) ([]requirements.Requirement, error) {
    55  	if len(fc.Args()) != 4 {
    56  		cmd.ui.Failed(T("Incorrect Usage. Requires USERNAME, ORG, SPACE, ROLE as arguments\n\n") + commandregistry.Commands.CommandUsage("set-space-role"))
    57  		return nil, fmt.Errorf("Incorrect usage: %d arguments of %d required", len(fc.Args()), 4)
    58  	}
    59  
    60  	setRolesByUsernameFlag, err := cmd.flagRepo.FindByName("set_roles_by_username")
    61  	wantGUID := (err != nil || !setRolesByUsernameFlag.Enabled)
    62  
    63  	cmd.userReq = requirementsFactory.NewUserRequirement(fc.Args()[0], wantGUID)
    64  	cmd.orgReq = requirementsFactory.NewOrganizationRequirement(fc.Args()[1])
    65  
    66  	reqs := []requirements.Requirement{
    67  		requirementsFactory.NewLoginRequirement(),
    68  		cmd.userReq,
    69  		cmd.orgReq,
    70  	}
    71  
    72  	return reqs, nil
    73  }
    74  
    75  func (cmd *SetSpaceRole) SetDependency(deps commandregistry.Dependency, pluginCall bool) commandregistry.Command {
    76  	cmd.ui = deps.UI
    77  	cmd.config = deps.Config
    78  	cmd.spaceRepo = deps.RepoLocator.GetSpaceRepository()
    79  	cmd.userRepo = deps.RepoLocator.GetUserRepository()
    80  	cmd.flagRepo = deps.RepoLocator.GetFeatureFlagRepository()
    81  	return cmd
    82  }
    83  
    84  func (cmd *SetSpaceRole) Execute(c flags.FlagContext) error {
    85  	spaceName := c.Args()[2]
    86  	roleStr := c.Args()[3]
    87  	role, err := models.RoleFromString(roleStr)
    88  	if err != nil {
    89  		return err
    90  	}
    91  
    92  	userFields := cmd.userReq.GetUser()
    93  	org := cmd.orgReq.GetOrganization()
    94  
    95  	space, err := cmd.spaceRepo.FindByNameInOrg(spaceName, org.GUID)
    96  	if err != nil {
    97  		return err
    98  	}
    99  
   100  	err = cmd.SetSpaceRole(space, org.GUID, org.Name, role, userFields.GUID, userFields.Username)
   101  	if err != nil {
   102  		return err
   103  	}
   104  	return nil
   105  }
   106  
   107  func (cmd *SetSpaceRole) SetSpaceRole(space models.Space, orgGUID, orgName string, role models.Role, userGUID, username string) error {
   108  	var err error
   109  
   110  	cmd.ui.Say(T("Assigning role {{.Role}} to user {{.TargetUser}} in org {{.TargetOrg}} / space {{.TargetSpace}} as {{.CurrentUser}}...",
   111  		map[string]interface{}{
   112  			"Role":        terminal.EntityNameColor(role.ToString()),
   113  			"TargetUser":  terminal.EntityNameColor(username),
   114  			"TargetOrg":   terminal.EntityNameColor(orgName),
   115  			"TargetSpace": terminal.EntityNameColor(space.Name),
   116  			"CurrentUser": terminal.EntityNameColor(cmd.config.Username()),
   117  		}))
   118  
   119  	if len(userGUID) > 0 {
   120  		err = cmd.userRepo.SetSpaceRoleByGUID(userGUID, space.GUID, orgGUID, role)
   121  	} else {
   122  		err = cmd.userRepo.SetSpaceRoleByUsername(username, space.GUID, orgGUID, role)
   123  	}
   124  	if err != nil {
   125  		return err
   126  	}
   127  
   128  	cmd.ui.Ok()
   129  	return nil
   130  }