-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathresources.go
More file actions
334 lines (252 loc) · 7.37 KB
/
resources.go
File metadata and controls
334 lines (252 loc) · 7.37 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
package parser
import (
docopt "github.com/docopt/docopt-go"
"github.com/drycc/workflow-cli/cmd"
)
// Resources commands to their specific function.
func Resources(argv []string, cmdr cmd.Commander) error {
usage := `
Valid commands for resources:
resources:services list all available resource services
resources:plans list all available plans for an resource services
resources:create create a resource for the application
resources:list list resources in the application
resources:describe get a resource detail info in the application
resources:update update a resource from the application
resources:destroy delete a resource from the applicationa
resources:bind bind a resource to servicebroker
resources:unbind unbind a resource from servicebroker
Use 'drycc help [command]' to learn more.
`
switch argv[0] {
case "resources:services":
return resourcesServices(argv, cmdr)
case "resources:plans":
return resourcesPlans(argv, cmdr)
case "resources:create":
return resourcesCreate(argv, cmdr)
case "resources:list":
return resourcesList(argv, cmdr)
case "resources:describe":
return resourceGet(argv, cmdr)
case "resources:update":
return resourcePut(argv, cmdr)
case "resources:destroy":
return resourceDelete(argv, cmdr)
case "resources:bind":
return resourceBind(argv, cmdr)
case "resources:unbind":
return resourceUnbind(argv, cmdr)
default:
if printHelp(argv, usage) {
return nil
}
if argv[0] == "resources" {
argv[0] = "resources:list"
return resourcesList(argv, cmdr)
}
PrintUsage(cmdr)
return nil
}
}
func resourcesServices(argv []string, cmdr cmd.Commander) error {
usage := `
List all available resource services.
Usage: drycc resources:services [options]
Options:
-l --limit=<num>
the maximum number of results to display, defaults to config setting
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
results, err := responseLimit(safeGetString(args, "--limit"))
if err != nil {
return err
}
return cmdr.ResourcesServices(results)
}
func resourcesPlans(argv []string, cmdr cmd.Commander) error {
usage := `
List all available plans for an resource services.
Usage: drycc resources:plans <service> [options]
Arguments:
<service>
the service name for plans.
Options:
-l --limit=<num>
the maximum number of results to display, defaults to config setting
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
service := safeGetString(args, "<service>")
results, err := responseLimit(safeGetString(args, "--limit"))
if err != nil {
return err
}
return cmdr.ResourcesPlans(service, results)
}
func resourcesCreate(argv []string, cmdr cmd.Commander) error {
usage := `
Create a resource for the application.
Usage: drycc resources:create <plan> <name> [<param>=<value>...] [options]
Arguments:
<plan>
the resource's plan, pattern: <service_name>:<plan_name>.
<name>
this resource instance alias.
<param>
the resource instance parameters key.
<value>
the resource instance parameters value.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
-f --values=<values_file>
specify values in a YAML file. If set, params will be discard.
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
values := safeGetString(args, "--values")
plan := safeGetString(args, "<plan>")
name := safeGetString(args, "<name>")
return cmdr.ResourcesCreate(app, plan, name, args["<param>=<value>"].([]string), values)
}
func resourcesList(argv []string, cmdr cmd.Commander) error {
usage := `
List resources in the application.
Usage: drycc resources:list [options]
Options:
-a --app=<app>
the uniquely identifiable name for the application.
-l --limit=<num>
the maximum number of results to display, defaults to config setting
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
results, err := responseLimit(safeGetString(args, "--limit"))
if err != nil {
return err
}
app := safeGetString(args, "--app")
return cmdr.ResourcesList(app, results)
}
func resourceGet(argv []string, cmdr cmd.Commander) error {
usage := `
Get a resource's detail in the application.
Usage: drycc resources:describe <name> [options]
Arguments:
<name>
this resource instance alias.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
-l --limit=<num>
the maximum number of results to display, defaults to config setting
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
name := safeGetString(args, "<name>")
return cmdr.ResourceGet(app, name)
}
func resourcePut(argv []string, cmdr cmd.Commander) error {
usage := `
update a resource from the application
Usage: drycc resources:update <plan> <name> [<param>=<value>...] [options]
Arguments:
<plan>
the resource's plan, pattern: <service_name>:<plan_name>.
<name>
this resource instance alias.
<param>
the resource instance parameters key.
<value>
the resource instance parameters value.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
-f --values=<values_file>
specify values in a YAML file. If set, params will be discard.
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
values := safeGetString(args, "--values")
plan := safeGetString(args, "<plan>")
name := safeGetString(args, "<name>")
return cmdr.ResourcePut(app, plan, name, args["<param>=<value>"].([]string), values)
}
func resourceDelete(argv []string, cmdr cmd.Commander) error {
usage := `
Delete a resource from the application.
Usage: drycc resources:destroy <name> [options]
Arguments:
<name>
the resource instance alias name to be removed.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
--confirm=<resource>
skips the prompt for the resource name. <resource> is the uniquely identifiable
name for the resource.
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
name := safeGetString(args, "<name>")
confirm := safeGetString(args, "--confirm")
return cmdr.ResourceDelete(app, name, confirm)
}
func resourceBind(argv []string, cmdr cmd.Commander) error {
usage := `
bind a resource for an application.
Usage: drycc resources:bind <name> [options]
Arguments:
<name>
the resource instance alias name.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
name := safeGetString(args, "<name>")
return cmdr.ResourceBind(app, name)
}
func resourceUnbind(argv []string, cmdr cmd.Commander) error {
usage := `
unbind a resources for an application.
Usage: drycc resources:unbind <name> [options]
Arguments:
<name>
the resource instance alias name.
Options:
-a --app=<app>
the uniquely identifiable name for the application.
`
args, err := docopt.ParseArgs(usage, argv, "")
if err != nil {
return err
}
app := safeGetString(args, "--app")
name := safeGetString(args, "<name>")
return cmdr.ResourceUnbind(app, name)
}