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
@@ -1,36 +1,39 @@
1
1
  require 'fog/core/model'
2
2
  require 'fog/internet_archive/models/storage/files'
3
- require 'fog/internet_archive/models/storage/versions'
3
+ require 'fog/internet_archive/models/storage/ia_attributes.rb'
4
4
 
5
5
  module Fog
6
6
  module Storage
7
7
  class InternetArchive
8
8
 
9
9
  class Directory < Fog::Model
10
- VALID_ACLS = ['private', 'public-read', 'public-read-write', 'authenticated-read']
11
10
 
12
- # See http://docs.amazonwebservices.com/AmazonS3/latest/API/RESTBucketPUT.html
13
- INVALID_LOCATIONS = ['us-east-1']
14
-
15
- attr_reader :acl
11
+ extend Fog::Storage::IAAttributes::ClassMethods
12
+ include Fog::Storage::IAAttributes::InstanceMethods
16
13
 
17
14
  identity :key, :aliases => ['Name', 'name']
18
15
 
19
16
  attribute :creation_date, :aliases => 'CreationDate'
20
17
 
18
+ # treat these differently
19
+ attribute :collections
20
+ attribute :subjects
21
+
22
+ ia_metadata_attribute :ignore_preexisting_bucket
23
+ ia_metadata_attribute :interactive_priority
24
+
25
+ # acl for internet archive is always public-read
26
+ def acl
27
+ 'public-read'
28
+ end
29
+
21
30
  def acl=(new_acl)
22
- unless VALID_ACLS.include?(new_acl)
23
- raise ArgumentError.new("acl must be one of [#{VALID_ACLS.join(', ')}]")
24
- else
25
- @acl = new_acl
26
- end
31
+ 'public-read'
27
32
  end
28
33
 
34
+ # See http://archive.org/help/abouts3.txt
29
35
  def destroy
30
- requires :key
31
- service.delete_bucket(key)
32
- true
33
- rescue Excon::Errors::NotFound
36
+ Fog::Logger.warning("fog: Internet Archive does not support deleting a Bucket (i.e. Item). For details see: See http://archive.org/help/abouts3.txt")
34
37
  false
35
38
  end
36
39
 
@@ -63,37 +66,13 @@ module Fog
63
66
  @payer = new_payer
64
67
  end
65
68
 
66
- def versioning?
67
- requires :key
68
- data = service.get_bucket_versioning(key)
69
- data.body['VersioningConfiguration']['Status'] == 'Enabled'
70
- end
71
-
72
- def versioning=(new_versioning)
73
- requires :key
74
- service.put_bucket_versioning(key, new_versioning ? 'Enabled' : 'Suspended')
75
- end
76
-
77
- def versions
78
- @versions ||= Fog::Storage::InternetArchive::Versions.new(:directory => self, :service => service)
79
- end
80
-
81
69
  def public=(new_public)
82
- self.acl = new_public ? 'public-read' : 'private'
83
- new_public
70
+ 'public-read'
84
71
  end
85
72
 
86
73
  def public_url
87
74
  requires :key
88
- if service.get_bucket_acl(key).body['AccessControlList'].detect {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'}
89
- if key.to_s =~ Fog::InternetArchive::COMPLIANT_BUCKET_NAMES
90
- "https://#{key}.s3.#{Fog::InternetArchive::DOMAIN_NAME}"
91
- else
92
- "https://s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{key}"
93
- end
94
- else
95
- nil
96
- end
75
+ "http://#{Fog::InternetArchive::DOMAIN_NAME}/details/#{key}"
97
76
  end
98
77
 
99
78
  def save
@@ -101,7 +80,11 @@ module Fog
101
80
 
102
81
  options = {}
103
82
 
104
- options['x-amz-acl'] = acl if acl
83
+ options['x-archive-ignore-preexisting-bucket'] = ignore_preexisting_bucket if ignore_preexisting_bucket
84
+ options['x-archive-interactive-priority'] = interactive_priority if interactive_priority
85
+
86
+ set_metadata_array_headers(:collections, options)
87
+ set_metadata_array_headers(:subjects, options)
105
88
 
106
89
  if location = attributes[:location] || (self.service.region != 'us-east-1' && self.service.region)
107
90
  options['LocationConstraint'] = location
@@ -1,16 +1,26 @@
1
1
  require 'fog/core/model'
2
- require 'fog/internet_archive/models/storage/versions'
2
+ require 'fog/internet_archive/models/storage/ia_attributes.rb'
3
3
 
4
4
  module Fog
5
5
  module Storage
6
6
  class InternetArchive
7
7
 
8
8
  class File < Fog::Model
9
+
10
+ extend Fog::Storage::IAAttributes::ClassMethods
11
+ include Fog::Storage::IAAttributes::InstanceMethods
12
+
9
13
  # @see AWS Object docs http://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectOps.html
10
14
 
11
- identity :key, :aliases => 'Key'
15
+ # @note Chunk size to use for multipart uploads.
16
+ # Use small chunk sizes to minimize memory. E.g. 5242880 = 5mb
17
+ attr_accessor :multipart_chunk_size
12
18
 
13
19
  attr_writer :body
20
+
21
+
22
+ identity :key, :aliases => 'Key'
23
+
14
24
  attribute :cache_control, :aliases => 'Cache-Control'
15
25
  attribute :content_disposition, :aliases => 'Content-Disposition'
16
26
  attribute :content_encoding, :aliases => 'Content-Encoding'
@@ -22,31 +32,28 @@ module Fog
22
32
  attribute :last_modified, :aliases => ['Last-Modified', 'LastModified']
23
33
  attribute :metadata
24
34
  attribute :owner, :aliases => 'Owner'
25
- attribute :storage_class, :aliases => ['x-amz-storage-class', 'StorageClass']
26
- attribute :encryption, :aliases => 'x-amz-server-side-encryption'
27
- attribute :version, :aliases => 'x-amz-version-id'
28
-
29
- # @note Chunk size to use for multipart uploads.
30
- # Use small chunk sizes to minimize memory. E.g. 5242880 = 5mb
31
- attr_accessor :multipart_chunk_size
32
35
 
36
+ # treat these differently
37
+ attribute :collections
38
+ attribute :subjects
39
+
40
+ ia_metadata_attribute :auto_make_bucket
41
+ ia_metadata_attribute :cascade_delete
42
+ ia_metadata_attribute :ignore_preexisting_bucket
43
+ ia_metadata_attribute :interactive_priority
44
+ ia_metadata_attribute :keep_old_version
45
+ ia_metadata_attribute :queue_derive
46
+ ia_metadata_attribute :size_hint
47
+
48
+ # acl for internet archive is always public-read
49
+ def acl
50
+ 'public-read'
51
+ end
33
52
 
34
- # Set file's access control list (ACL).
35
- #
36
- # valid acls: private, public-read, public-read-write, authenticated-read
37
- #
38
- # @param [String] new_acl one of valid options
39
- # @return [String] @acl
40
- #
41
53
  def acl=(new_acl)
42
- valid_acls = ['private', 'public-read', 'public-read-write', 'authenticated-read']
43
- unless valid_acls.include?(new_acl)
44
- raise ArgumentError.new("acl must be one of [#{valid_acls.join(', ')}]")
45
- end
46
- @acl = new_acl
54
+ 'public-read'
47
55
  end
48
56
 
49
-
50
57
  # Get file's body if exists, else ' '.
51
58
  #
52
59
  # @return [File]
@@ -101,23 +108,20 @@ module Fog
101
108
  # required attributes: directory, key
102
109
  #
103
110
  # @param options [Hash]
104
- # @option options versionId []
105
111
  # @return [Boolean] true if successful
106
112
  #
107
113
  def destroy(options = {})
108
114
  requires :directory, :key
109
- attributes[:body] = nil if options['versionId'] == version
115
+ options['x-archive-cascade-delete'] = cascade_delete if cascade_delete
110
116
  service.delete_object(directory.key, key, options)
111
117
  true
112
118
  end
113
119
 
114
-
115
120
  remove_method :metadata
116
121
  def metadata
117
- attributes.reject {|key, value| !(key.to_s =~ /^x-amz-/)}
122
+ attributes.reject {|key, value| !(key.to_s =~ /^x-(amz||archive)-meta/)}
118
123
  end
119
124
 
120
-
121
125
  remove_method :metadata=
122
126
  def metadata=(new_metadata)
123
127
  merge_attributes(new_metadata)
@@ -143,18 +147,11 @@ module Fog
143
147
  # @return [String] new_puplic
144
148
  #
145
149
  def public=(new_public)
146
- if new_public
147
- @acl = 'public-read'
148
- else
149
- @acl = 'private'
150
- end
151
- new_public
150
+ 'public-read'
152
151
  end
153
152
 
154
153
 
155
- # Get pubically acessible url via http GET.
156
- # Checks persmissions before creating.
157
- # Defaults to s3 subdomain or compliant bucket name
154
+ # Get publicly acessible url via http GET.
158
155
  #
159
156
  # required attributes: directory, key
160
157
  #
@@ -162,15 +159,7 @@ module Fog
162
159
  #
163
160
  def public_url
164
161
  requires :directory, :key
165
- if service.get_object_acl(directory.key, key).body['AccessControlList'].detect {|grant| grant['Grantee']['URI'] == 'http://acs.amazonaws.com/groups/global/AllUsers' && grant['Permission'] == 'READ'}
166
- if directory.key.to_s =~ Fog::InternetArchive::COMPLIANT_BUCKET_NAMES
167
- "https://#{directory.key}.s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
168
- else
169
- "https://s3.#{Fog::InternetArchive::DOMAIN_NAME}/#{directory.key}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
170
- end
171
- else
172
- nil
173
- end
162
+ "http://#{Fog::InternetArchive::DOMAIN_NAME}/download/#{directory.key}/#{Fog::InternetArchive.escape(key)}".gsub('%2F','/')
174
163
  end
175
164
 
176
165
  # Save file with body as contents to directory.key with name key via http PUT
@@ -178,7 +167,6 @@ module Fog
178
167
  # required attributes: body, directory, key
179
168
  #
180
169
  # @param [Hash] options
181
- # @option options [String] acl sets x-amz-acl HTTP header. Valid values include, private | public-read | public-read-write | authenticated-read | bucket-owner-read | bucket-owner-full-control
182
170
  # @option options [String] cache_controle sets Cache-Control header. For example, 'No-cache'
183
171
  # @option options [String] content_disposition sets Content-Disposition HTTP header. For exampple, 'attachment; filename=testing.txt'
184
172
  # @option options [String] content_encoding sets Content-Encoding HTTP header. For example, 'x-gzip'
@@ -192,9 +180,8 @@ module Fog
192
180
  def save(options = {})
193
181
  requires :body, :directory, :key
194
182
  if options != {}
195
- Fog::Logger.deprecation("options param is deprecated, use acl= instead [light_black](#{caller.first})[/]")
183
+ Fog::Logger.deprecation("options param is deprecated [light_black](#{caller.first})[/]")
196
184
  end
197
- options['x-amz-acl'] ||= @acl if @acl
198
185
  options['Cache-Control'] = cache_control if cache_control
199
186
  options['Content-Disposition'] = content_disposition if content_disposition
200
187
  options['Content-Encoding'] = content_encoding if content_encoding
@@ -202,8 +189,15 @@ module Fog
202
189
  options['Content-Type'] = content_type if content_type
203
190
  options['Expires'] = expires if expires
204
191
  options.merge!(metadata)
205
- options['x-amz-storage-class'] = storage_class if storage_class
206
- options['x-amz-server-side-encryption'] = encryption if encryption
192
+
193
+ options['x-archive-auto-make-bucket'] = auto_make_bucket if auto_make_bucket
194
+ options['x-archive-interactive-priority'] = interactive_priority if interactive_priority
195
+ options['x-archive-keep-old-version'] = keep_old_version if keep_old_version
196
+ options['x-archive-queue-derive'] = queue_derive if queue_derive
197
+ options['x-archive-size-hint'] = size_hint.to_i.to_s if size_hint
198
+
199
+ set_metadata_array_headers(:collections, options)
200
+ set_metadata_array_headers(:subjects, options)
207
201
 
208
202
  if multipart_chunk_size && body.respond_to?(:read)
209
203
  data = multipart_save(options)
@@ -212,7 +206,7 @@ module Fog
212
206
  data = service.put_object(directory.key, key, body, options)
213
207
  merge_attributes(data.headers.reject {|key, value| ['Content-Length', 'Content-Type'].include?(key)})
214
208
  end
215
- self.etag.gsub!('"','')
209
+ self.etag.gsub!('"','') if self.etag
216
210
  self.content_length = Fog::Storage.get_body_size(body)
217
211
  self.content_type ||= Fog::Storage.get_content_type(body)
218
212
  true
@@ -232,19 +226,6 @@ module Fog
232
226
  collection.get_url(key, expires, options)
233
227
  end
234
228
 
235
-
236
- # File version if exists or creates new version.
237
- # @return [Fog::Storage::InternetArchive::Version]
238
- #
239
- def versions
240
- @versions ||= begin
241
- Fog::Storage::InternetArchive::Versions.new(
242
- :file => self,
243
- :service => service
244
- )
245
- end
246
- end
247
-
248
229
  private
249
230
 
250
231
  def directory=(new_directory)
@@ -0,0 +1,39 @@
1
+ module Fog
2
+ module Storage
3
+ module IAAttributes
4
+
5
+ # you can add other x-archive-metadata-* values, but these are standard
6
+ IA_STANDARD_METADATA_FIELDS = %q[hidden, title, collection, creator, mediatype, description, date, subject, licenseurl , pick, noindex, notes, rights, contributor, language, coverage, credits]
7
+
8
+ # for x-archive-metadata-mediatype, these are the valid values
9
+ IA_VALID_MEDIA_TYPES = %q[audio, data, etree, image, movies, software, texts, web]
10
+
11
+ module ClassMethods
12
+ def ia_metadata_attribute(name)
13
+ attribute(name, :aliases=>['amz','archive'].collect{|p|"x-#{p}-#{name.to_s.tr('_','-')}"})
14
+ end
15
+ end
16
+
17
+ module InstanceMethods
18
+ # set_metadata_array_headers(:collections, options)
19
+ def set_metadata_array_headers(array_attribute, options={})
20
+ attr_values = Array(self.send(array_attribute))
21
+ opt_values = options.collect do |key,value|
22
+ options.delete(key) if (key.to_s =~ /^x-(amz||archive)-meta(\d*)-#{array_attribute.to_s[0..-2]}/)
23
+ end
24
+ values = (attr_values + opt_values).compact.sort.uniq
25
+ # got the values, now add them back to the options
26
+ if values.size == 1
27
+ options["x-archive-meta-#{array_attribute.to_s[0..-2]}"] = values.first
28
+ elsif values.size > 1
29
+ values[0,99].each_with_index do |value, i|
30
+ options["x-archive-meta#{format("%02d", i+1)}-#{array_attribute.to_s[0..-2]}"] = value
31
+ end
32
+ end
33
+
34
+ end
35
+ end
36
+
37
+ end
38
+ end
39
+ end
@@ -34,14 +34,9 @@ module Fog
34
34
  def delete_multiple_objects(bucket_name, object_names, options = {})
35
35
  data = "<Delete>"
36
36
  data << "<Quiet>true</Quiet>" if options.delete(:quiet)
37
- version_ids = options.delete('versionId')
38
37
  object_names.each do |object_name|
39
38
  data << "<Object>"
40
39
  data << "<Key>#{CGI.escapeHTML(object_name)}</Key>"
41
- object_version = version_ids.nil? ? nil : version_ids[object_name]
42
- if object_version
43
- data << "<VersionId>#{CGI.escapeHTML(object_version)}</VersionId>"
44
- end
45
40
  data << "</Object>"
46
41
  end
47
42
  data << "</Delete>"
@@ -71,12 +66,9 @@ module Fog
71
66
  if bucket = self.data[:buckets][bucket_name]
72
67
  response.status = 200
73
68
  response.body = { 'DeleteResult' => [] }
74
- version_ids = options.delete('versionId')
75
69
  object_names.each do |object_name|
76
- object_version = version_ids.nil? ? nil : version_ids[object_name]
77
70
  response.body['DeleteResult'] << delete_object_helper(bucket,
78
- object_name,
79
- object_version)
71
+ object_name)
80
72
  end
81
73
  else
82
74
  response.status = 404
@@ -87,79 +79,13 @@ module Fog
87
79
 
88
80
  private
89
81
 
90
- def delete_object_helper(bucket, object_name, version_id)
82
+ def delete_object_helper(bucket, object_name)
91
83
  response = { 'Deleted' => {} }
92
- if bucket[:versioning]
93
- bucket[:objects][object_name] ||= []
94
-
95
- if version_id
96
- version = bucket[:objects][object_name].find { |object| object['VersionId'] == version_id}
97
-
98
- # S3 special cases the 'null' value to not error out if no such version exists.
99
- if version || (version_id == 'null')
100
- bucket[:objects][object_name].delete(version)
101
- bucket[:objects].delete(object_name) if bucket[:objects][object_name].empty?
102
-
103
- response['Deleted'] = { 'Key' => object_name,
104
- 'VersionId' => version_id,
105
- 'DeleteMarker' => 'true',
106
- 'DeleteMarkerVersionId' => version_id
107
- }
108
- else
109
- response = delete_error_body(object_name,
110
- version_id,
111
- 'InvalidVersion',
112
- 'Invalid version ID specified')
113
- end
114
- else
115
- delete_marker = {
116
- :delete_marker => true,
117
- 'Key' => object_name,
118
- 'VersionId' => bucket[:versioning] == 'Enabled' ? Fog::Mock.random_base64(32) : 'null',
119
- 'Last-Modified' => Fog::Time.now.to_date_header
120
- }
121
-
122
- # When versioning is suspended, a delete marker is placed if the last object ID is not the value 'null',
123
- # otherwise the last object is replaced.
124
- if bucket[:versioning] == 'Suspended' && bucket[:objects][object_name].first['VersionId'] == 'null'
125
- bucket[:objects][object_name].shift
126
- end
127
-
128
- bucket[:objects][object_name].unshift(delete_marker)
129
-
130
- response['Deleted'] = { 'Key' => object_name,
131
- 'VersionId' => delete_marker['VersionId'],
132
- 'DeleteMarkerVersionId' =>
133
- delete_marker['VersionId'],
134
- 'DeleteMarker' => 'true',
135
- }
136
- end
137
- else
138
- if version_id && version_id != 'null'
139
- response = delete_error_body(object_name,
140
- version_id,
141
- 'InvalidVersion',
142
- 'Invalid version ID specified')
143
- response = invalid_version_id_payload(version_id)
144
- else
145
- bucket[:objects].delete(object_name)
146
- response['Deleted'] = { 'Key' => object_name }
147
- end
148
- end
84
+ bucket[:objects].delete(object_name)
85
+ response['Deleted'] = { 'Key' => object_name }
149
86
  response
150
87
  end
151
88
 
152
- def delete_error_body(key, version_id, message, code)
153
- {
154
- 'Error' => {
155
- 'Code' => code,
156
- 'Message' => message,
157
- 'VersionId' => version_id,
158
- 'Key' => key,
159
- }
160
- }
161
- end
162
-
163
89
  end
164
90
  end
165
91
  end