func (cmd *RenameService) Execute(c flags.FlagContext) error { newName := c.Args()[1] serviceInstance := cmd.serviceInstanceReq.GetServiceInstance() cmd.ui.Say(T("Renaming service {{.ServiceName}} to {{.NewServiceName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.CurrentUser}}...", map[string]interface{}{ "ServiceName": terminal.EntityNameColor(serviceInstance.Name), "NewServiceName": terminal.EntityNameColor(newName), "OrgName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) err := cmd.serviceRepo.RenameService(serviceInstance, newName) if err != nil { if httpError, ok := err.(errors.HTTPError); ok && httpError.ErrorCode() == errors.ServiceInstanceNameTaken { return errors.New(T("{{.ErrorDescription}}\nTIP: Use '{{.CFServicesCommand}}' to view all services in this org and space.", map[string]interface{}{ "ErrorDescription": httpError.Error(), "CFServicesCommand": cf.Name + " " + "services", })) } return err } cmd.ui.Ok() return nil }
func (cmd *AddPluginRepo) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) (reqs []requirements.Requirement, err error) { if len(fc.Args()) != 2 { cmd.ui.Failed(T("Incorrect Usage. Requires [REPO_NAME] [URL] as arguments\n\n") + command_registry.Commands.CommandUsage("add-plugin-repo")) } return }
func (cmd *Env) Execute(c flags.FlagContext) { app, err := cmd.appRepo.Read(c.Args()[0]) if notFound, ok := err.(*errors.ModelNotFoundError); ok { cmd.ui.Failed(notFound.Error()) } cmd.ui.Say(T("Getting env variables for app {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.Username}}...", map[string]interface{}{ "AppName": terminal.EntityNameColor(app.Name), "OrgName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), "Username": terminal.EntityNameColor(cmd.config.Username())})) env, err := cmd.appRepo.ReadEnv(app.GUID) if err != nil { cmd.ui.Failed(err.Error()) } cmd.ui.Ok() cmd.ui.Say("") cmd.displaySystemiAndAppProvidedEnvironment(env.System, env.Application) cmd.ui.Say("") cmd.displayUserProvidedEnvironment(env.Environment) cmd.ui.Say("") cmd.displayRunningEnvironment(env.Running) cmd.ui.Say("") cmd.displayStagingEnvironment(env.Staging) cmd.ui.Say("") }
func (cmd *DeleteServiceBroker) Execute(c flags.FlagContext) { brokerName := c.Args()[0] if !c.Bool("f") && !cmd.ui.ConfirmDelete(T("service-broker"), brokerName) { return } cmd.ui.Say(T("Deleting service broker {{.Name}} as {{.Username}}...", map[string]interface{}{ "Name": terminal.EntityNameColor(brokerName), "Username": terminal.EntityNameColor(cmd.config.Username()), })) broker, apiErr := cmd.repo.FindByName(brokerName) switch apiErr.(type) { case nil: case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("Service Broker {{.Name}} does not exist.", map[string]interface{}{"Name": brokerName})) return default: cmd.ui.Failed(apiErr.Error()) return } apiErr = cmd.repo.Delete(broker.GUID) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Ok() return }
func (cmd *PluginUninstall) Execute(c flags.FlagContext) error { pluginName := c.Args()[0] pluginNameMap := map[string]interface{}{"PluginName": pluginName} cmd.ui.Say(fmt.Sprintf(T("Uninstalling plugin {{.PluginName}}...", pluginNameMap))) plugins := cmd.config.Plugins() if _, ok := plugins[pluginName]; !ok { return errors.New(fmt.Sprintf(T("Plugin name {{.PluginName}} does not exist", pluginNameMap))) } pluginMetadata := plugins[pluginName] warn, err := cmd.notifyPluginUninstalling(pluginMetadata) if err != nil { return err } if warn != nil { cmd.ui.Say("Error invoking plugin: " + warn.Error() + ". Process to uninstall ...") } time.Sleep(500 * time.Millisecond) //prevent 'process being used' error in Windows err = os.Remove(pluginMetadata.Location) if err != nil { cmd.ui.Warn("Error removing plugin binary: " + err.Error()) } cmd.config.RemovePlugin(pluginName) cmd.ui.Ok() cmd.ui.Say(fmt.Sprintf(T("Plugin {{.PluginName}} successfully uninstalled.", pluginNameMap))) return nil }
func (cmd *DeleteOrphanedRoutes) Execute(c flags.FlagContext) { force := c.Bool("f") if !force { response := cmd.ui.Confirm(T("Really delete orphaned routes?{{.Prompt}}", map[string]interface{}{"Prompt": terminal.PromptColor(">")})) if !response { return } } cmd.ui.Say(T("Getting routes as {{.Username}} ...\n", map[string]interface{}{"Username": terminal.EntityNameColor(cmd.config.Username())})) apiErr := cmd.routeRepo.ListRoutes(func(route models.Route) bool { if len(route.Apps) == 0 { cmd.ui.Say(T("Deleting route {{.Route}}...", map[string]interface{}{"Route": terminal.EntityNameColor(route.Host + "." + route.Domain.Name)})) apiErr := cmd.routeRepo.Delete(route.Guid) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return false } } return true }) if apiErr != nil { cmd.ui.Failed(T("Failed fetching routes.\n{{.Err}}", map[string]interface{}{"Err": apiErr.Error()})) return } cmd.ui.Ok() }
func (cmd *unbindFromStagingGroup) Execute(context flags.FlagContext) error { name := context.Args()[0] cmd.ui.Say(T("Unbinding security group {{.security_group}} from defaults for staging as {{.username}}", map[string]interface{}{ "security_group": terminal.EntityNameColor(name), "username": terminal.EntityNameColor(cmd.configRepo.Username()), })) securityGroup, err := cmd.securityGroupRepo.Read(name) switch (err).(type) { case nil: case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("Security group {{.security_group}} {{.error_message}}", map[string]interface{}{ "security_group": terminal.EntityNameColor(name), "error_message": terminal.WarningColor(T("does not exist.")), })) return nil default: return err } err = cmd.stagingGroupRepo.UnbindFromStagingSet(securityGroup.GUID) if err != nil { return err } cmd.ui.Ok() cmd.ui.Say("\n\n") cmd.ui.Say(T("TIP: Changes will not apply to existing running applications until they are restarted.")) return nil }
func (cmd *SetOrgRole) Execute(c flags.FlagContext) error { user := cmd.userReq.GetUser() org := cmd.orgReq.GetOrganization() roleStr := c.Args()[2] role, err := models.RoleFromString(roleStr) if err != nil { return err } cmd.ui.Say(T("Assigning role {{.Role}} to user {{.TargetUser}} in org {{.TargetOrg}} as {{.CurrentUser}}...", map[string]interface{}{ "Role": terminal.EntityNameColor(roleStr), "TargetUser": terminal.EntityNameColor(user.Username), "TargetOrg": terminal.EntityNameColor(org.Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) err = cmd.SetOrgRole(org.GUID, role, user.GUID, user.Username) if err != nil { return err } cmd.ui.Ok() return nil }
func (cmd Login) setOrganization(c flags.FlagContext) (bool, error) { orgName := c.String("o") if orgName == "" { orgs, err := cmd.orgRepo.ListOrgs(maxChoices) if err != nil { return false, errors.New(T("Error finding available orgs\n{{.APIErr}}", map[string]interface{}{"APIErr": err.Error()})) } switch len(orgs) { case 0: return false, nil case 1: cmd.targetOrganization(orgs[0]) return true, nil default: orgName = cmd.promptForOrgName(orgs) if orgName == "" { cmd.ui.Say("") return false, nil } } } org, err := cmd.orgRepo.FindByName(orgName) if err != nil { return false, errors.New(T("Error finding org {{.OrgName}}\n{{.Err}}", map[string]interface{}{"OrgName": terminal.EntityNameColor(orgName), "Err": err.Error()})) } cmd.targetOrganization(org) return true, nil }
func (cmd *UnsetEnv) Execute(c flags.FlagContext) { varName := c.Args()[1] app := cmd.appReq.GetApplication() cmd.ui.Say(T("Removing env variable {{.VarName}} from app {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.CurrentUser}}...", map[string]interface{}{ "VarName": terminal.EntityNameColor(varName), "AppName": terminal.EntityNameColor(app.Name), "OrgName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username())})) envParams := app.EnvironmentVars if _, ok := envParams[varName]; !ok { cmd.ui.Ok() cmd.ui.Warn(T("Env variable {{.VarName}} was not set.", map[string]interface{}{"VarName": varName})) return } delete(envParams, varName) _, apiErr := cmd.appRepo.Update(app.Guid, models.AppParams{EnvironmentVars: &envParams}) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Ok() cmd.ui.Say(T("TIP: Use '{{.Command}}' to ensure your env variable changes take effect", map[string]interface{}{"Command": terminal.CommandColor(cf.Name() + " restage")})) }
func (cmd *PluginUninstall) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) (reqs []requirements.Requirement, err error) { if len(fc.Args()) != 1 { cmd.ui.Failed(T("Incorrect Usage. Requires an argument\n\n") + command_registry.Commands.CommandUsage("uninstall-plugin")) } return }
func (cmd *DeleteSpaceQuota) Execute(c flags.FlagContext) { quotaName := c.Args()[0] if !c.Bool("f") { response := cmd.ui.ConfirmDelete("quota", quotaName) if !response { return } } cmd.ui.Say(T("Deleting space quota {{.QuotaName}} as {{.Username}}...", map[string]interface{}{ "QuotaName": terminal.EntityNameColor(quotaName), "Username": terminal.EntityNameColor(cmd.config.Username()), })) quota, apiErr := cmd.spaceQuotaRepo.FindByName(quotaName) switch (apiErr).(type) { case nil: // no error case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("Quota {{.QuotaName}} does not exist", map[string]interface{}{"QuotaName": quotaName})) return default: cmd.ui.Failed(apiErr.Error()) } apiErr = cmd.spaceQuotaRepo.Delete(quota.Guid) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) } cmd.ui.Ok() }
func (cmd *DeleteSecurityGroup) Execute(context flags.FlagContext) { name := context.Args()[0] cmd.ui.Say(T("Deleting security group {{.security_group}} as {{.username}}", map[string]interface{}{ "security_group": terminal.EntityNameColor(name), "username": terminal.EntityNameColor(cmd.configRepo.Username()), })) if !context.Bool("f") { response := cmd.ui.ConfirmDelete(T("security group"), name) if !response { return } } group, err := cmd.securityGroupRepo.Read(name) switch err.(type) { case nil: case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("Security group {{.security_group}} does not exist", map[string]interface{}{"security_group": name})) return default: cmd.ui.Failed(err.Error()) } err = cmd.securityGroupRepo.Delete(group.Guid) if err != nil { cmd.ui.Failed(err.Error()) } cmd.ui.Ok() }
func (cmd *ShowSecurityGroup) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) (reqs []requirements.Requirement, err error) { if len(fc.Args()) != 1 { cmd.ui.Failed(T("Incorrect Usage. Requires an argument\n\n") + command_registry.Commands.CommandUsage("security-group")) } return []requirements.Requirement{requirementsFactory.NewLoginRequirement()}, nil }
func (cmd *RepoPlugins) Execute(c flags.FlagContext) { var repos []models.PluginRepo repoName := c.String("r") repos = cmd.config.PluginRepos() if repoName == "" { cmd.ui.Say(T("Getting plugins from all repositories ... ")) } else { index := cmd.findRepoIndex(repoName) if index != -1 { cmd.ui.Say(T("Getting plugins from repository '") + repoName + "' ...") repos = []models.PluginRepo{repos[index]} } else { cmd.ui.Failed(repoName + T(" does not exist as an available plugin repo."+"\nTip: use `add-plugin-repo` command to add repos.")) } } cmd.ui.Say("") repoPlugins, repoError := cmd.pluginRepo.GetPlugins(repos) cmd.printTable(repoPlugins) cmd.printErrors(repoError) }
func (cmd *ListStack) Execute(c flags.FlagContext) { stackName := c.Args()[0] stack, apiErr := cmd.stacksRepo.FindByName(stackName) if c.Bool("guid") { cmd.ui.Say(stack.GUID) } else { if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Say(T("Getting stack '{{.Stack}}' in org {{.OrganizationName}} / space {{.SpaceName}} as {{.Username}}...", map[string]interface{}{"Stack": stackName, "OrganizationName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), "Username": terminal.EntityNameColor(cmd.config.Username())})) cmd.ui.Ok() cmd.ui.Say("") table := cmd.ui.Table([]string{T("name"), T("description")}) table.Add(stack.Name, stack.Description) table.Print() } }
func (cmd *Plugins) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) (reqs []requirements.Requirement, err error) { if len(fc.Args()) != 0 { cmd.ui.Failed(T("Incorrect Usage. No argument required\n\n") + command_registry.Commands.CommandUsage("plugins")) } return }
func (cmd *UnsetOrgRole) Execute(c flags.FlagContext) { user := cmd.userReq.GetUser() org := cmd.orgReq.GetOrganization() role := models.UserInputToOrgRole[c.Args()[2]] cmd.ui.Say(T("Removing role {{.Role}} from user {{.TargetUser}} in org {{.TargetOrg}} as {{.CurrentUser}}...", map[string]interface{}{ "Role": terminal.EntityNameColor(role), "TargetUser": terminal.EntityNameColor(c.Args()[0]), "TargetOrg": terminal.EntityNameColor(c.Args()[1]), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) var err error if len(user.Guid) > 0 { err = cmd.userRepo.UnsetOrgRoleByGuid(user.Guid, org.Guid, role) } else { err = cmd.userRepo.UnsetOrgRoleByUsername(user.Username, org.Guid, role) } if err != nil { cmd.ui.Failed(err.Error()) } cmd.ui.Ok() }
func (cmd *DeleteUser) Execute(c flags.FlagContext) { username := c.Args()[0] force := c.Bool("f") if !force && !cmd.ui.ConfirmDelete(T("user"), username) { return } cmd.ui.Say(T("Deleting user {{.TargetUser}} as {{.CurrentUser}}...", map[string]interface{}{ "TargetUser": terminal.EntityNameColor(username), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) user, apiErr := cmd.userRepo.FindByUsername(username) switch apiErr.(type) { case nil: case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("User {{.TargetUser}} does not exist.", map[string]interface{}{"TargetUser": username})) return default: cmd.ui.Failed(apiErr.Error()) return } apiErr = cmd.userRepo.Delete(user.Guid) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Ok() }
func (cmd *SetEnv) Execute(c flags.FlagContext) { varName := c.Args()[1] varValue := c.Args()[2] app := cmd.appReq.GetApplication() cmd.ui.Say(T("Setting env variable '{{.VarName}}' to '{{.VarValue}}' for app {{.AppName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.CurrentUser}}...", map[string]interface{}{ "VarName": terminal.EntityNameColor(varName), "VarValue": terminal.EntityNameColor(varValue), "AppName": terminal.EntityNameColor(app.Name), "OrgName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username())})) if len(app.EnvironmentVars) == 0 { app.EnvironmentVars = map[string]interface{}{} } envParams := app.EnvironmentVars envParams[varName] = varValue _, apiErr := cmd.appRepo.Update(app.Guid, models.AppParams{EnvironmentVars: &envParams}) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Ok() cmd.ui.Say(T("TIP: Use '{{.Command}}' to ensure your env variable changes take effect", map[string]interface{}{"Command": terminal.CommandColor(cf.Name + " restage")})) }
func (cmd *SetHealthCheck) Execute(fc flags.FlagContext) error { healthCheckType := fc.Args()[1] app := cmd.appReq.GetApplication() if app.HealthCheckType == healthCheckType { cmd.ui.Say(fmt.Sprintf("%s "+T("health_check_type is already set")+" to '%s'", app.Name, app.HealthCheckType)) return nil } cmd.ui.Say(fmt.Sprintf(T("Updating %s health_check_type to '%s'"), app.Name, healthCheckType)) cmd.ui.Say("") updatedApp, err := cmd.appRepo.Update(app.GUID, models.AppParams{HealthCheckType: &healthCheckType}) if err != nil { return errors.New(T("Error updating health_check_type for ") + app.Name + ": " + err.Error()) } if updatedApp.HealthCheckType == healthCheckType { cmd.ui.Ok() } else { return errors.New(T("health_check_type is not set to ") + healthCheckType + T(" for ") + app.Name) } return nil }
func (cmd *DeleteSpace) Execute(c flags.FlagContext) error { spaceName := c.Args()[0] if !c.Bool("f") { if !cmd.ui.ConfirmDelete(T("space"), spaceName) { return nil } } cmd.ui.Say(T("Deleting space {{.TargetSpace}} in org {{.TargetOrg}} as {{.CurrentUser}}...", map[string]interface{}{ "TargetSpace": terminal.EntityNameColor(spaceName), "TargetOrg": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) space := cmd.spaceReq.GetSpace() err := cmd.spaceRepo.Delete(space.GUID) if err != nil { return err } cmd.ui.Ok() if cmd.config.SpaceFields().GUID == space.GUID { cmd.config.SetSpaceFields(models.SpaceFields{}) cmd.ui.Say(T("TIP: No space targeted, use '{{.CfTargetCommand}}' to target a space", map[string]interface{}{"CfTargetCommand": cf.Name + " target -s"})) } return nil }
func (cmd *UnsetSpaceRole) Execute(c flags.FlagContext) error { spaceName := c.Args()[2] roleStr := c.Args()[3] role, err := models.RoleFromString(roleStr) if err != nil { return err } user := cmd.userReq.GetUser() org := cmd.orgReq.GetOrganization() space, err := cmd.spaceRepo.FindByNameInOrg(spaceName, org.GUID) if err != nil { return err } cmd.ui.Say(T("Removing role {{.Role}} from user {{.TargetUser}} in org {{.TargetOrg}} / space {{.TargetSpace}} as {{.CurrentUser}}...", map[string]interface{}{ "Role": terminal.EntityNameColor(roleStr), "TargetUser": terminal.EntityNameColor(user.Username), "TargetOrg": terminal.EntityNameColor(org.Name), "TargetSpace": terminal.EntityNameColor(space.Name), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) if len(user.GUID) > 0 { err = cmd.userRepo.UnsetSpaceRoleByGUID(user.GUID, space.GUID, role) } else { err = cmd.userRepo.UnsetSpaceRoleByUsername(user.Username, space.GUID, role) } if err != nil { return err } cmd.ui.Ok() return nil }
func (cmd *Target) Execute(c flags.FlagContext) { orgName := c.String("o") spaceName := c.String("s") if orgName != "" { err := cmd.setOrganization(orgName) if err != nil { cmd.ui.Failed(err.Error()) } else if spaceName == "" { spaceList, apiErr := cmd.getSpaceList() if apiErr == nil && len(spaceList) == 1 { cmd.setSpace(spaceList[0].Name) } } } if spaceName != "" { err := cmd.setSpace(spaceName) if err != nil { cmd.ui.Failed(err.Error()) } } cmd.ui.ShowConfiguration(cmd.config) if !cmd.config.IsLoggedIn() { cmd.ui.PanicQuietly() } cmd.ui.NotifyUpdateIfNeeded(cmd.config) return }
func (cmd *EnableServiceAccess) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) (reqs []requirements.Requirement, err error) { if len(fc.Args()) != 1 { cmd.ui.Failed(T("Incorrect Usage. Requires an argument\n\n") + command_registry.Commands.CommandUsage("enable-service-access")) } return []requirements.Requirement{requirementsFactory.NewLoginRequirement()}, nil }
func (cmd *DeleteQuota) Execute(c flags.FlagContext) error { quotaName := c.Args()[0] if !c.Bool("f") { response := cmd.ui.ConfirmDelete("quota", quotaName) if !response { return nil } } cmd.ui.Say(T("Deleting quota {{.QuotaName}} as {{.Username}}...", map[string]interface{}{ "QuotaName": terminal.EntityNameColor(quotaName), "Username": terminal.EntityNameColor(cmd.config.Username()), })) quota, err := cmd.quotaRepo.FindByName(quotaName) switch (err).(type) { case nil: // no error case *errors.ModelNotFoundError: cmd.ui.Ok() cmd.ui.Warn(T("Quota {{.QuotaName}} does not exist", map[string]interface{}{"QuotaName": quotaName})) return nil default: return err } err = cmd.quotaRepo.Delete(quota.GUID) if err != nil { return err } cmd.ui.Ok() return err }
func (cmd *OrgUsers) printer(c flags.FlagContext) userprint.UserPrinter { var roles []string if c.Bool("a") { roles = []string{models.ORG_USER} } else { roles = []string{models.ORG_MANAGER, models.BILLING_MANAGER, models.ORG_AUDITOR} } if cmd.pluginCall { return userprint.NewOrgUsersPluginPrinter( cmd.pluginModel, cmd.userLister(), roles, ) } return &userprint.OrgUsersUiPrinter{ Ui: cmd.ui, UserLister: cmd.userLister(), Roles: roles, RoleDisplayNames: map[string]string{ models.ORG_USER: T("USERS"), models.ORG_MANAGER: T("ORG MANAGER"), models.BILLING_MANAGER: T("BILLING MANAGER"), models.ORG_AUDITOR: T("ORG AUDITOR"), }, } }
func (cmd *UnsetSpaceQuota) Execute(c flags.FlagContext) { spaceName := c.Args()[0] quotaName := c.Args()[1] space, apiErr := cmd.spaceRepo.FindByName(spaceName) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } quota, apiErr := cmd.quotaRepo.FindByName(quotaName) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Say(T("Unassigning space quota {{.QuotaName}} from space {{.SpaceName}} as {{.Username}}...", map[string]interface{}{ "QuotaName": terminal.EntityNameColor(quota.Name), "SpaceName": terminal.EntityNameColor(space.Name), "Username": terminal.EntityNameColor(cmd.config.Username())})) apiErr = cmd.quotaRepo.UnassignQuotaFromSpace(space.GUID, quota.GUID) if apiErr != nil { cmd.ui.Failed(apiErr.Error()) return } cmd.ui.Ok() }
func (cmd *ShowService) Execute(c flags.FlagContext) { serviceInstance := cmd.serviceInstanceReq.GetServiceInstance() if cmd.pluginCall { cmd.populatePluginModel(serviceInstance) return } if c.Bool("guid") { cmd.ui.Say(serviceInstance.Guid) } else { cmd.ui.Say("") cmd.ui.Say(T("Service instance: {{.ServiceName}}", map[string]interface{}{"ServiceName": terminal.EntityNameColor(serviceInstance.Name)})) if serviceInstance.IsUserProvided() { cmd.ui.Say(T("Service: {{.ServiceDescription}}", map[string]interface{}{ "ServiceDescription": terminal.EntityNameColor(T("user-provided")), })) } else { cmd.ui.Say(T("Service: {{.ServiceDescription}}", map[string]interface{}{ "ServiceDescription": terminal.EntityNameColor(serviceInstance.ServiceOffering.Label), })) cmd.ui.Say(T("Plan: {{.ServicePlanName}}", map[string]interface{}{ "ServicePlanName": terminal.EntityNameColor(serviceInstance.ServicePlan.Name), })) cmd.ui.Say(T("Description: {{.ServiceDescription}}", map[string]interface{}{"ServiceDescription": terminal.EntityNameColor(serviceInstance.ServiceOffering.Description)})) cmd.ui.Say(T("Documentation url: {{.URL}}", map[string]interface{}{ "URL": terminal.EntityNameColor(serviceInstance.ServiceOffering.DocumentationUrl), })) cmd.ui.Say(T("Dashboard: {{.URL}}", map[string]interface{}{ "URL": terminal.EntityNameColor(serviceInstance.DashboardUrl), })) cmd.ui.Say("") cmd.ui.Say(T("Last Operation")) cmd.ui.Say(T("Status: {{.State}}", map[string]interface{}{ "State": terminal.EntityNameColor(ServiceInstanceStateToStatus(serviceInstance.LastOperation.Type, serviceInstance.LastOperation.State, serviceInstance.IsUserProvided())), })) cmd.ui.Say(T("Message: {{.Message}}", map[string]interface{}{ "Message": terminal.EntityNameColor(serviceInstance.LastOperation.Description), })) if "" != serviceInstance.LastOperation.CreatedAt { cmd.ui.Say(T("Started: {{.Started}}", map[string]interface{}{ "Started": terminal.EntityNameColor(serviceInstance.LastOperation.CreatedAt), })) } cmd.ui.Say(T("Updated: {{.Updated}}", map[string]interface{}{ "Updated": terminal.EntityNameColor(serviceInstance.LastOperation.UpdatedAt), })) } } }
func (cmd *CreateServiceKey) Execute(c flags.FlagContext) { serviceInstance := cmd.serviceInstanceRequirement.GetServiceInstance() serviceKeyName := c.Args()[1] params := c.String("c") paramsMap, err := json.ParseJsonFromFileOrString(params) if err != nil { cmd.ui.Failed(T("Invalid configuration provided for -c flag. Please provide a valid JSON object or path to a file containing a valid JSON object.")) } cmd.ui.Say(T("Creating service key {{.ServiceKeyName}} for service instance {{.ServiceInstanceName}} as {{.CurrentUser}}...", map[string]interface{}{ "ServiceInstanceName": terminal.EntityNameColor(serviceInstance.Name), "ServiceKeyName": terminal.EntityNameColor(serviceKeyName), "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), })) err = cmd.serviceKeyRepo.CreateServiceKey(serviceInstance.Guid, serviceKeyName, paramsMap) switch err.(type) { case nil: cmd.ui.Ok() case *errors.ModelAlreadyExistsError: cmd.ui.Ok() cmd.ui.Warn(err.Error()) default: cmd.ui.Failed(err.Error()) } }