github.com/ablease/cli@v6.37.1-0.20180613014814-3adbb7d7fb19+incompatible/cf/commands/service/create_user_provided_service.go (about) 1 package service 2 3 import ( 4 "encoding/json" 5 "strings" 6 7 "code.cloudfoundry.org/cli/cf" 8 "code.cloudfoundry.org/cli/cf/flagcontext" 9 "code.cloudfoundry.org/cli/cf/flags" 10 . "code.cloudfoundry.org/cli/cf/i18n" 11 "code.cloudfoundry.org/cli/cf/uihelpers" 12 13 "fmt" 14 15 "code.cloudfoundry.org/cli/cf/api" 16 "code.cloudfoundry.org/cli/cf/commandregistry" 17 "code.cloudfoundry.org/cli/cf/configuration/coreconfig" 18 "code.cloudfoundry.org/cli/cf/requirements" 19 "code.cloudfoundry.org/cli/cf/terminal" 20 ) 21 22 type CreateUserProvidedService struct { 23 ui terminal.UI 24 config coreconfig.Reader 25 userProvidedServiceInstanceRepo api.UserProvidedServiceInstanceRepository 26 } 27 28 func init() { 29 commandregistry.Register(&CreateUserProvidedService{}) 30 } 31 32 func (cmd *CreateUserProvidedService) MetaData() commandregistry.CommandMetadata { 33 fs := make(map[string]flags.FlagSet) 34 fs["p"] = &flags.StringFlag{ShortName: "p", Usage: T("Credentials, provided inline or in a file, to be exposed in the VCAP_SERVICES environment variable for bound applications")} 35 fs["l"] = &flags.StringFlag{ShortName: "l", Usage: T("URL to which logs for bound applications will be streamed")} 36 fs["r"] = &flags.StringFlag{ShortName: "r", Usage: T("URL to which requests for bound routes will be forwarded. Scheme for this URL must be https")} 37 fs["t"] = &flags.StringFlag{ShortName: "t", Usage: T("User provided tags")} 38 39 return commandregistry.CommandMetadata{ 40 Name: "create-user-provided-service", 41 ShortName: "cups", 42 Description: T("Make a user-provided service instance available to CF apps"), 43 Usage: []string{ 44 T(`CF_NAME create-user-provided-service SERVICE_INSTANCE [-p CREDENTIALS] [-l SYSLOG_DRAIN_URL] [-r ROUTE_SERVICE_URL] [-t TAGS] 45 46 Pass comma separated credential parameter names to enable interactive mode: 47 CF_NAME create-user-provided-service SERVICE_INSTANCE -p "comma, separated, parameter, names" 48 49 Pass credential parameters as JSON to create a service non-interactively: 50 CF_NAME create-user-provided-service SERVICE_INSTANCE -p '{"key1":"value1","key2":"value2"}' 51 52 Specify a path to a file containing JSON: 53 CF_NAME create-user-provided-service SERVICE_INSTANCE -p PATH_TO_FILE`), 54 }, 55 Examples: []string{ 56 `CF_NAME create-user-provided-service my-db-mine -p "username, password"`, 57 `CF_NAME create-user-provided-service my-db-mine -p /path/to/credentials.json`, 58 `CF_NAME create-user-provided-service my-db-mine -t "list, of, tags"`, 59 `CF_NAME create-user-provided-service my-drain-service -l syslog://example.com`, 60 `CF_NAME create-user-provided-service my-route-service -r https://example.com`, 61 ``, 62 fmt.Sprintf("%s:", T(`Linux/Mac`)), 63 ` CF_NAME create-user-provided-service my-db-mine -p '{"username":"admin","password":"pa55woRD"}'`, 64 ``, 65 fmt.Sprintf("%s:", T(`Windows Command Line`)), 66 ` CF_NAME create-user-provided-service my-db-mine -p "{\"username\":\"admin\",\"password\":\"pa55woRD\"}"`, 67 ``, 68 fmt.Sprintf("%s:", T(`Windows PowerShell`)), 69 ` CF_NAME create-user-provided-service my-db-mine -p '{\"username\":\"admin\",\"password\":\"pa55woRD\"}'`, 70 }, 71 Flags: fs, 72 } 73 } 74 75 func (cmd *CreateUserProvidedService) Requirements(requirementsFactory requirements.Factory, fc flags.FlagContext) ([]requirements.Requirement, error) { 76 if len(fc.Args()) != 1 { 77 cmd.ui.Failed(T("Incorrect Usage. Requires an argument\n\n") + commandregistry.Commands.CommandUsage("create-user-provided-service")) 78 return nil, fmt.Errorf("Incorrect usage: %d arguments of %d required", len(fc.Args()), 1) 79 } 80 81 reqs := []requirements.Requirement{ 82 requirementsFactory.NewLoginRequirement(), 83 requirementsFactory.NewTargetedSpaceRequirement(), 84 } 85 86 if fc.IsSet("r") { 87 reqs = append(reqs, requirementsFactory.NewMinAPIVersionRequirement("Option '-r'", cf.MultipleAppPortsMinimumAPIVersion)) 88 } 89 90 if fc.IsSet("t") { 91 reqs = append(reqs, requirementsFactory.NewMinAPIVersionRequirement("Option '-t'", cf.UserProvidedServiceTagsMinimumAPIVersion)) 92 } 93 94 return reqs, nil 95 } 96 97 func (cmd *CreateUserProvidedService) SetDependency(deps commandregistry.Dependency, pluginCall bool) commandregistry.Command { 98 cmd.ui = deps.UI 99 cmd.config = deps.Config 100 cmd.userProvidedServiceInstanceRepo = deps.RepoLocator.GetUserProvidedServiceInstanceRepository() 101 return cmd 102 } 103 104 func (cmd *CreateUserProvidedService) Execute(c flags.FlagContext) error { 105 name := c.Args()[0] 106 drainURL := c.String("l") 107 routeServiceURL := c.String("r") 108 credentials := strings.Trim(c.String("p"), `"'`) 109 credentialsMap := make(map[string]interface{}) 110 tags := c.String("t") 111 tagsList := uihelpers.ParseTags(tags) 112 113 if c.IsSet("p") { 114 jsonBytes, err := flagcontext.GetContentsFromFlagValue(credentials) 115 if err != nil { 116 return err 117 } 118 119 err = json.Unmarshal(jsonBytes, &credentialsMap) 120 if err != nil { 121 for _, param := range strings.Split(credentials, ",") { 122 param = strings.Trim(param, " ") 123 credentialsMap[param] = cmd.ui.Ask(param) 124 } 125 } 126 } 127 128 cmd.ui.Say(T("Creating user provided service {{.ServiceName}} in org {{.OrgName}} / space {{.SpaceName}} as {{.CurrentUser}}...", 129 map[string]interface{}{ 130 "ServiceName": terminal.EntityNameColor(name), 131 "OrgName": terminal.EntityNameColor(cmd.config.OrganizationFields().Name), 132 "SpaceName": terminal.EntityNameColor(cmd.config.SpaceFields().Name), 133 "CurrentUser": terminal.EntityNameColor(cmd.config.Username()), 134 })) 135 136 err := cmd.userProvidedServiceInstanceRepo.Create(name, drainURL, routeServiceURL, credentialsMap, tagsList) 137 if err != nil { 138 return err 139 } 140 141 cmd.ui.Ok() 142 return nil 143 }