razor-client 0.14.0 → 0.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (48) hide show
  1. data/NEWS.md +18 -0
  2. data/bin/razor +9 -4
  3. data/lib/razor/cli.rb +10 -0
  4. data/lib/razor/cli/document.rb +59 -0
  5. data/lib/razor/cli/format.rb +70 -20
  6. data/lib/razor/cli/navigate.rb +114 -25
  7. data/lib/razor/cli/parse.rb +79 -10
  8. data/lib/razor/cli/transforms.rb +39 -0
  9. data/lib/razor/cli/version.rb +46 -0
  10. data/lib/razor/cli/views.rb +25 -0
  11. data/lib/razor/cli/views.yaml +189 -0
  12. data/spec/cli/format_spec.rb +77 -0
  13. data/spec/cli/navigate_spec.rb +102 -2
  14. data/spec/cli/parse_spec.rb +20 -0
  15. data/spec/fixtures/vcr/Razor_CLI_Navigate/argument_formatting/should_allow_spaces.yml +966 -0
  16. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_--help_command_.yml +99 -0
  17. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_-h_command_.yml +99 -0
  18. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_command_--help_.yml +99 -0
  19. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_command_-h_.yml +99 -0
  20. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_command_help_.yml +99 -0
  21. data/spec/fixtures/vcr/Razor_CLI_Navigate/for_command_help/should_provide_command_help_for_razor_help_command_.yml +99 -0
  22. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_authentication/should_preserve_that_across_navigation.yml +9 -42
  23. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_authentication/should_supply_that_to_the_API_service.yml +5 -5
  24. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_invalid_parameter/should_fail_with_bad_JSON.yml +228 -0
  25. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_invalid_parameter/should_fail_with_malformed_argument.yml +120 -0
  26. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_array/should_merge_an_array_into_an_existing_array.yml +2006 -0
  27. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_array/should_merge_the_arguments_as_an_array.yml +2006 -0
  28. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_array/should_merge_the_arguments_into_an_existing_array.yml +2006 -0
  29. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_object/should_construct_a_json_object.yml +234 -0
  30. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_object/should_fail_with_mixed_types_array_then_hash_.yml +228 -0
  31. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_multiple_arguments_with_same_name/combining_as_an_object/should_fail_with_mixed_types_hash_then_array_.yml +164 -0
  32. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_no_parameters/should_fail_with_bad_JSON.yml +36 -0
  33. data/spec/fixtures/vcr/Razor_CLI_Parse/_new/_help/should_print_a_list_of_known_endpoints.yml +5 -5
  34. data/spec/spec_helper.rb +12 -1
  35. data/spec/testing.md +16 -0
  36. data/spec/version_spec.rb +8 -0
  37. metadata +74 -66
  38. data/.gitignore +0 -7
  39. data/.yardopts +0 -2
  40. data/Gemfile +0 -35
  41. data/Gemfile.lock +0 -53
  42. data/Rakefile +0 -37
  43. data/lib/razor/cli/navigate.yaml +0 -28
  44. data/razor-client.gemspec +0 -32
  45. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_a_single_item_path/.yml +0 -69
  46. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_an_invalid_path/.yml +0 -36
  47. data/spec/fixtures/vcr/Razor_CLI_Navigate/with_no_path/.yml +0 -36
  48. data/spec/fixtures/vcr/Razor_CLI_Parse/_new/_help/.yml +0 -36
@@ -0,0 +1,234 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: get
5
+ uri: http://localhost:8080/api
6
+ body:
7
+ encoding: US-ASCII
8
+ string: ''
9
+ headers:
10
+ Accept:
11
+ - application/json
12
+ Accept-Encoding:
13
+ - gzip, deflate
14
+ User-Agent:
15
+ - Ruby
16
+ response:
17
+ status:
18
+ code: 200
19
+ message: OK
20
+ headers:
21
+ Server:
22
+ - Apache-Coyote/1.1
23
+ X-Content-Type-Options:
24
+ - nosniff
25
+ Content-Type:
26
+ - application/json;charset=utf-8
27
+ Content-Length:
28
+ - '4982'
29
+ Date:
30
+ - Fri, 16 May 2014 22:18:28 GMT
31
+ body:
32
+ encoding: US-ASCII
33
+ string: '{"commands":[{"name":"add-policy-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/add-policy-tag","id":"http://localhost:8080/api/commands/add-policy-tag"},{"name":"create-broker","rel":"http://api.puppetlabs.com/razor/v1/commands/create-broker","id":"http://localhost:8080/api/commands/create-broker"},{"name":"create-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/create-policy","id":"http://localhost:8080/api/commands/create-policy"},{"name":"create-repo","rel":"http://api.puppetlabs.com/razor/v1/commands/create-repo","id":"http://localhost:8080/api/commands/create-repo"},{"name":"create-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/create-tag","id":"http://localhost:8080/api/commands/create-tag"},{"name":"create-task","rel":"http://api.puppetlabs.com/razor/v1/commands/create-task","id":"http://localhost:8080/api/commands/create-task"},{"name":"delete-broker","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-broker","id":"http://localhost:8080/api/commands/delete-broker"},{"name":"delete-node","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-node","id":"http://localhost:8080/api/commands/delete-node"},{"name":"delete-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-policy","id":"http://localhost:8080/api/commands/delete-policy"},{"name":"delete-repo","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-repo","id":"http://localhost:8080/api/commands/delete-repo"},{"name":"delete-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-tag","id":"http://localhost:8080/api/commands/delete-tag"},{"name":"disable-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/disable-policy","id":"http://localhost:8080/api/commands/disable-policy"},{"name":"enable-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/enable-policy","id":"http://localhost:8080/api/commands/enable-policy"},{"name":"modify-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/modify-node-metadata","id":"http://localhost:8080/api/commands/modify-node-metadata"},{"name":"modify-policy-max-count","rel":"http://api.puppetlabs.com/razor/v1/commands/modify-policy-max-count","id":"http://localhost:8080/api/commands/modify-policy-max-count"},{"name":"move-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/move-policy","id":"http://localhost:8080/api/commands/move-policy"},{"name":"reboot-node","rel":"http://api.puppetlabs.com/razor/v1/commands/reboot-node","id":"http://localhost:8080/api/commands/reboot-node"},{"name":"register-node","rel":"http://api.puppetlabs.com/razor/v1/commands/register-node","id":"http://localhost:8080/api/commands/register-node"},{"name":"reinstall-node","rel":"http://api.puppetlabs.com/razor/v1/commands/reinstall-node","id":"http://localhost:8080/api/commands/reinstall-node"},{"name":"remove-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/remove-node-metadata","id":"http://localhost:8080/api/commands/remove-node-metadata"},{"name":"remove-policy-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/remove-policy-tag","id":"http://localhost:8080/api/commands/remove-policy-tag"},{"name":"set-node-desired-power-state","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-desired-power-state","id":"http://localhost:8080/api/commands/set-node-desired-power-state"},{"name":"set-node-hw-info","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-hw-info","id":"http://localhost:8080/api/commands/set-node-hw-info"},{"name":"set-node-ipmi-credentials","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-ipmi-credentials","id":"http://localhost:8080/api/commands/set-node-ipmi-credentials"},{"name":"update-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/update-node-metadata","id":"http://localhost:8080/api/commands/update-node-metadata"},{"name":"update-tag-rule","rel":"http://api.puppetlabs.com/razor/v1/commands/update-tag-rule","id":"http://localhost:8080/api/commands/update-tag-rule"}],"collections":[{"name":"brokers","rel":"http://api.puppetlabs.com/razor/v1/collections/brokers","id":"http://localhost:8080/api/collections/brokers"},{"name":"repos","rel":"http://api.puppetlabs.com/razor/v1/collections/repos","id":"http://localhost:8080/api/collections/repos"},{"name":"tags","rel":"http://api.puppetlabs.com/razor/v1/collections/tags","id":"http://localhost:8080/api/collections/tags"},{"name":"policies","rel":"http://api.puppetlabs.com/razor/v1/collections/policies","id":"http://localhost:8080/api/collections/policies"},{"name":"nodes","rel":"http://api.puppetlabs.com/razor/v1/collections/nodes","id":"http://localhost:8080/api/collections/nodes"},{"name":"tasks","rel":"http://api.puppetlabs.com/razor/v1/collections/tasks","id":"http://localhost:8080/api/collections/tasks"},{"name":"commands","rel":"http://api.puppetlabs.com/razor/v1/collections/commands","id":"http://localhost:8080/api/collections/commands"}],"version":{"server":"v0.14.1-113-g8b33d83-dirty"}}'
34
+ http_version:
35
+ recorded_at: Fri, 16 May 2014 22:18:28 GMT
36
+ - request:
37
+ method: get
38
+ uri: http://localhost:8080/api/commands/create-broker
39
+ body:
40
+ encoding: US-ASCII
41
+ string: ''
42
+ headers:
43
+ Accept:
44
+ - application/json
45
+ Accept-Encoding:
46
+ - gzip, deflate
47
+ User-Agent:
48
+ - Ruby
49
+ response:
50
+ status:
51
+ code: 200
52
+ message: OK
53
+ headers:
54
+ Server:
55
+ - Apache-Coyote/1.1
56
+ Etag:
57
+ - '"server-version-v0.14.1-113-g8b33d83-dirty"'
58
+ X-Content-Type-Options:
59
+ - nosniff
60
+ Content-Type:
61
+ - application/json;charset=utf-8
62
+ Content-Length:
63
+ - '2496'
64
+ Date:
65
+ - Fri, 16 May 2014 22:18:28 GMT
66
+ body:
67
+ encoding: US-ASCII
68
+ string: '{"name":"create-broker","help":{"full":"# SYNOPSIS\nCreate a new broker
69
+ configuration for hand-off of installed nodes\n\n# DESCRIPTION\nCreate a new
70
+ broker configuration. Brokers are responsible for handing a node\noff to
71
+ a config management system, such as Puppet or Chef. In cases where you\nhave
72
+ no configuration management system, you can use the `noop` broker.\n\n\n#
73
+ Access Control\n\nThis command''s access control pattern: `commands:create-broker:%{name}`\n\nWords
74
+ surrounded by `%{...}` are substitutions from the input data: typically\nthe
75
+ name of the object being modified, or some other critical detail, these\nallow
76
+ roles to be granted partial access to modify the system.\n\nFor more detail
77
+ on how the permission strings are structured and work, you can\nsee the [Shiro
78
+ Permissions documentation][shiro]. That pattern is expanded\nand then a permission
79
+ check applied to it, before the command is authorized.\n\nThese checks only
80
+ apply if security is enabled in the Razor configuration\nfile; on this server
81
+ security is currently disabled.\n\n[shiro]: http://shiro.apache.org/permissions.html\n\n#
82
+ Attributes\n\n * name\n - The name of the broker, as it will be referenced
83
+ within Razor.\n This is the name that you supply to, eg, `create-policy`
84
+ to specify\n which broker the node will be handed off via after installation.\n -
85
+ This attribute is required\n - It must be of type string.\n - It must
86
+ be between 1 and 250 in length.\n\n * broker-type\n - The broker type that
87
+ this broker is created from. The available\n broker types on your server
88
+ are:\n - chef\n - noop\n - puppet-pe\n - puppet\n - This
89
+ attribute is required\n - It must be of type string.\n - It must match
90
+ the name of an existing broker type.\n\n * configuration\n - The configuration
91
+ for the broker. The acceptable values here are\n determined by the `broker-type`
92
+ selected. In general this has\n settings like which server to contact,
93
+ and other configuration\n related to handing on the newly installed system
94
+ to the final\n configuration management system.\n - It must be of type
95
+ object.\n \n \n\n\n\n# EXAMPLES\n Creating a simple Puppet broker:\n \n {\n \"name\":
96
+ \"puppet\",\n \"configuration\": {\n \"server\": \"puppet.example.org\",\n \"environment\":
97
+ \"production\"\n },\n \"broker-type\": \"puppet\"\n }\n\n"},"schema":{"name":{"type":"string"},"broker-type":{"type":"string"},"configuration":{"type":"object"}}}'
98
+ http_version:
99
+ recorded_at: Fri, 16 May 2014 22:18:28 GMT
100
+ - request:
101
+ method: get
102
+ uri: http://localhost:8080/api/commands/create-broker
103
+ body:
104
+ encoding: US-ASCII
105
+ string: ''
106
+ headers:
107
+ Accept:
108
+ - application/json
109
+ Accept-Encoding:
110
+ - gzip, deflate
111
+ User-Agent:
112
+ - Ruby
113
+ response:
114
+ status:
115
+ code: 200
116
+ message: OK
117
+ headers:
118
+ Server:
119
+ - Apache-Coyote/1.1
120
+ Etag:
121
+ - '"server-version-v0.14.1-113-g8b33d83-dirty"'
122
+ X-Content-Type-Options:
123
+ - nosniff
124
+ Content-Type:
125
+ - application/json;charset=utf-8
126
+ Content-Length:
127
+ - '2496'
128
+ Date:
129
+ - Fri, 16 May 2014 22:18:28 GMT
130
+ body:
131
+ encoding: US-ASCII
132
+ string: '{"name":"create-broker","help":{"full":"# SYNOPSIS\nCreate a new broker
133
+ configuration for hand-off of installed nodes\n\n# DESCRIPTION\nCreate a new
134
+ broker configuration. Brokers are responsible for handing a node\noff to
135
+ a config management system, such as Puppet or Chef. In cases where you\nhave
136
+ no configuration management system, you can use the `noop` broker.\n\n\n#
137
+ Access Control\n\nThis command''s access control pattern: `commands:create-broker:%{name}`\n\nWords
138
+ surrounded by `%{...}` are substitutions from the input data: typically\nthe
139
+ name of the object being modified, or some other critical detail, these\nallow
140
+ roles to be granted partial access to modify the system.\n\nFor more detail
141
+ on how the permission strings are structured and work, you can\nsee the [Shiro
142
+ Permissions documentation][shiro]. That pattern is expanded\nand then a permission
143
+ check applied to it, before the command is authorized.\n\nThese checks only
144
+ apply if security is enabled in the Razor configuration\nfile; on this server
145
+ security is currently disabled.\n\n[shiro]: http://shiro.apache.org/permissions.html\n\n#
146
+ Attributes\n\n * name\n - The name of the broker, as it will be referenced
147
+ within Razor.\n This is the name that you supply to, eg, `create-policy`
148
+ to specify\n which broker the node will be handed off via after installation.\n -
149
+ This attribute is required\n - It must be of type string.\n - It must
150
+ be between 1 and 250 in length.\n\n * broker-type\n - The broker type that
151
+ this broker is created from. The available\n broker types on your server
152
+ are:\n - chef\n - noop\n - puppet-pe\n - puppet\n - This
153
+ attribute is required\n - It must be of type string.\n - It must match
154
+ the name of an existing broker type.\n\n * configuration\n - The configuration
155
+ for the broker. The acceptable values here are\n determined by the `broker-type`
156
+ selected. In general this has\n settings like which server to contact,
157
+ and other configuration\n related to handing on the newly installed system
158
+ to the final\n configuration management system.\n - It must be of type
159
+ object.\n \n \n\n\n\n# EXAMPLES\n Creating a simple Puppet broker:\n \n {\n \"name\":
160
+ \"puppet\",\n \"configuration\": {\n \"server\": \"puppet.example.org\",\n \"environment\":
161
+ \"production\"\n },\n \"broker-type\": \"puppet\"\n }\n\n"},"schema":{"name":{"type":"string"},"broker-type":{"type":"string"},"configuration":{"type":"object"}}}'
162
+ http_version:
163
+ recorded_at: Fri, 16 May 2014 22:18:28 GMT
164
+ - request:
165
+ method: post
166
+ uri: http://localhost:8080/api/commands/create-broker
167
+ body:
168
+ encoding: UTF-8
169
+ string: '{"name":"broker1","broker-type":"puppet","configuration":{"server":"puppet.example.org","environment":"production"}}'
170
+ headers:
171
+ Accept:
172
+ - application/json
173
+ Accept-Encoding:
174
+ - gzip, deflate
175
+ Content-Type:
176
+ - application/json
177
+ Content-Length:
178
+ - '116'
179
+ User-Agent:
180
+ - Ruby
181
+ response:
182
+ status:
183
+ code: 202
184
+ message: Accepted
185
+ headers:
186
+ Server:
187
+ - Apache-Coyote/1.1
188
+ X-Content-Type-Options:
189
+ - nosniff
190
+ Content-Type:
191
+ - application/json;charset=utf-8
192
+ Content-Length:
193
+ - '211'
194
+ Date:
195
+ - Fri, 16 May 2014 22:18:28 GMT
196
+ body:
197
+ encoding: US-ASCII
198
+ string: '{"spec":"http://api.puppetlabs.com/razor/v1/collections/brokers/member","id":"http://localhost:8080/api/collections/brokers/broker1","name":"broker1","command":"http://localhost:8080/api/collections/commands/1"}'
199
+ http_version:
200
+ recorded_at: Fri, 16 May 2014 22:18:28 GMT
201
+ - request:
202
+ method: get
203
+ uri: http://localhost:8080/api/collections/brokers/broker1
204
+ body:
205
+ encoding: US-ASCII
206
+ string: ''
207
+ headers:
208
+ Accept:
209
+ - application/json
210
+ Accept-Encoding:
211
+ - gzip, deflate
212
+ User-Agent:
213
+ - Ruby
214
+ response:
215
+ status:
216
+ code: 200
217
+ message: OK
218
+ headers:
219
+ Server:
220
+ - Apache-Coyote/1.1
221
+ X-Content-Type-Options:
222
+ - nosniff
223
+ Content-Type:
224
+ - application/json;charset=utf-8
225
+ Content-Length:
226
+ - '359'
227
+ Date:
228
+ - Fri, 16 May 2014 22:18:28 GMT
229
+ body:
230
+ encoding: US-ASCII
231
+ string: '{"spec":"http://api.puppetlabs.com/razor/v1/collections/brokers/member","id":"http://localhost:8080/api/collections/brokers/broker1","name":"broker1","configuration":{"server":"puppet.example.org","environment":"production"},"broker-type":"puppet","policies":{"id":"http://localhost:8080/api/collections/brokers/broker1/policies","count":0,"name":"policies"}}'
232
+ http_version:
233
+ recorded_at: Fri, 16 May 2014 22:18:28 GMT
234
+ recorded_with: VCR 2.5.0
@@ -0,0 +1,228 @@
1
+ ---
2
+ http_interactions:
3
+ - request:
4
+ method: get
5
+ uri: http://localhost:8080/api
6
+ body:
7
+ encoding: US-ASCII
8
+ string: ''
9
+ headers:
10
+ Accept:
11
+ - application/json
12
+ Accept-Encoding:
13
+ - gzip, deflate
14
+ User-Agent:
15
+ - Ruby
16
+ response:
17
+ status:
18
+ code: 200
19
+ message: OK
20
+ headers:
21
+ Server:
22
+ - Apache-Coyote/1.1
23
+ X-Content-Type-Options:
24
+ - nosniff
25
+ Content-Type:
26
+ - application/json;charset=utf-8
27
+ Content-Length:
28
+ - '4982'
29
+ Date:
30
+ - Fri, 16 May 2014 22:18:33 GMT
31
+ body:
32
+ encoding: US-ASCII
33
+ string: '{"commands":[{"name":"add-policy-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/add-policy-tag","id":"http://localhost:8080/api/commands/add-policy-tag"},{"name":"create-broker","rel":"http://api.puppetlabs.com/razor/v1/commands/create-broker","id":"http://localhost:8080/api/commands/create-broker"},{"name":"create-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/create-policy","id":"http://localhost:8080/api/commands/create-policy"},{"name":"create-repo","rel":"http://api.puppetlabs.com/razor/v1/commands/create-repo","id":"http://localhost:8080/api/commands/create-repo"},{"name":"create-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/create-tag","id":"http://localhost:8080/api/commands/create-tag"},{"name":"create-task","rel":"http://api.puppetlabs.com/razor/v1/commands/create-task","id":"http://localhost:8080/api/commands/create-task"},{"name":"delete-broker","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-broker","id":"http://localhost:8080/api/commands/delete-broker"},{"name":"delete-node","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-node","id":"http://localhost:8080/api/commands/delete-node"},{"name":"delete-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-policy","id":"http://localhost:8080/api/commands/delete-policy"},{"name":"delete-repo","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-repo","id":"http://localhost:8080/api/commands/delete-repo"},{"name":"delete-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/delete-tag","id":"http://localhost:8080/api/commands/delete-tag"},{"name":"disable-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/disable-policy","id":"http://localhost:8080/api/commands/disable-policy"},{"name":"enable-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/enable-policy","id":"http://localhost:8080/api/commands/enable-policy"},{"name":"modify-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/modify-node-metadata","id":"http://localhost:8080/api/commands/modify-node-metadata"},{"name":"modify-policy-max-count","rel":"http://api.puppetlabs.com/razor/v1/commands/modify-policy-max-count","id":"http://localhost:8080/api/commands/modify-policy-max-count"},{"name":"move-policy","rel":"http://api.puppetlabs.com/razor/v1/commands/move-policy","id":"http://localhost:8080/api/commands/move-policy"},{"name":"reboot-node","rel":"http://api.puppetlabs.com/razor/v1/commands/reboot-node","id":"http://localhost:8080/api/commands/reboot-node"},{"name":"register-node","rel":"http://api.puppetlabs.com/razor/v1/commands/register-node","id":"http://localhost:8080/api/commands/register-node"},{"name":"reinstall-node","rel":"http://api.puppetlabs.com/razor/v1/commands/reinstall-node","id":"http://localhost:8080/api/commands/reinstall-node"},{"name":"remove-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/remove-node-metadata","id":"http://localhost:8080/api/commands/remove-node-metadata"},{"name":"remove-policy-tag","rel":"http://api.puppetlabs.com/razor/v1/commands/remove-policy-tag","id":"http://localhost:8080/api/commands/remove-policy-tag"},{"name":"set-node-desired-power-state","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-desired-power-state","id":"http://localhost:8080/api/commands/set-node-desired-power-state"},{"name":"set-node-hw-info","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-hw-info","id":"http://localhost:8080/api/commands/set-node-hw-info"},{"name":"set-node-ipmi-credentials","rel":"http://api.puppetlabs.com/razor/v1/commands/set-node-ipmi-credentials","id":"http://localhost:8080/api/commands/set-node-ipmi-credentials"},{"name":"update-node-metadata","rel":"http://api.puppetlabs.com/razor/v1/commands/update-node-metadata","id":"http://localhost:8080/api/commands/update-node-metadata"},{"name":"update-tag-rule","rel":"http://api.puppetlabs.com/razor/v1/commands/update-tag-rule","id":"http://localhost:8080/api/commands/update-tag-rule"}],"collections":[{"name":"brokers","rel":"http://api.puppetlabs.com/razor/v1/collections/brokers","id":"http://localhost:8080/api/collections/brokers"},{"name":"repos","rel":"http://api.puppetlabs.com/razor/v1/collections/repos","id":"http://localhost:8080/api/collections/repos"},{"name":"tags","rel":"http://api.puppetlabs.com/razor/v1/collections/tags","id":"http://localhost:8080/api/collections/tags"},{"name":"policies","rel":"http://api.puppetlabs.com/razor/v1/collections/policies","id":"http://localhost:8080/api/collections/policies"},{"name":"nodes","rel":"http://api.puppetlabs.com/razor/v1/collections/nodes","id":"http://localhost:8080/api/collections/nodes"},{"name":"tasks","rel":"http://api.puppetlabs.com/razor/v1/collections/tasks","id":"http://localhost:8080/api/collections/tasks"},{"name":"commands","rel":"http://api.puppetlabs.com/razor/v1/collections/commands","id":"http://localhost:8080/api/collections/commands"}],"version":{"server":"v0.14.1-113-g8b33d83-dirty"}}'
34
+ http_version:
35
+ recorded_at: Fri, 16 May 2014 22:18:34 GMT
36
+ - request:
37
+ method: get
38
+ uri: http://localhost:8080/api/commands/create-broker
39
+ body:
40
+ encoding: US-ASCII
41
+ string: ''
42
+ headers:
43
+ Accept:
44
+ - application/json
45
+ Accept-Encoding:
46
+ - gzip, deflate
47
+ User-Agent:
48
+ - Ruby
49
+ response:
50
+ status:
51
+ code: 200
52
+ message: OK
53
+ headers:
54
+ Server:
55
+ - Apache-Coyote/1.1
56
+ Etag:
57
+ - '"server-version-v0.14.1-113-g8b33d83-dirty"'
58
+ X-Content-Type-Options:
59
+ - nosniff
60
+ Content-Type:
61
+ - application/json;charset=utf-8
62
+ Content-Length:
63
+ - '2496'
64
+ Date:
65
+ - Fri, 16 May 2014 22:18:33 GMT
66
+ body:
67
+ encoding: US-ASCII
68
+ string: '{"name":"create-broker","help":{"full":"# SYNOPSIS\nCreate a new broker
69
+ configuration for hand-off of installed nodes\n\n# DESCRIPTION\nCreate a new
70
+ broker configuration. Brokers are responsible for handing a node\noff to
71
+ a config management system, such as Puppet or Chef. In cases where you\nhave
72
+ no configuration management system, you can use the `noop` broker.\n\n\n#
73
+ Access Control\n\nThis command''s access control pattern: `commands:create-broker:%{name}`\n\nWords
74
+ surrounded by `%{...}` are substitutions from the input data: typically\nthe
75
+ name of the object being modified, or some other critical detail, these\nallow
76
+ roles to be granted partial access to modify the system.\n\nFor more detail
77
+ on how the permission strings are structured and work, you can\nsee the [Shiro
78
+ Permissions documentation][shiro]. That pattern is expanded\nand then a permission
79
+ check applied to it, before the command is authorized.\n\nThese checks only
80
+ apply if security is enabled in the Razor configuration\nfile; on this server
81
+ security is currently disabled.\n\n[shiro]: http://shiro.apache.org/permissions.html\n\n#
82
+ Attributes\n\n * name\n - The name of the broker, as it will be referenced
83
+ within Razor.\n This is the name that you supply to, eg, `create-policy`
84
+ to specify\n which broker the node will be handed off via after installation.\n -
85
+ This attribute is required\n - It must be of type string.\n - It must
86
+ be between 1 and 250 in length.\n\n * broker-type\n - The broker type that
87
+ this broker is created from. The available\n broker types on your server
88
+ are:\n - chef\n - noop\n - puppet-pe\n - puppet\n - This
89
+ attribute is required\n - It must be of type string.\n - It must match
90
+ the name of an existing broker type.\n\n * configuration\n - The configuration
91
+ for the broker. The acceptable values here are\n determined by the `broker-type`
92
+ selected. In general this has\n settings like which server to contact,
93
+ and other configuration\n related to handing on the newly installed system
94
+ to the final\n configuration management system.\n - It must be of type
95
+ object.\n \n \n\n\n\n# EXAMPLES\n Creating a simple Puppet broker:\n \n {\n \"name\":
96
+ \"puppet\",\n \"configuration\": {\n \"server\": \"puppet.example.org\",\n \"environment\":
97
+ \"production\"\n },\n \"broker-type\": \"puppet\"\n }\n\n"},"schema":{"name":{"type":"string"},"broker-type":{"type":"string"},"configuration":{"type":"object"}}}'
98
+ http_version:
99
+ recorded_at: Fri, 16 May 2014 22:18:34 GMT
100
+ - request:
101
+ method: get
102
+ uri: http://localhost:8080/api/commands/create-broker
103
+ body:
104
+ encoding: US-ASCII
105
+ string: ''
106
+ headers:
107
+ Accept:
108
+ - application/json
109
+ Accept-Encoding:
110
+ - gzip, deflate
111
+ User-Agent:
112
+ - Ruby
113
+ response:
114
+ status:
115
+ code: 200
116
+ message: OK
117
+ headers:
118
+ Server:
119
+ - Apache-Coyote/1.1
120
+ Etag:
121
+ - '"server-version-v0.14.1-113-g8b33d83-dirty"'
122
+ X-Content-Type-Options:
123
+ - nosniff
124
+ Content-Type:
125
+ - application/json;charset=utf-8
126
+ Content-Length:
127
+ - '2496'
128
+ Date:
129
+ - Fri, 16 May 2014 22:18:33 GMT
130
+ body:
131
+ encoding: US-ASCII
132
+ string: '{"name":"create-broker","help":{"full":"# SYNOPSIS\nCreate a new broker
133
+ configuration for hand-off of installed nodes\n\n# DESCRIPTION\nCreate a new
134
+ broker configuration. Brokers are responsible for handing a node\noff to
135
+ a config management system, such as Puppet or Chef. In cases where you\nhave
136
+ no configuration management system, you can use the `noop` broker.\n\n\n#
137
+ Access Control\n\nThis command''s access control pattern: `commands:create-broker:%{name}`\n\nWords
138
+ surrounded by `%{...}` are substitutions from the input data: typically\nthe
139
+ name of the object being modified, or some other critical detail, these\nallow
140
+ roles to be granted partial access to modify the system.\n\nFor more detail
141
+ on how the permission strings are structured and work, you can\nsee the [Shiro
142
+ Permissions documentation][shiro]. That pattern is expanded\nand then a permission
143
+ check applied to it, before the command is authorized.\n\nThese checks only
144
+ apply if security is enabled in the Razor configuration\nfile; on this server
145
+ security is currently disabled.\n\n[shiro]: http://shiro.apache.org/permissions.html\n\n#
146
+ Attributes\n\n * name\n - The name of the broker, as it will be referenced
147
+ within Razor.\n This is the name that you supply to, eg, `create-policy`
148
+ to specify\n which broker the node will be handed off via after installation.\n -
149
+ This attribute is required\n - It must be of type string.\n - It must
150
+ be between 1 and 250 in length.\n\n * broker-type\n - The broker type that
151
+ this broker is created from. The available\n broker types on your server
152
+ are:\n - chef\n - noop\n - puppet-pe\n - puppet\n - This
153
+ attribute is required\n - It must be of type string.\n - It must match
154
+ the name of an existing broker type.\n\n * configuration\n - The configuration
155
+ for the broker. The acceptable values here are\n determined by the `broker-type`
156
+ selected. In general this has\n settings like which server to contact,
157
+ and other configuration\n related to handing on the newly installed system
158
+ to the final\n configuration management system.\n - It must be of type
159
+ object.\n \n \n\n\n\n# EXAMPLES\n Creating a simple Puppet broker:\n \n {\n \"name\":
160
+ \"puppet\",\n \"configuration\": {\n \"server\": \"puppet.example.org\",\n \"environment\":
161
+ \"production\"\n },\n \"broker-type\": \"puppet\"\n }\n\n"},"schema":{"name":{"type":"string"},"broker-type":{"type":"string"},"configuration":{"type":"object"}}}'
162
+ http_version:
163
+ recorded_at: Fri, 16 May 2014 22:18:34 GMT
164
+ - request:
165
+ method: get
166
+ uri: http://localhost:8080/api/commands/create-broker
167
+ body:
168
+ encoding: US-ASCII
169
+ string: ''
170
+ headers:
171
+ Accept:
172
+ - application/json
173
+ Accept-Encoding:
174
+ - gzip, deflate
175
+ User-Agent:
176
+ - Ruby
177
+ response:
178
+ status:
179
+ code: 200
180
+ message: OK
181
+ headers:
182
+ Server:
183
+ - Apache-Coyote/1.1
184
+ Etag:
185
+ - '"server-version-v0.14.1-113-g8b33d83-dirty"'
186
+ X-Content-Type-Options:
187
+ - nosniff
188
+ Content-Type:
189
+ - application/json;charset=utf-8
190
+ Content-Length:
191
+ - '2496'
192
+ Date:
193
+ - Fri, 16 May 2014 22:18:33 GMT
194
+ body:
195
+ encoding: US-ASCII
196
+ string: '{"name":"create-broker","help":{"full":"# SYNOPSIS\nCreate a new broker
197
+ configuration for hand-off of installed nodes\n\n# DESCRIPTION\nCreate a new
198
+ broker configuration. Brokers are responsible for handing a node\noff to
199
+ a config management system, such as Puppet or Chef. In cases where you\nhave
200
+ no configuration management system, you can use the `noop` broker.\n\n\n#
201
+ Access Control\n\nThis command''s access control pattern: `commands:create-broker:%{name}`\n\nWords
202
+ surrounded by `%{...}` are substitutions from the input data: typically\nthe
203
+ name of the object being modified, or some other critical detail, these\nallow
204
+ roles to be granted partial access to modify the system.\n\nFor more detail
205
+ on how the permission strings are structured and work, you can\nsee the [Shiro
206
+ Permissions documentation][shiro]. That pattern is expanded\nand then a permission
207
+ check applied to it, before the command is authorized.\n\nThese checks only
208
+ apply if security is enabled in the Razor configuration\nfile; on this server
209
+ security is currently disabled.\n\n[shiro]: http://shiro.apache.org/permissions.html\n\n#
210
+ Attributes\n\n * name\n - The name of the broker, as it will be referenced
211
+ within Razor.\n This is the name that you supply to, eg, `create-policy`
212
+ to specify\n which broker the node will be handed off via after installation.\n -
213
+ This attribute is required\n - It must be of type string.\n - It must
214
+ be between 1 and 250 in length.\n\n * broker-type\n - The broker type that
215
+ this broker is created from. The available\n broker types on your server
216
+ are:\n - chef\n - noop\n - puppet-pe\n - puppet\n - This
217
+ attribute is required\n - It must be of type string.\n - It must match
218
+ the name of an existing broker type.\n\n * configuration\n - The configuration
219
+ for the broker. The acceptable values here are\n determined by the `broker-type`
220
+ selected. In general this has\n settings like which server to contact,
221
+ and other configuration\n related to handing on the newly installed system
222
+ to the final\n configuration management system.\n - It must be of type
223
+ object.\n \n \n\n\n\n# EXAMPLES\n Creating a simple Puppet broker:\n \n {\n \"name\":
224
+ \"puppet\",\n \"configuration\": {\n \"server\": \"puppet.example.org\",\n \"environment\":
225
+ \"production\"\n },\n \"broker-type\": \"puppet\"\n }\n\n"},"schema":{"name":{"type":"string"},"broker-type":{"type":"string"},"configuration":{"type":"object"}}}'
226
+ http_version:
227
+ recorded_at: Fri, 16 May 2014 22:18:34 GMT
228
+ recorded_with: VCR 2.5.0