fog 1.10.0 → 1.10.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (379) hide show
  1. data/benchs/load_times.rb +31 -0
  2. data/changelog.txt +320 -0
  3. data/fog.gemspec +3 -3
  4. data/lib/fog.rb +42 -15
  5. data/lib/fog/aws/auto_scaling.rb +1 -1
  6. data/lib/fog/aws/beanstalk.rb +1 -1
  7. data/lib/fog/aws/cloud_formation.rb +1 -1
  8. data/lib/fog/aws/compute.rb +1 -1
  9. data/lib/fog/aws/elasticache.rb +1 -1
  10. data/lib/fog/aws/elb.rb +1 -1
  11. data/lib/fog/aws/iam.rb +1 -1
  12. data/lib/fog/aws/models/beanstalk/environment.rb +6 -2
  13. data/lib/fog/aws/models/cdn/distributions.rb +2 -1
  14. data/lib/fog/aws/models/cdn/distributions_helper.rb +2 -1
  15. data/lib/fog/aws/models/cdn/streaming_distributions.rb +2 -1
  16. data/lib/fog/aws/models/compute/server.rb +1 -1
  17. data/lib/fog/aws/models/storage/directory.rb +1 -1
  18. data/lib/fog/aws/models/storage/file.rb +1 -1
  19. data/lib/fog/aws/parsers/beanstalk/describe_environment_resources.rb +11 -0
  20. data/lib/fog/aws/rds.rb +1 -1
  21. data/lib/fog/aws/requests/cdn/delete_distribution.rb +5 -7
  22. data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +5 -7
  23. data/lib/fog/aws/requests/cdn/get_distribution.rb +28 -31
  24. data/lib/fog/aws/requests/cdn/get_distribution_list.rb +29 -33
  25. data/lib/fog/aws/requests/cdn/get_invalidation.rb +15 -13
  26. data/lib/fog/aws/requests/cdn/get_invalidation_list.rb +15 -17
  27. data/lib/fog/aws/requests/cdn/get_streaming_distribution.rb +23 -26
  28. data/lib/fog/aws/requests/cdn/get_streaming_distribution_list.rb +29 -33
  29. data/lib/fog/aws/requests/cdn/post_distribution.rb +40 -42
  30. data/lib/fog/aws/requests/cdn/post_invalidation.rb +14 -18
  31. data/lib/fog/aws/requests/cdn/post_streaming_distribution.rb +28 -30
  32. data/lib/fog/aws/requests/cdn/put_distribution_config.rb +41 -43
  33. data/lib/fog/aws/requests/cdn/put_streaming_distribution_config.rb +31 -33
  34. data/lib/fog/aws/requests/cloud_formation/create_stack.rb +16 -20
  35. data/lib/fog/aws/requests/cloud_formation/delete_stack.rb +5 -8
  36. data/lib/fog/aws/requests/cloud_formation/describe_stack_events.rb +19 -22
  37. data/lib/fog/aws/requests/cloud_formation/describe_stack_resources.rb +18 -21
  38. data/lib/fog/aws/requests/cloud_formation/describe_stacks.rb +18 -21
  39. data/lib/fog/aws/requests/cloud_formation/get_template.rb +7 -10
  40. data/lib/fog/aws/requests/cloud_formation/update_stack.rb +12 -16
  41. data/lib/fog/aws/requests/cloud_formation/validate_template.rb +9 -12
  42. data/lib/fog/aws/requests/compute/associate_address.rb +13 -7
  43. data/lib/fog/aws/requests/compute/describe_reserved_instances_offerings.rb +16 -2
  44. data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -2
  45. data/lib/fog/aws/requests/elb/create_load_balancer.rb +10 -0
  46. data/lib/fog/aws/requests/iam/update_server_certificate.rb +27 -0
  47. data/lib/fog/aws/requests/storage/get_object.rb +6 -2
  48. data/lib/fog/aws/storage.rb +6 -4
  49. data/lib/fog/aws/sts.rb +1 -1
  50. data/lib/fog/bin.rb +2 -0
  51. data/lib/fog/bin/digitalocean.rb +31 -0
  52. data/lib/fog/bin/riakcs.rb +27 -0
  53. data/lib/fog/cloudstack/compute.rb +3 -0
  54. data/lib/fog/cloudstack/models/compute/snapshot.rb +46 -0
  55. data/lib/fog/cloudstack/models/compute/snapshots.rb +25 -0
  56. data/lib/fog/cloudstack/requests/compute/create_snapshot.rb +24 -0
  57. data/lib/fog/compute.rb +3 -0
  58. data/lib/fog/compute/models/server.rb +6 -7
  59. data/lib/fog/core.rb +10 -5
  60. data/lib/fog/core/errors.rb +2 -0
  61. data/lib/fog/core/scp.rb +3 -3
  62. data/lib/fog/core/ssh.rb +1 -1
  63. data/lib/fog/digitalocean.rb +9 -0
  64. data/lib/fog/digitalocean/CHANGELOG.md +6 -0
  65. data/lib/fog/digitalocean/compute.rb +107 -0
  66. data/lib/fog/digitalocean/examples/getting_started.md +106 -0
  67. data/lib/fog/digitalocean/models/compute/flavor.rb +14 -0
  68. data/lib/fog/digitalocean/models/compute/flavors.rb +25 -0
  69. data/lib/fog/digitalocean/models/compute/image.rb +15 -0
  70. data/lib/fog/digitalocean/models/compute/images.rb +25 -0
  71. data/lib/fog/digitalocean/models/compute/region.rb +14 -0
  72. data/lib/fog/digitalocean/models/compute/regions.rb +25 -0
  73. data/lib/fog/digitalocean/models/compute/server.rb +150 -0
  74. data/lib/fog/digitalocean/models/compute/servers.rb +27 -0
  75. data/lib/fog/digitalocean/models/compute/ssh_key.rb +28 -0
  76. data/lib/fog/digitalocean/models/compute/ssh_keys.rb +27 -0
  77. data/lib/fog/digitalocean/requests/compute/create_server.rb +68 -0
  78. data/lib/fog/digitalocean/requests/compute/create_ssh_key.rb +38 -0
  79. data/lib/fog/digitalocean/requests/compute/destroy_server.rb +34 -0
  80. data/lib/fog/digitalocean/requests/compute/destroy_ssh_key.rb +37 -0
  81. data/lib/fog/digitalocean/requests/compute/get_server_details.rb +35 -0
  82. data/lib/fog/digitalocean/requests/compute/get_ssh_key.rb +39 -0
  83. data/lib/fog/digitalocean/requests/compute/list_flavors.rb +38 -0
  84. data/lib/fog/digitalocean/requests/compute/list_images.rb +49 -0
  85. data/lib/fog/digitalocean/requests/compute/list_regions.rb +34 -0
  86. data/lib/fog/digitalocean/requests/compute/list_servers.rb +31 -0
  87. data/lib/fog/digitalocean/requests/compute/list_ssh_keys.rb +31 -0
  88. data/lib/fog/digitalocean/requests/compute/power_cycle_server.rb +33 -0
  89. data/lib/fog/digitalocean/requests/compute/power_off_server.rb +33 -0
  90. data/lib/fog/digitalocean/requests/compute/power_on_server.rb +33 -0
  91. data/lib/fog/digitalocean/requests/compute/reboot_server.rb +33 -0
  92. data/lib/fog/digitalocean/requests/compute/shutdown_server.rb +36 -0
  93. data/lib/fog/dreamhost/CHANGELOG.md +8 -0
  94. data/lib/fog/glesys/models/compute/server.rb +3 -3
  95. data/lib/fog/google/storage.rb +1 -1
  96. data/lib/fog/hp.rb +1 -1
  97. data/lib/fog/hp/CHANGELOG.hp +12 -2
  98. data/lib/fog/hp/block_storage.rb +1 -0
  99. data/lib/fog/hp/cdn.rb +1 -0
  100. data/lib/fog/hp/compute.rb +1 -0
  101. data/lib/fog/hp/models/compute/server.rb +14 -8
  102. data/lib/fog/hp/models/storage/directories.rb +1 -1
  103. data/lib/fog/hp/models/storage/directory.rb +28 -3
  104. data/lib/fog/hp/models/storage/files.rb +1 -1
  105. data/lib/fog/hp/requests/compute/create_server.rb +4 -14
  106. data/lib/fog/hp/storage.rb +2 -0
  107. data/lib/fog/internet_archive.rb +3 -1
  108. data/lib/fog/internet_archive/models/storage/directory.rb +25 -42
  109. data/lib/fog/internet_archive/models/storage/file.rb +45 -64
  110. data/lib/fog/internet_archive/models/storage/ia_attributes.rb +39 -0
  111. data/lib/fog/internet_archive/requests/storage/delete_multiple_objects.rb +4 -78
  112. data/lib/fog/internet_archive/requests/storage/delete_object.rb +2 -70
  113. data/lib/fog/internet_archive/requests/storage/get_object.rb +1 -22
  114. data/lib/fog/internet_archive/requests/storage/get_object_acl.rb +0 -4
  115. data/lib/fog/internet_archive/requests/storage/get_service.rb +1 -2
  116. data/lib/fog/internet_archive/requests/storage/head_object.rb +0 -4
  117. data/lib/fog/internet_archive/requests/storage/post_object_hidden_fields.rb +1 -1
  118. data/lib/fog/internet_archive/requests/storage/put_object.rb +2 -17
  119. data/lib/fog/internet_archive/requests/storage/put_object_acl.rb +0 -5
  120. data/lib/fog/internet_archive/storage.rb +6 -18
  121. data/lib/fog/joyent.rb +2 -0
  122. data/lib/fog/libvirt/requests/compute/get_node_info.rb +1 -1
  123. data/lib/fog/openstack/CHANGELOG.md +47 -0
  124. data/lib/fog/openstack/examples/identity/basics.rb +69 -0
  125. data/lib/fog/openstack/examples/image/upload-test-image.rb +77 -0
  126. data/lib/fog/openstack/examples/network/network_subnets_routers.rb +63 -0
  127. data/lib/fog/openstack/examples/storage/set-account-quota.rb +66 -0
  128. data/lib/fog/openstack/image.rb +4 -0
  129. data/lib/fog/openstack/models/compute/server.rb +4 -2
  130. data/lib/fog/openstack/models/network/floating_ip.rb +2 -2
  131. data/lib/fog/openstack/models/network/floating_ips.rb +1 -1
  132. data/lib/fog/openstack/models/network/router.rb +56 -0
  133. data/lib/fog/openstack/models/network/routers.rb +34 -0
  134. data/lib/fog/openstack/network.rb +15 -2
  135. data/lib/fog/openstack/requests/compute/create_server.rb +11 -0
  136. data/lib/fog/openstack/requests/compute/rebuild_server.rb +9 -1
  137. data/lib/fog/openstack/requests/network/add_router_interface.rb +48 -0
  138. data/lib/fog/openstack/requests/network/create_network.rb +57 -2
  139. data/lib/fog/openstack/requests/network/create_router.rb +57 -0
  140. data/lib/fog/openstack/requests/network/delete_router.rb +30 -0
  141. data/lib/fog/openstack/requests/network/get_router.rb +32 -0
  142. data/lib/fog/openstack/requests/network/list_routers.rb +27 -0
  143. data/lib/fog/openstack/requests/network/remove_router_interface.rb +36 -0
  144. data/lib/fog/openstack/requests/network/update_router.rb +85 -0
  145. data/lib/fog/openstack/storage.rb +57 -0
  146. data/lib/fog/ovirt/compute.rb +4 -0
  147. data/lib/fog/ovirt/models/compute/quota.rb +21 -0
  148. data/lib/fog/ovirt/models/compute/quotas.rb +24 -0
  149. data/lib/fog/ovirt/models/compute/server.rb +2 -1
  150. data/lib/fog/ovirt/models/compute/volume.rb +1 -0
  151. data/lib/fog/ovirt/requests/compute/get_quota.rb +19 -0
  152. data/lib/fog/ovirt/requests/compute/list_quotas.rb +21 -0
  153. data/lib/fog/ovirt/requests/compute/mock_files/quotas.xml +7 -0
  154. data/lib/fog/rackspace.rb +11 -0
  155. data/lib/fog/rackspace/block_storage.rb +73 -20
  156. data/lib/fog/rackspace/cdn.rb +57 -19
  157. data/lib/fog/rackspace/compute.rb +53 -28
  158. data/lib/fog/rackspace/compute_v2.rb +99 -22
  159. data/lib/fog/rackspace/databases.rb +74 -18
  160. data/lib/fog/rackspace/dns.rb +55 -22
  161. data/lib/fog/rackspace/docs/block_storage.md +417 -0
  162. data/lib/fog/rackspace/docs/compute_v2.md +114 -55
  163. data/lib/fog/rackspace/docs/getting_started.md +20 -10
  164. data/lib/fog/rackspace/docs/storage.md +496 -0
  165. data/lib/fog/rackspace/examples/README.md +1 -1
  166. data/lib/fog/rackspace/examples/block_storage/create_snapshot.rb +118 -0
  167. data/lib/fog/rackspace/examples/block_storage/create_volume.rb +58 -0
  168. data/lib/fog/rackspace/examples/block_storage/delete_volume.rb +53 -0
  169. data/lib/fog/rackspace/examples/compute_v2/create_image.rb +2 -2
  170. data/lib/fog/rackspace/examples/compute_v2/create_server.rb +1 -1
  171. data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +2 -2
  172. data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +2 -2
  173. data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +4 -4
  174. data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +2 -2
  175. data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +3 -3
  176. data/lib/fog/rackspace/examples/compute_v2/server_metadata.rb +2 -2
  177. data/lib/fog/rackspace/examples/storage/create_cdn_directory.rb +44 -0
  178. data/lib/fog/rackspace/examples/storage/create_private_directory.rb +46 -0
  179. data/lib/fog/rackspace/examples/storage/delete_directory.rb +62 -0
  180. data/lib/fog/rackspace/examples/storage/delete_file.rb +70 -0
  181. data/lib/fog/rackspace/examples/storage/download_file.rb +75 -0
  182. data/lib/fog/rackspace/examples/storage/lorem.txt +1 -0
  183. data/lib/fog/rackspace/examples/storage/storage_metadata.rb +82 -0
  184. data/lib/fog/rackspace/examples/storage/upload_file.rb +45 -0
  185. data/lib/fog/rackspace/identity.rb +10 -3
  186. data/lib/fog/rackspace/load_balancers.rb +76 -18
  187. data/lib/fog/rackspace/models/block_storage/snapshot.rb +42 -0
  188. data/lib/fog/rackspace/models/block_storage/snapshots.rb +15 -0
  189. data/lib/fog/rackspace/models/block_storage/volume.rb +65 -0
  190. data/lib/fog/rackspace/models/block_storage/volume_type.rb +6 -0
  191. data/lib/fog/rackspace/models/block_storage/volume_types.rb +15 -0
  192. data/lib/fog/rackspace/models/block_storage/volumes.rb +15 -0
  193. data/lib/fog/rackspace/models/compute_v2/attachment.rb +8 -0
  194. data/lib/fog/rackspace/models/compute_v2/attachments.rb +9 -1
  195. data/lib/fog/rackspace/models/compute_v2/flavors.rb +9 -1
  196. data/lib/fog/rackspace/models/compute_v2/image.rb +10 -2
  197. data/lib/fog/rackspace/models/compute_v2/images.rb +9 -1
  198. data/lib/fog/rackspace/models/compute_v2/meta_parent.rb +1 -1
  199. data/lib/fog/rackspace/models/compute_v2/metadata.rb +17 -5
  200. data/lib/fog/rackspace/models/compute_v2/metadatum.rb +8 -0
  201. data/lib/fog/rackspace/models/compute_v2/server.rb +72 -13
  202. data/lib/fog/rackspace/models/compute_v2/servers.rb +16 -2
  203. data/lib/fog/rackspace/models/dns/zones.rb +5 -9
  204. data/lib/fog/rackspace/models/identity/service_catalog.rb +83 -0
  205. data/lib/fog/rackspace/models/storage/account.rb +26 -0
  206. data/lib/fog/rackspace/models/storage/directories.rb +23 -3
  207. data/lib/fog/rackspace/models/storage/directory.rb +89 -5
  208. data/lib/fog/rackspace/models/storage/file.rb +112 -2
  209. data/lib/fog/rackspace/models/storage/files.rb +78 -0
  210. data/lib/fog/rackspace/models/storage/metadata.rb +28 -5
  211. data/lib/fog/rackspace/requests/block_storage/create_snapshot.rb +24 -0
  212. data/lib/fog/rackspace/requests/block_storage/create_volume.rb +29 -0
  213. data/lib/fog/rackspace/requests/block_storage/delete_snapshot.rb +10 -0
  214. data/lib/fog/rackspace/requests/block_storage/delete_volume.rb +11 -0
  215. data/lib/fog/rackspace/requests/block_storage/get_snapshot.rb +20 -0
  216. data/lib/fog/rackspace/requests/block_storage/get_volume.rb +24 -0
  217. data/lib/fog/rackspace/requests/block_storage/get_volume_type.rb +14 -0
  218. data/lib/fog/rackspace/requests/block_storage/list_snapshots.rb +17 -0
  219. data/lib/fog/rackspace/requests/block_storage/list_volume_types.rb +13 -0
  220. data/lib/fog/rackspace/requests/block_storage/list_volumes.rb +21 -0
  221. data/lib/fog/rackspace/requests/cdn/delete_object.rb +5 -1
  222. data/lib/fog/rackspace/requests/cdn/get_containers.rb +5 -0
  223. data/lib/fog/rackspace/requests/cdn/head_container.rb +5 -0
  224. data/lib/fog/rackspace/requests/cdn/post_container.rb +6 -1
  225. data/lib/fog/rackspace/requests/cdn/put_container.rb +6 -1
  226. data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +4 -0
  227. data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +4 -0
  228. data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +5 -0
  229. data/lib/fog/rackspace/requests/compute_v2/create_image.rb +9 -4
  230. data/lib/fog/rackspace/requests/compute_v2/create_server.rb +9 -5
  231. data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +5 -0
  232. data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +5 -0
  233. data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +5 -0
  234. data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +5 -0
  235. data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +4 -0
  236. data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +4 -0
  237. data/lib/fog/rackspace/requests/compute_v2/get_image.rb +5 -1
  238. data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +4 -0
  239. data/lib/fog/rackspace/requests/compute_v2/get_server.rb +4 -0
  240. data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +4 -0
  241. data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +4 -0
  242. data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +4 -0
  243. data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +4 -0
  244. data/lib/fog/rackspace/requests/compute_v2/list_images.rb +4 -0
  245. data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +4 -0
  246. data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +4 -0
  247. data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +4 -0
  248. data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +8 -4
  249. data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +6 -1
  250. data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +8 -3
  251. data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +4 -0
  252. data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +4 -0
  253. data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +4 -0
  254. data/lib/fog/rackspace/requests/compute_v2/update_server.rb +4 -0
  255. data/lib/fog/rackspace/requests/storage/copy_object.rb +4 -0
  256. data/lib/fog/rackspace/requests/storage/delete_container.rb +4 -1
  257. data/lib/fog/rackspace/requests/storage/delete_object.rb +4 -1
  258. data/lib/fog/rackspace/requests/storage/get_container.rb +4 -0
  259. data/lib/fog/rackspace/requests/storage/get_containers.rb +4 -0
  260. data/lib/fog/rackspace/requests/storage/get_object.rb +4 -1
  261. data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +7 -4
  262. data/lib/fog/rackspace/requests/storage/head_container.rb +4 -0
  263. data/lib/fog/rackspace/requests/storage/head_containers.rb +4 -0
  264. data/lib/fog/rackspace/requests/storage/head_object.rb +4 -1
  265. data/lib/fog/rackspace/requests/storage/post_set_meta_temp_url_key.rb +4 -1
  266. data/lib/fog/rackspace/requests/storage/put_container.rb +4 -1
  267. data/lib/fog/rackspace/requests/storage/put_object.rb +4 -1
  268. data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +4 -1
  269. data/lib/fog/rackspace/service.rb +78 -0
  270. data/lib/fog/rackspace/storage.rb +62 -22
  271. data/lib/fog/riakcs.rb +122 -0
  272. data/lib/fog/riakcs/provisioning.rb +100 -0
  273. data/lib/fog/riakcs/requests/provisioning/create_user.rb +77 -0
  274. data/lib/fog/riakcs/requests/provisioning/disable_user.rb +23 -0
  275. data/lib/fog/riakcs/requests/provisioning/enable_user.rb +23 -0
  276. data/lib/fog/riakcs/requests/provisioning/get_user.rb +41 -0
  277. data/lib/fog/riakcs/requests/provisioning/list_users.rb +43 -0
  278. data/lib/fog/riakcs/requests/provisioning/regrant_secret.rb +23 -0
  279. data/lib/fog/riakcs/requests/provisioning/update_user.rb +23 -0
  280. data/lib/fog/riakcs/requests/usage/get_usage.rb +68 -0
  281. data/lib/fog/riakcs/usage.rb +66 -0
  282. data/lib/fog/vcloud/compute.rb +1 -1
  283. data/lib/fog/vcloud/models/compute/catalog_item.rb +8 -0
  284. data/lib/fog/vcloud/models/compute/server.rb +1 -0
  285. data/lib/fog/vcloud/requests/compute/configure_vm_network.rb +1 -2
  286. data/lib/fog/version.rb +1 -1
  287. data/lib/fog/vsphere/compute.rb +1 -1
  288. data/lib/fog/vsphere/models/compute/servers.rb +9 -9
  289. data/lib/fog/xenserver.rb +2 -0
  290. data/lib/fog/xenserver/CHANGELOG.md +7 -1
  291. data/lib/fog/xenserver/compute.rb +6 -0
  292. data/lib/fog/xenserver/examples/networks-and-vlans.rb +45 -0
  293. data/lib/fog/xenserver/models/compute/network.rb +33 -0
  294. data/lib/fog/xenserver/models/compute/vlan.rb +80 -0
  295. data/lib/fog/xenserver/models/compute/vlans.rb +39 -0
  296. data/lib/fog/xenserver/requests/compute/create_network.rb +42 -0
  297. data/lib/fog/xenserver/requests/compute/create_vlan.rb +35 -0
  298. data/lib/fog/xenserver/requests/compute/destroy_network.rb +33 -0
  299. data/lib/fog/xenserver/requests/compute/destroy_vlan.rb +32 -0
  300. data/lib/fog/zerigo/models/dns/records.rb +15 -12
  301. data/lib/tasks/changelog_task.rb +1 -0
  302. data/tests/aws/requests/compute/address_tests.rb +4 -0
  303. data/tests/aws/requests/iam/server_certificate_tests.rb +32 -0
  304. data/tests/cloudstack/compute/models/snapshot_tests.rb +34 -0
  305. data/tests/digitalocean/helper.rb +44 -0
  306. data/tests/digitalocean/models/compute/flavor_tests.rb +30 -0
  307. data/tests/digitalocean/models/compute/image_tests.rb +31 -0
  308. data/tests/digitalocean/models/compute/region_tests.rb +30 -0
  309. data/tests/digitalocean/models/compute/server_tests.rb +84 -0
  310. data/tests/digitalocean/models/compute/servers_tests.rb +35 -0
  311. data/tests/digitalocean/models/compute/ssh_key_tests.rb +40 -0
  312. data/tests/digitalocean/models/compute/ssh_keys_tests.rb +28 -0
  313. data/tests/digitalocean/requests/compute/create_server_tests.rb +28 -0
  314. data/tests/digitalocean/requests/compute/create_ssh_key_tests.rb +22 -0
  315. data/tests/digitalocean/requests/compute/destroy_server_tests.rb +15 -0
  316. data/tests/digitalocean/requests/compute/destroy_ssh_key_tests.rb +23 -0
  317. data/tests/digitalocean/requests/compute/get_server_details_tests.rb +13 -0
  318. data/tests/digitalocean/requests/compute/get_ssh_key_tests.rb +22 -0
  319. data/tests/digitalocean/requests/compute/list_flavors_tests.rb +23 -0
  320. data/tests/digitalocean/requests/compute/list_images_tests.rb +24 -0
  321. data/tests/digitalocean/requests/compute/list_regions_tests.rb +23 -0
  322. data/tests/digitalocean/requests/compute/list_servers_tests.rb +26 -0
  323. data/tests/digitalocean/requests/compute/list_ssh_keys_tests.rb +21 -0
  324. data/tests/digitalocean/requests/compute/power_cycle_server_tests.rb +20 -0
  325. data/tests/digitalocean/requests/compute/power_state_tests.rb +25 -0
  326. data/tests/digitalocean/requests/compute/reboot_server_tests.rb +14 -0
  327. data/tests/helpers/collection_helper.rb +36 -1
  328. data/tests/helpers/mock_helper.rb +2 -0
  329. data/tests/internet_archive/models/storage/directory_tests.rb +24 -32
  330. data/tests/internet_archive/models/storage/file_tests.rb +16 -35
  331. data/tests/internet_archive/models/storage/files_tests.rb +33 -31
  332. data/tests/internet_archive/models/storage/url_tests.rb +1 -1
  333. data/tests/internet_archive/requests/storage/bucket_tests.rb +34 -38
  334. data/tests/internet_archive/requests/storage/multipart_upload_tests.rb +1 -1
  335. data/tests/openstack/models/network/network_tests.rb +17 -0
  336. data/tests/openstack/models/network/router_tests.rb +38 -0
  337. data/tests/openstack/models/network/routers_tests.rb +21 -0
  338. data/tests/openstack/requests/network/network_tests.rb +61 -10
  339. data/tests/openstack/requests/network/router_tests.rb +75 -0
  340. data/tests/openstack/storage_tests.rb +19 -0
  341. data/tests/ovirt/requests/compute/list_quotas_tests.rb +12 -0
  342. data/tests/rackspace/block_storage_tests.rb +101 -0
  343. data/tests/rackspace/cdn_tests.rb +144 -52
  344. data/tests/rackspace/compute_tests.rb +88 -0
  345. data/tests/rackspace/compute_v2_tests.rb +101 -0
  346. data/tests/rackspace/databases_tests.rb +98 -0
  347. data/tests/rackspace/dns_tests.rb +82 -0
  348. data/tests/rackspace/load_balancer_tests.rb +99 -0
  349. data/tests/rackspace/models/compute_v2/image_tests.rb +51 -0
  350. data/tests/rackspace/models/compute_v2/server_tests.rb +51 -0
  351. data/tests/rackspace/models/identity/service_catalog_tests.rb +81 -0
  352. data/tests/rackspace/models/storage/file_tests.rb +10 -1
  353. data/tests/rackspace/rackspace_tests.rb +21 -0
  354. data/tests/rackspace/requests/compute_v2/metadata_tests.rb +2 -2
  355. data/tests/rackspace/requests/storage/object_tests.rb +2 -2
  356. data/tests/rackspace/storage_tests.rb +99 -3
  357. data/tests/riakcs/requests/provisioning/provisioning_tests.rb +174 -0
  358. data/tests/riakcs/requests/usage/usage_tests.rb +29 -0
  359. data/tests/xenserver/models/compute/network_tests.rb +18 -6
  360. data/tests/xenserver/models/compute/vlan_tests.rb +76 -0
  361. data/tests/xenserver/models/compute/vlans_tests.rb +36 -0
  362. data/tests/xenserver/requests/compute/create_network_tests.rb +20 -0
  363. data/tests/xenserver/requests/compute/create_vlan_tests.rb +36 -0
  364. data/tests/xenserver/requests/compute/destroy_network_tests.rb +13 -0
  365. data/tests/xenserver/requests/compute/destroy_vlan_tests.rb +36 -0
  366. metadata +178 -21
  367. data/lib/fog/internet_archive/models/storage/version.rb +0 -36
  368. data/lib/fog/internet_archive/models/storage/versions.rb +0 -38
  369. data/lib/fog/internet_archive/parsers/storage/get_bucket_object_versions.rb +0 -88
  370. data/lib/fog/internet_archive/parsers/storage/get_bucket_versioning.rb +0 -24
  371. data/lib/fog/internet_archive/requests/storage/get_bucket_object_versions.rb +0 -162
  372. data/lib/fog/internet_archive/requests/storage/get_bucket_versioning.rb +0 -69
  373. data/lib/fog/internet_archive/requests/storage/put_bucket_versioning.rb +0 -75
  374. data/lib/fog/openstack/README.identity.md +0 -69
  375. data/lib/fog/providers.rb +0 -34
  376. data/lib/fog/rackspace/examples/compute_v2/README.md +0 -47
  377. data/tests/internet_archive/models/storage/version_tests.rb +0 -52
  378. data/tests/internet_archive/models/storage/versions_tests.rb +0 -56
  379. data/tests/internet_archive/requests/storage/versioning_tests.rb +0 -258
@@ -14,11 +14,7 @@ module Fog
14
14
  # @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTObjectDELETE.html
15
15
 
16
16
  def delete_object(bucket_name, object_name, options = {})
17
- if version_id = options.delete('versionId')
18
- path = "#{CGI.escape(object_name)}?versionId=#{CGI.escape(version_id)}"
19
- else
20
- path = CGI.escape(object_name)
21
- end
17
+ path = CGI.escape(object_name)
22
18
 
23
19
  headers = options
24
20
  request({
@@ -40,56 +36,7 @@ module Fog
40
36
  if bucket = self.data[:buckets][bucket_name]
41
37
  response.status = 204
42
38
 
43
- version_id = options.delete('versionId')
44
-
45
- if bucket[:versioning]
46
- bucket[:objects][object_name] ||= []
47
-
48
- if version_id
49
- version = bucket[:objects][object_name].find { |object| object['VersionId'] == version_id}
50
-
51
- # S3 special cases the 'null' value to not error out if no such version exists.
52
- if version || (version_id == 'null')
53
- bucket[:objects][object_name].delete(version)
54
- bucket[:objects].delete(object_name) if bucket[:objects][object_name].empty?
55
-
56
- response.headers['x-amz-delete-marker'] = 'true' if version[:delete_marker]
57
- response.headers['x-amz-version-id'] = version_id
58
- else
59
- response.status = 400
60
- response.body = invalid_version_id_payload(version_id)
61
- raise(Excon::Errors.status_error({:expects => 200}, response))
62
- end
63
- else
64
- delete_marker = {
65
- :delete_marker => true,
66
- 'Key' => object_name,
67
- 'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null',
68
- 'Last-Modified' => Fog::Time.now.to_date_header
69
- }
70
-
71
- # When versioning is suspended, a delete marker is placed if the last object ID is not the value 'null',
72
- # otherwise the last object is replaced.
73
- if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
74
- bucket[:objects][object_name].shift
75
- end
76
-
77
- bucket[:objects][object_name].unshift(delete_marker)
78
-
79
- response.headers['x-amz-delete-marker'] = 'true'
80
- response.headers['x-amz-version-id'] = delete_marker['VersionId']
81
- end
82
- else
83
- if version_id && version_id != 'null'
84
- response.status = 400
85
- response.body = invalid_version_id_payload(version_id)
86
- raise(Excon::Errors.status_error({:expects => 200}, response))
87
- else
88
- bucket[:objects].delete(object_name)
89
-
90
- response.headers['x-amz-version-id'] = 'null'
91
- end
92
- end
39
+ bucket[:objects].delete(object_name)
93
40
  else
94
41
  response.status = 404
95
42
  raise(Excon::Errors.status_error({:expects => 204}, response))
@@ -97,21 +44,6 @@ module Fog
97
44
  response
98
45
  end
99
46
 
100
- private
101
-
102
- def invalid_version_id_payload(version_id)
103
- {
104
- 'Error' => {
105
- 'Code' => 'InvalidArgument',
106
- 'Message' => 'Invalid version id specified',
107
- 'ArgumentValue' => version_id,
108
- 'ArgumentName' => 'versionId',
109
- 'RequestId' => Fog::Mock.random_hex(16),
110
- 'HostId' => Fog::Mock.random_base64(65)
111
- }
112
- }
113
- end
114
-
115
47
  end
116
48
  end
117
49
  end
@@ -13,7 +13,6 @@ module Fog
13
13
  # @option options If-None-Match [String] Returns object only if its etag differs from this value, otherwise returns 304 (Not Modified)
14
14
  # @option options If-Unmodified-Since [Time] Returns object only if it has not been modified since this time, otherwise returns 412 (Precodition Failed).
15
15
  # @option options Range [String] Range of object to download
16
- # @option options versionId [String] specify a particular version to retrieve
17
16
  #
18
17
  # @return [Excon::Response] response:
19
18
  # * body [String]- Contents of object
@@ -34,9 +33,6 @@ module Fog
34
33
  end
35
34
 
36
35
  params = { :headers => {} }
37
- if version_id = options.delete('versionId')
38
- params[:query] = {'versionId' => version_id}
39
- end
40
36
  params[:headers].merge!(options)
41
37
  if options['If-Modified-Since']
42
38
  params[:headers]['If-Modified-Since'] = Fog::Time.at(options['If-Modified-Since'].to_i).to_date_header
@@ -63,7 +59,6 @@ module Fog
63
59
  class Mock # :nodoc:all
64
60
 
65
61
  def get_object(bucket_name, object_name, options = {}, &block)
66
- version_id = options.delete('versionId')
67
62
 
68
63
  unless bucket_name
69
64
  raise ArgumentError.new('bucket_name is required')
@@ -77,7 +72,7 @@ module Fog
77
72
  if (bucket = self.data[:buckets][bucket_name])
78
73
  object = nil
79
74
  if bucket[:objects].has_key?(object_name)
80
- object = version_id ? bucket[:objects][object_name].find { |object| object['VersionId'] == version_id} : bucket[:objects][object_name].first
75
+ object = bucket[:objects][object_name].first
81
76
  end
82
77
 
83
78
  if (object && !object[:delete_marker])
@@ -98,8 +93,6 @@ module Fog
98
93
  end
99
94
  end
100
95
 
101
- response.headers['x-amz-version-id'] = object['VersionId'] if bucket[:versioning]
102
-
103
96
  body = object[:body]
104
97
  if options['Range']
105
98
  # since AWS S3 itself does not support multiple range headers, we will use only the first
@@ -122,20 +115,6 @@ module Fog
122
115
  end
123
116
  end
124
117
  end
125
- elsif version_id && !object
126
- response.status = 400
127
- response.body = {
128
- 'Error' => {
129
- 'Code' => 'InvalidArgument',
130
- 'Message' => 'Invalid version id specified',
131
- 'ArgumentValue' => version_id,
132
- 'ArgumentName' => 'versionId',
133
- 'RequestId' => Fog::Mock.random_hex(16),
134
- 'HostId' => Fog::Mock.random_base64(65)
135
- }
136
- }
137
-
138
- raise(Excon::Errors.status_error({:expects => 200}, response))
139
118
  else
140
119
  response.status = 404
141
120
  response.body = "...<Code>NoSuchKey<\/Code>..."
@@ -10,7 +10,6 @@ module Fog
10
10
  # @param bucket_name [String] name of bucket containing object
11
11
  # @param object_name [String] name of object to get access control list for
12
12
  # @param options [Hash]
13
- # @option options versionId [String] specify a particular version to retrieve
14
13
  #
15
14
  # @return [Excon::Response] response:
16
15
  # * body [Hash]:
@@ -37,9 +36,6 @@ module Fog
37
36
  raise ArgumentError.new('object_name is required')
38
37
  end
39
38
  query = {'acl' => nil}
40
- if version_id = options.delete('versionId')
41
- query['versionId'] = version_id
42
- end
43
39
  request({
44
40
  :expects => 200,
45
41
  :headers => {},
@@ -25,8 +25,7 @@ module Fog
25
25
  :host => @host,
26
26
  :idempotent => true,
27
27
  :method => 'GET',
28
- :parser => Fog::Parsers::Storage::InternetArchive::GetService.new,
29
- :url => @host
28
+ :parser => Fog::Parsers::Storage::InternetArchive::GetService.new
30
29
  })
31
30
  end
32
31
 
@@ -13,7 +13,6 @@ module Fog
13
13
  # @option options [String] If-None-Match Returns object only if its etag differs from this value, otherwise returns 304 (Not Modified)
14
14
  # @option options [Time] If-Unmodified-Since Returns object only if it has not been modified since this time, otherwise returns 412 (Precodition Failed).
15
15
  # @option options [String] Range Range of object to download
16
- # @option options [String] versionId specify a particular version to retrieve
17
16
  #
18
17
  # @return [Excon::Response] response:
19
18
  # * body [String] Contents of object
@@ -32,9 +31,6 @@ module Fog
32
31
  unless object_name
33
32
  raise ArgumentError.new('object_name is required')
34
33
  end
35
- if version_id = options.delete('versionId')
36
- query = {'versionId' => version_id}
37
- end
38
34
  headers = {}
39
35
  headers['If-Modified-Since'] = Fog::Time.at(options['If-Modified-Since'].to_i).to_date_header if options['If-Modified-Since']
40
36
  headers['If-Unmodified-Since'] = Fog::Time.at(options['If-Unmodified-Since'].to_i).to_date_header if options['If-Modified-Since']
@@ -4,7 +4,7 @@ module Fog
4
4
  class Real
5
5
 
6
6
  # Get a hash of hidden fields for form uploading to S3, in the form {:field_name => :field_value}
7
- # Form should look like: <form action="http://#{bucket_name}.s3.#{Fog::InternetArchive::DOMAIN_NAME}/" method="post" enctype="multipart/form-data">
7
+ # Form should look like: <form action="http://#{bucket_name}.#{Fog::InternetArchive::API_DOMAIN_NAME}/" method="post" enctype="multipart/form-data">
8
8
  # These hidden fields should then appear, followed by a field named 'file' which is either a textarea or file input.
9
9
  #
10
10
  # @param options Hash:
@@ -67,30 +67,16 @@ module Fog
67
67
  'Key' => object_name,
68
68
  'Last-Modified' => Fog::Time.now.to_date_header,
69
69
  'Content-Length' => options['Content-Length'] || data[:headers]['Content-Length'],
70
- 'StorageClass' => options['x-amz-storage-class'] || 'STANDARD',
71
- 'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null'
72
70
  }
73
71
 
74
72
  for key, value in options
75
73
  case key
76
- when 'Cache-Control', 'Content-Disposition', 'Content-Encoding', 'Content-MD5', 'Expires', /^x-amz-meta-/
74
+ when 'Cache-Control', 'Content-Disposition', 'Content-Encoding', 'Content-MD5', 'Expires', /^x-amz-meta-/, /^x-archive-/
77
75
  object[key] = value
78
76
  end
79
77
  end
80
78
 
81
- if bucket[:versioning]
82
- bucket[:objects][object_name] ||= []
83
-
84
- # When versioning is suspended, putting an object will create a new 'null' version if the latest version
85
- # is a value other than 'null', otherwise it will replace the latest version.
86
- if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
87
- bucket[:objects][object_name].shift
88
- end
89
-
90
- bucket[:objects][object_name].unshift(object)
91
- else
92
- bucket[:objects][object_name] = [object]
93
- end
79
+ bucket[:objects][object_name] = [object]
94
80
 
95
81
  response.headers = {
96
82
  'Content-Length' => object['Content-Length'],
@@ -99,7 +85,6 @@ module Fog
99
85
  'Last-Modified' => object['Last-Modified'],
100
86
  }
101
87
 
102
- response.headers['x-amz-version-id'] = object['VersionId'] if object['VersionId'] != 'null'
103
88
  else
104
89
  response.status = 404
105
90
  raise(Excon::Errors.status_error({:expects => 200}, response))
@@ -24,16 +24,11 @@ module Fog
24
24
  # * Permission [String] Permission, in [FULL_CONTROL, WRITE, WRITE_ACP, READ, READ_ACP]
25
25
  # @param acl [String] Permissions, must be in ['private', 'public-read', 'public-read-write', 'authenticated-read']
26
26
  # @param options [Hash]
27
- # @option options versionId [String] specify a particular version to retrieve
28
27
  #
29
28
  # @see http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTObjectPUTacl.html
30
29
 
31
30
  def put_object_acl(bucket_name, object_name, acl, options = {})
32
31
  query = {'acl' => nil}
33
- if version_id = options.delete('versionId')
34
- query['versionId'] = version_id
35
- end
36
-
37
32
  data = ""
38
33
  headers = {}
39
34
 
@@ -33,9 +33,7 @@ module Fog
33
33
  request :get_bucket_lifecycle
34
34
  request :get_bucket_location
35
35
  request :get_bucket_logging
36
- request :get_bucket_object_versions
37
36
  request :get_bucket_policy
38
- request :get_bucket_versioning
39
37
  request :get_bucket_website
40
38
  request :get_object
41
39
  request :get_object_acl
@@ -56,7 +54,6 @@ module Fog
56
54
  request :put_bucket_lifecycle
57
55
  request :put_bucket_logging
58
56
  request :put_bucket_policy
59
- request :put_bucket_versioning
60
57
  request :put_bucket_website
61
58
  request :put_object
62
59
  request :put_object_acl
@@ -79,9 +76,10 @@ module Fog
79
76
 
80
77
  def url(params, expires)
81
78
  Fog::Logger.deprecation("Fog::Storage::InternetArchive => #url is deprecated, use #https_url instead [light_black](#{caller.first})[/]")
82
- https_url(params, expires)
79
+ http_url(params, expires)
83
80
  end
84
81
 
82
+
85
83
  private
86
84
 
87
85
  def scheme_host_path_query(params, expires)
@@ -201,13 +199,8 @@ module Fog
201
199
  require 'mime/types'
202
200
  setup_credentials(options)
203
201
  options[:region] ||= 'us-east-1'
204
- @host = options[:host] || case options[:region]
205
- when 'us-east-1'
206
- "s3.#{Fog::InternetArchive::DOMAIN_NAME}"
207
- else
208
- "s3-#{options[:region]}.#{Fog::InternetArchive::DOMAIN_NAME}"
209
- end
210
- @scheme = options[:scheme] || 'https'
202
+ @host = options[:host] || Fog::InternetArchive::API_DOMAIN_NAME
203
+ @scheme = options[:scheme] || 'http'
211
204
  @region = options[:region]
212
205
  end
213
206
 
@@ -273,12 +266,7 @@ module Fog
273
266
  else
274
267
  options[:region] ||= 'us-east-1'
275
268
  @region = options[:region]
276
- @host = options[:host] || case options[:region]
277
- when 'us-east-1'
278
- "s3.#{Fog::InternetArchive::DOMAIN_NAME}"
279
- else
280
- "s3-#{options[:region]}.#{Fog::InternetArchive::DOMAIN_NAME}"
281
- end
269
+ @host = options[:host] || Fog::InternetArchive::API_DOMAIN_NAME
282
270
  @path = options[:path] || '/'
283
271
  @persistent = options.fetch(:persistent, false)
284
272
  @port = options[:port] || 80
@@ -389,7 +377,7 @@ DATA
389
377
  begin
390
378
  response = @connection.request(params, &block)
391
379
  rescue Excon::Errors::TemporaryRedirect => error
392
- uri = URI.parse(error.response.headers['Location'])
380
+ uri = URI.parse(error.response.headers['location'])
393
381
  Fog::Logger.warning("fog: followed redirect to #{uri.host}, connecting to the matching region will be more performant")
394
382
  response = Fog::Connection.new("#{@scheme}://#{uri.host}:#{@port}", false, @connection_options).request(original_params, &block)
395
383
  end
@@ -1,3 +1,5 @@
1
+ require 'fog/core'
2
+
1
3
  module Fog
2
4
  module Joyent
3
5
  extend Fog::Provider
@@ -14,7 +14,7 @@ module Fog
14
14
  node_hash[:uri] = client.uri
15
15
  xml = client.sys_info rescue nil
16
16
  [:uuid, :manufacturer, :product, :serial].each do |attr|
17
- node_hash[attr] = node_attr(attr, xml)
17
+ node_hash[attr] = node_attr(attr, xml) rescue nil
18
18
  end if xml
19
19
 
20
20
  node_hash[:hostname] = client.hostname
@@ -0,0 +1,47 @@
1
+ # 1.11.0 2013/04/04
2
+
3
+ ## Storage
4
+
5
+ * Added storage (Swift) example to set account quotas:
6
+
7
+ https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/storage/set-account-quota.rb
8
+
9
+ * Added account impersonation to the storage service
10
+
11
+ Now it's possible to use an admin account with a reseller
12
+ role to impersonate other accounts and set account metadata
13
+ headers. See the account quotas example included in this release
14
+
15
+ ## Network
16
+
17
+ * create_network request updated
18
+
19
+ Implements provider extensions when creating networks.
20
+
21
+ See http://docs.openstack.org/trunk/openstack-network/admin/content/provider_attributes.html
22
+
23
+ * Network Router support (Quantum)
24
+
25
+ Added router model/collection and related requests.
26
+
27
+ * New network service example
28
+
29
+ See https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/network/network_subnets_routers.rb
30
+
31
+ * :openstack_endpoint_type parameter was added to the network service
32
+
33
+ ## Image
34
+
35
+ * Added basic image service example (Glance)
36
+
37
+ Download CirrOS 0.3.0 image from launchpad (~6.5MB) to /tmp
38
+ and upload it to Glance.
39
+
40
+ See https://github.com/fog/fog/blob/master/lib/fog/openstack/examples/image/upload-test-image.rb
41
+
42
+ * Check for glance version (fog only supports v1)
43
+
44
+ ## Compute
45
+
46
+ * create_server and the Server model where updated to allow booting a VM
47
+ with NICs (net_id, port_id, fixed_ip).
@@ -0,0 +1,69 @@
1
+ # OpenStack Identity Service (Keystone) Example
2
+
3
+ require 'fog'
4
+ require 'pp'
5
+
6
+ auth_url = "https://example.net/v2.0/tokens"
7
+ username = 'admin@example.net'
8
+ password = 'secret'
9
+
10
+ keystone = Fog::Identity.new :provider => 'OpenStack',
11
+ :openstack_auth_url => auth_url,
12
+ :openstack_username => username,
13
+ :openstack_api_key => password
14
+ # Optional, self-signed certs
15
+ #:connection_options => { :ssl_verify_peer => false }
16
+
17
+ #
18
+ # Listing keystone tenants
19
+ #
20
+ keystone.tenants.each do |tenant|
21
+ # <Fog::Identity::OpenStack::Tenant
22
+ # id="46b4ab...",
23
+ # description=nil,
24
+ # enabled=1,
25
+ # name="admin@example.net"
26
+ # >
27
+ pp tenant
28
+ end
29
+
30
+ #
31
+ # List users
32
+ #
33
+ keystone.users.each do |user|
34
+ # <Fog::Identity::OpenStack::User
35
+ # id="c975f...",
36
+ # email="quantum@example.net",
37
+ # enabled=true,
38
+ # name="quantum",
39
+ # tenant_id="00928...",
40
+ # password=nil
41
+ # >
42
+ # ...
43
+ pp user
44
+ end
45
+
46
+ #
47
+ # Create a new tenant
48
+ #
49
+ tenant = keystone.tenants.create :name => 'rubiojr@example.net',
50
+ :description => 'My foo tenant'
51
+
52
+ #
53
+ # Create a new user
54
+ #
55
+ user = keystone.users.create :name => 'rubiojr@example.net',
56
+ :tenant_id => tenant.id,
57
+ :password => 'rubiojr@example.net',
58
+ :email => 'rubiojr@example.net'
59
+
60
+
61
+ # Find the recently created tenant
62
+ tenant = keystone.tenants.find { |t| t.name == 'rubiojr@example.net' }
63
+ # Destroy the tenant
64
+ tenant.destroy
65
+
66
+ # Find the recently created user
67
+ user = keystone.users.find { |u| u.name == 'rubiojr@example.net' }
68
+ # Destroy the user
69
+ user.destroy