fog 1.36.0 → 1.37.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (305) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +61 -0
  3. data/Rakefile +0 -3
  4. data/fog.gemspec +4 -3
  5. data/lib/fog/digitalocean/compute_v2.rb +2 -1
  6. data/lib/fog/digitalocean/examples/getting_started.md +24 -48
  7. data/lib/fog/digitalocean/models/compute_v2/server.rb +4 -0
  8. data/lib/fog/digitalocean/models/compute_v2/ssh_key.rb +17 -16
  9. data/lib/fog/digitalocean/requests/compute_v2/delete_ssh_key.rb +1 -1
  10. data/lib/fog/digitalocean/requests/compute_v2/get_image_details.rb +1 -2
  11. data/lib/fog/openstack.rb +2 -0
  12. data/lib/fog/openstack/common.rb +46 -0
  13. data/lib/fog/openstack/compute.rb +3 -1
  14. data/lib/fog/openstack/core.rb +15 -3
  15. data/lib/fog/openstack/docs/compute.md +1 -1
  16. data/lib/fog/openstack/identity.rb +0 -37
  17. data/lib/fog/openstack/identity_v2.rb +9 -3
  18. data/lib/fog/openstack/identity_v3.rb +8 -3
  19. data/lib/fog/openstack/image.rb +1 -41
  20. data/lib/fog/openstack/image_v1.rb +9 -3
  21. data/lib/fog/openstack/image_v2.rb +7 -2
  22. data/lib/fog/openstack/metering.rb +2 -1
  23. data/lib/fog/openstack/models/compute/server.rb +5 -0
  24. data/lib/fog/openstack/models/identity_v2/user.rb +6 -2
  25. data/lib/fog/openstack/models/volume/availability_zone.rb +1 -4
  26. data/lib/fog/openstack/models/volume/availability_zones.rb +1 -4
  27. data/lib/fog/openstack/models/volume/transfer.rb +1 -9
  28. data/lib/fog/openstack/models/volume/transfers.rb +1 -4
  29. data/lib/fog/openstack/models/volume/volume.rb +6 -18
  30. data/lib/fog/openstack/models/volume/volume_type.rb +0 -3
  31. data/lib/fog/openstack/models/volume/volume_types.rb +1 -4
  32. data/lib/fog/openstack/models/volume/volumes.rb +1 -4
  33. data/lib/fog/openstack/models/volume_v1/availability_zone.rb +15 -0
  34. data/lib/fog/openstack/models/volume_v1/availability_zones.rb +16 -0
  35. data/lib/fog/openstack/models/volume_v1/transfer.rb +18 -0
  36. data/lib/fog/openstack/models/volume_v1/transfers.rb +16 -0
  37. data/lib/fog/openstack/models/volume_v1/volume.rb +26 -0
  38. data/lib/fog/openstack/models/volume_v1/volume_type.rb +16 -0
  39. data/lib/fog/openstack/models/volume_v1/volume_types.rb +16 -0
  40. data/lib/fog/openstack/models/volume_v1/volumes.rb +16 -0
  41. data/lib/fog/openstack/models/volume_v2/availability_zone.rb +15 -0
  42. data/lib/fog/openstack/models/volume_v2/availability_zones.rb +16 -0
  43. data/lib/fog/openstack/models/volume_v2/transfer.rb +19 -0
  44. data/lib/fog/openstack/models/volume_v2/transfers.rb +16 -0
  45. data/lib/fog/openstack/models/volume_v2/volume.rb +27 -0
  46. data/lib/fog/openstack/models/volume_v2/volume_type.rb +16 -0
  47. data/lib/fog/openstack/models/volume_v2/volume_types.rb +16 -0
  48. data/lib/fog/openstack/models/volume_v2/volumes.rb +16 -0
  49. data/lib/fog/openstack/network.rb +2 -1
  50. data/lib/fog/openstack/orchestration.rb +2 -1
  51. data/lib/fog/openstack/planning.rb +2 -1
  52. data/lib/fog/openstack/requests/compute/evacuate_server.rb +26 -0
  53. data/lib/fog/openstack/requests/volume/accept_transfer.rb +8 -10
  54. data/lib/fog/openstack/requests/volume/create_transfer.rb +8 -10
  55. data/lib/fog/openstack/requests/volume/create_volume.rb +9 -40
  56. data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +13 -31
  57. data/lib/fog/openstack/requests/volume/create_volume_type.rb +2 -2
  58. data/lib/fog/openstack/requests/volume/delete_snapshot.rb +2 -2
  59. data/lib/fog/openstack/requests/volume/delete_transfer.rb +1 -3
  60. data/lib/fog/openstack/requests/volume/delete_volume.rb +2 -2
  61. data/lib/fog/openstack/requests/volume/delete_volume_type.rb +2 -2
  62. data/lib/fog/openstack/requests/volume/extend_volume.rb +2 -2
  63. data/lib/fog/openstack/requests/volume/get_quota.rb +2 -2
  64. data/lib/fog/openstack/requests/volume/get_quota_defaults.rb +7 -7
  65. data/lib/fog/openstack/requests/volume/get_quota_usage.rb +2 -2
  66. data/lib/fog/openstack/requests/volume/get_snapshot_details.rb +1 -20
  67. data/lib/fog/openstack/requests/volume/get_transfer_details.rb +1 -1
  68. data/lib/fog/openstack/requests/volume/get_volume_details.rb +1 -22
  69. data/lib/fog/openstack/requests/volume/get_volume_type_details.rb +2 -2
  70. data/lib/fog/openstack/requests/volume/list_snapshots.rb +2 -2
  71. data/lib/fog/openstack/requests/volume/list_snapshots_detailed.rb +2 -2
  72. data/lib/fog/openstack/requests/volume/list_transfers.rb +1 -1
  73. data/lib/fog/openstack/requests/volume/list_transfers_detailed.rb +1 -1
  74. data/lib/fog/openstack/requests/volume/list_volume_types.rb +2 -2
  75. data/lib/fog/openstack/requests/volume/list_volumes.rb +1 -34
  76. data/lib/fog/openstack/requests/volume/list_volumes_detailed.rb +1 -34
  77. data/lib/fog/openstack/requests/volume/list_zones.rb +2 -2
  78. data/lib/fog/openstack/requests/volume/set_tenant.rb +2 -2
  79. data/lib/fog/openstack/requests/volume/update_quota.rb +2 -2
  80. data/lib/fog/openstack/requests/volume/update_volume_type.rb +2 -2
  81. data/lib/fog/openstack/requests/volume_v1/accept_transfer.rb +2 -0
  82. data/lib/fog/openstack/requests/volume_v1/create_transfer.rb +2 -0
  83. data/lib/fog/openstack/requests/volume_v1/create_volume.rb +49 -0
  84. data/lib/fog/openstack/requests/volume_v1/create_volume_snapshot.rb +44 -0
  85. data/lib/fog/openstack/requests/volume_v1/create_volume_type.rb +2 -0
  86. data/lib/fog/openstack/requests/volume_v1/delete_snapshot.rb +2 -0
  87. data/lib/fog/openstack/requests/volume_v1/delete_transfer.rb +2 -0
  88. data/lib/fog/openstack/requests/volume_v1/delete_volume.rb +2 -0
  89. data/lib/fog/openstack/requests/volume_v1/delete_volume_type.rb +2 -0
  90. data/lib/fog/openstack/requests/volume_v1/extend_volume.rb +2 -0
  91. data/lib/fog/openstack/requests/volume_v1/get_quota.rb +2 -0
  92. data/lib/fog/openstack/requests/volume_v1/get_quota_defaults.rb +2 -0
  93. data/lib/fog/openstack/requests/volume_v1/get_quota_usage.rb +2 -0
  94. data/lib/fog/openstack/requests/volume_v1/get_snapshot_details.rb +32 -0
  95. data/lib/fog/openstack/requests/volume_v1/get_transfer_details.rb +2 -0
  96. data/lib/fog/openstack/requests/volume_v1/get_volume_details.rb +35 -0
  97. data/lib/fog/openstack/requests/volume_v1/get_volume_type_details.rb +2 -0
  98. data/lib/fog/openstack/requests/volume_v1/list_snapshots.rb +2 -0
  99. data/lib/fog/openstack/requests/volume_v1/list_snapshots_detailed.rb +2 -0
  100. data/lib/fog/openstack/requests/volume_v1/list_transfers.rb +2 -0
  101. data/lib/fog/openstack/requests/volume_v1/list_transfers_detailed.rb +2 -0
  102. data/lib/fog/openstack/requests/volume_v1/list_volume_types.rb +2 -0
  103. data/lib/fog/openstack/requests/volume_v1/list_volumes.rb +46 -0
  104. data/lib/fog/openstack/requests/volume_v1/list_volumes_detailed.rb +46 -0
  105. data/lib/fog/openstack/requests/volume_v1/list_zones.rb +2 -0
  106. data/lib/fog/openstack/requests/volume_v1/real.rb +11 -0
  107. data/lib/fog/openstack/requests/volume_v1/real_mock.rb +14 -0
  108. data/lib/fog/openstack/requests/volume_v1/set_tenant.rb +2 -0
  109. data/lib/fog/openstack/requests/volume_v1/update_quota.rb +2 -0
  110. data/lib/fog/openstack/requests/volume_v2/accept_transfer.rb +2 -0
  111. data/lib/fog/openstack/requests/volume_v2/create_transfer.rb +2 -0
  112. data/lib/fog/openstack/requests/volume_v2/create_volume.rb +49 -0
  113. data/lib/fog/openstack/requests/volume_v2/create_volume_snapshot.rb +43 -0
  114. data/lib/fog/openstack/requests/volume_v2/create_volume_type.rb +2 -0
  115. data/lib/fog/openstack/requests/volume_v2/delete_snapshot.rb +2 -0
  116. data/lib/fog/openstack/requests/volume_v2/delete_transfer.rb +2 -0
  117. data/lib/fog/openstack/requests/volume_v2/delete_volume.rb +2 -0
  118. data/lib/fog/openstack/requests/volume_v2/delete_volume_type.rb +2 -0
  119. data/lib/fog/openstack/requests/volume_v2/extend_volume.rb +2 -0
  120. data/lib/fog/openstack/requests/volume_v2/get_quota.rb +2 -0
  121. data/lib/fog/openstack/requests/volume_v2/get_quota_defaults.rb +2 -0
  122. data/lib/fog/openstack/requests/volume_v2/get_quota_usage.rb +2 -0
  123. data/lib/fog/openstack/requests/volume_v2/get_snapshot_details.rb +32 -0
  124. data/lib/fog/openstack/requests/volume_v2/get_transfer_details.rb +2 -0
  125. data/lib/fog/openstack/requests/volume_v2/get_volume_details.rb +35 -0
  126. data/lib/fog/openstack/requests/volume_v2/get_volume_type_details.rb +2 -0
  127. data/lib/fog/openstack/requests/volume_v2/list_snapshots.rb +2 -0
  128. data/lib/fog/openstack/requests/volume_v2/list_snapshots_detailed.rb +2 -0
  129. data/lib/fog/openstack/requests/volume_v2/list_transfers.rb +2 -0
  130. data/lib/fog/openstack/requests/volume_v2/list_transfers_detailed.rb +2 -0
  131. data/lib/fog/openstack/requests/volume_v2/list_volume_types.rb +2 -0
  132. data/lib/fog/openstack/requests/volume_v2/list_volumes.rb +46 -0
  133. data/lib/fog/openstack/requests/volume_v2/list_volumes_detailed.rb +46 -0
  134. data/lib/fog/openstack/requests/volume_v2/list_zones.rb +2 -0
  135. data/lib/fog/openstack/requests/volume_v2/real.rb +11 -0
  136. data/lib/fog/openstack/requests/volume_v2/real_mock.rb +14 -0
  137. data/lib/fog/openstack/requests/volume_v2/set_tenant.rb +2 -0
  138. data/lib/fog/openstack/requests/volume_v2/update_quota.rb +2 -0
  139. data/lib/fog/openstack/requests/volume_v2/update_volume_type.rb +2 -0
  140. data/lib/fog/openstack/storage.rb +2 -1
  141. data/lib/fog/openstack/volume.rb +21 -176
  142. data/lib/fog/openstack/volume_v1.rb +163 -0
  143. data/lib/fog/openstack/volume_v2.rb +164 -0
  144. data/lib/fog/rackspace/compute_v2.rb +1 -0
  145. data/lib/fog/rackspace/docs/compute_v2.md +1 -1
  146. data/lib/fog/rackspace/models/compute_v2/server.rb +14 -0
  147. data/lib/fog/rackspace/requests/compute_v2/get_vnc_console.rb +45 -0
  148. data/lib/fog/rackspace/requests/storage/put_container.rb +10 -6
  149. data/lib/fog/vcloud_director/compute.rb +18 -2
  150. data/lib/fog/vcloud_director/models/compute/disks.rb +6 -0
  151. data/lib/fog/vcloud_director/models/compute/networks.rb +7 -2
  152. data/lib/fog/vcloud_director/models/compute/vdc.rb +5 -0
  153. data/lib/fog/vcloud_director/models/compute/vm.rb +15 -1
  154. data/lib/fog/vcloud_director/parsers/compute/vm.rb +4 -0
  155. data/lib/fog/vcloud_director/parsers/compute/vms.rb +4 -0
  156. data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +30 -0
  157. data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +24 -3
  158. data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +23 -0
  159. data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +11 -0
  160. data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +1 -0
  161. data/lib/fog/vcloud_director/requests/compute/get_vm.rb +46 -0
  162. data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +20 -0
  163. data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +25 -0
  164. data/lib/fog/vcloud_director/requests/compute/get_vms.rb +13 -0
  165. data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +70 -0
  166. data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +35 -0
  167. data/lib/fog/vcloud_director/requests/compute/post_reconfigure_vm.rb +118 -0
  168. data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +34 -0
  169. data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +2 -1
  170. data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +31 -0
  171. data/lib/fog/version.rb +1 -1
  172. data/lib/tasks/changelog_task.rb +1 -0
  173. data/spec/fog/openstack/shared_context.rb +11 -2
  174. data/spec/fog/openstack/volume/common_setup.yml +74 -50
  175. data/spec/fog/openstack/volume/volume_crud.yml +286 -236
  176. data/spec/fog/openstack/volume/volume_extend.yml +270 -363
  177. data/spec/fog/openstack/volume/volume_transfer_and_accept.yml +418 -424
  178. data/spec/fog/openstack/volume/volume_transfer_and_delete.yml +292 -321
  179. data/spec/fog/openstack/volume/volume_type_read.yml +30 -36
  180. data/spec/fog/openstack/volume_spec.rb +251 -224
  181. data/spec/fog/openstack/volume_v1/common_setup.yml +100 -0
  182. data/spec/fog/openstack/volume_v1/volume_crud.yml +535 -0
  183. data/spec/fog/openstack/volume_v1/volume_extend.yml +596 -0
  184. data/spec/fog/openstack/volume_v1/volume_transfer_and_accept.yml +1010 -0
  185. data/spec/fog/openstack/volume_v1/volume_transfer_and_delete.yml +645 -0
  186. data/spec/fog/openstack/volume_v1/volume_type_read.yml +114 -0
  187. data/spec/fog/openstack/volume_v2/common_setup.yml +100 -0
  188. data/spec/fog/openstack/volume_v2/volume_crud.yml +611 -0
  189. data/spec/fog/openstack/volume_v2/volume_extend.yml +669 -0
  190. data/spec/fog/openstack/volume_v2/volume_transfer_and_accept.yml +1072 -0
  191. data/spec/fog/openstack/volume_v2/volume_transfer_and_delete.yml +666 -0
  192. data/spec/fog/openstack/volume_v2/volume_type_read.yml +114 -0
  193. data/tests/helpers/mock_helper.rb +0 -4
  194. data/tests/openstack/authenticate_tests.rb +4 -0
  195. data/tests/openstack/volume_tests.rb +4 -0
  196. data/tests/rackspace/requests/compute_v2/server_tests.rb +4 -0
  197. metadata +135 -152
  198. data/lib/fog/bin/vsphere.rb +0 -28
  199. data/lib/fog/vsphere.rb +0 -1
  200. data/lib/fog/vsphere/compute.rb +0 -474
  201. data/lib/fog/vsphere/core.rb +0 -39
  202. data/lib/fog/vsphere/models/compute/cluster.rb +0 -28
  203. data/lib/fog/vsphere/models/compute/clusters.rb +0 -23
  204. data/lib/fog/vsphere/models/compute/customfield.rb +0 -16
  205. data/lib/fog/vsphere/models/compute/customfields.rb +0 -24
  206. data/lib/fog/vsphere/models/compute/customvalue.rb +0 -14
  207. data/lib/fog/vsphere/models/compute/customvalues.rb +0 -34
  208. data/lib/fog/vsphere/models/compute/datacenter.rb +0 -44
  209. data/lib/fog/vsphere/models/compute/datacenters.rb +0 -20
  210. data/lib/fog/vsphere/models/compute/datastore.rb +0 -21
  211. data/lib/fog/vsphere/models/compute/datastores.rb +0 -22
  212. data/lib/fog/vsphere/models/compute/folder.rb +0 -24
  213. data/lib/fog/vsphere/models/compute/folders.rb +0 -24
  214. data/lib/fog/vsphere/models/compute/interface.rb +0 -91
  215. data/lib/fog/vsphere/models/compute/interfaces.rb +0 -67
  216. data/lib/fog/vsphere/models/compute/interfacetype.rb +0 -22
  217. data/lib/fog/vsphere/models/compute/interfacetypes.rb +0 -35
  218. data/lib/fog/vsphere/models/compute/network.rb +0 -18
  219. data/lib/fog/vsphere/models/compute/networks.rb +0 -23
  220. data/lib/fog/vsphere/models/compute/process.rb +0 -18
  221. data/lib/fog/vsphere/models/compute/resource_pool.rb +0 -19
  222. data/lib/fog/vsphere/models/compute/resource_pools.rb +0 -23
  223. data/lib/fog/vsphere/models/compute/scsicontroller.rb +0 -16
  224. data/lib/fog/vsphere/models/compute/server.rb +0 -325
  225. data/lib/fog/vsphere/models/compute/servers.rb +0 -37
  226. data/lib/fog/vsphere/models/compute/servertype.rb +0 -36
  227. data/lib/fog/vsphere/models/compute/servertypes.rb +0 -24
  228. data/lib/fog/vsphere/models/compute/snapshot.rb +0 -35
  229. data/lib/fog/vsphere/models/compute/snapshots.rb +0 -27
  230. data/lib/fog/vsphere/models/compute/template.rb +0 -11
  231. data/lib/fog/vsphere/models/compute/templates.rb +0 -20
  232. data/lib/fog/vsphere/models/compute/volume.rb +0 -99
  233. data/lib/fog/vsphere/models/compute/volumes.rb +0 -54
  234. data/lib/fog/vsphere/requests/compute/cloudinit_to_customspec.rb +0 -65
  235. data/lib/fog/vsphere/requests/compute/create_folder.rb +0 -22
  236. data/lib/fog/vsphere/requests/compute/create_vm.rb +0 -227
  237. data/lib/fog/vsphere/requests/compute/current_time.rb +0 -18
  238. data/lib/fog/vsphere/requests/compute/get_cluster.rb +0 -25
  239. data/lib/fog/vsphere/requests/compute/get_compute_resource.rb +0 -41
  240. data/lib/fog/vsphere/requests/compute/get_datacenter.rb +0 -31
  241. data/lib/fog/vsphere/requests/compute/get_datastore.rb +0 -30
  242. data/lib/fog/vsphere/requests/compute/get_folder.rb +0 -74
  243. data/lib/fog/vsphere/requests/compute/get_interface_type.rb +0 -15
  244. data/lib/fog/vsphere/requests/compute/get_network.rb +0 -59
  245. data/lib/fog/vsphere/requests/compute/get_resource_pool.rb +0 -26
  246. data/lib/fog/vsphere/requests/compute/get_server_type.rb +0 -32
  247. data/lib/fog/vsphere/requests/compute/get_template.rb +0 -16
  248. data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +0 -57
  249. data/lib/fog/vsphere/requests/compute/get_vm_first_scsi_controller.rb +0 -26
  250. data/lib/fog/vsphere/requests/compute/list_child_snapshots.rb +0 -71
  251. data/lib/fog/vsphere/requests/compute/list_clusters.rb +0 -72
  252. data/lib/fog/vsphere/requests/compute/list_compute_resources.rb +0 -92
  253. data/lib/fog/vsphere/requests/compute/list_customfields.rb +0 -21
  254. data/lib/fog/vsphere/requests/compute/list_datacenters.rb +0 -53
  255. data/lib/fog/vsphere/requests/compute/list_datastores.rb +0 -40
  256. data/lib/fog/vsphere/requests/compute/list_folders.rb +0 -44
  257. data/lib/fog/vsphere/requests/compute/list_interface_types.rb +0 -25
  258. data/lib/fog/vsphere/requests/compute/list_networks.rb +0 -38
  259. data/lib/fog/vsphere/requests/compute/list_processes.rb +0 -41
  260. data/lib/fog/vsphere/requests/compute/list_resource_pools.rb +0 -38
  261. data/lib/fog/vsphere/requests/compute/list_server_types.rb +0 -54
  262. data/lib/fog/vsphere/requests/compute/list_templates.rb +0 -48
  263. data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +0 -80
  264. data/lib/fog/vsphere/requests/compute/list_vm_customvalues.rb +0 -20
  265. data/lib/fog/vsphere/requests/compute/list_vm_interfaces.rb +0 -63
  266. data/lib/fog/vsphere/requests/compute/list_vm_snapshots.rb +0 -66
  267. data/lib/fog/vsphere/requests/compute/list_vm_volumes.rb +0 -52
  268. data/lib/fog/vsphere/requests/compute/modify_vm_interface.rb +0 -59
  269. data/lib/fog/vsphere/requests/compute/modify_vm_volume.rb +0 -25
  270. data/lib/fog/vsphere/requests/compute/revert_to_snapshot.rb +0 -30
  271. data/lib/fog/vsphere/requests/compute/set_vm_customvalue.rb +0 -17
  272. data/lib/fog/vsphere/requests/compute/vm_clone.rb +0 -727
  273. data/lib/fog/vsphere/requests/compute/vm_config_vnc.rb +0 -45
  274. data/lib/fog/vsphere/requests/compute/vm_destroy.rb +0 -23
  275. data/lib/fog/vsphere/requests/compute/vm_execute.rb +0 -47
  276. data/lib/fog/vsphere/requests/compute/vm_migrate.rb +0 -33
  277. data/lib/fog/vsphere/requests/compute/vm_power_off.rb +0 -39
  278. data/lib/fog/vsphere/requests/compute/vm_power_on.rb +0 -26
  279. data/lib/fog/vsphere/requests/compute/vm_reboot.rb +0 -31
  280. data/lib/fog/vsphere/requests/compute/vm_reconfig_cpus.rb +0 -23
  281. data/lib/fog/vsphere/requests/compute/vm_reconfig_hardware.rb +0 -24
  282. data/lib/fog/vsphere/requests/compute/vm_reconfig_memory.rb +0 -23
  283. data/lib/fog/vsphere/requests/compute/vm_take_snapshot.rb +0 -37
  284. data/tests/vsphere/compute_tests.rb +0 -53
  285. data/tests/vsphere/models/compute/server_tests.rb +0 -70
  286. data/tests/vsphere/models/compute/servers_tests.rb +0 -15
  287. data/tests/vsphere/requests/compute/current_time_tests.rb +0 -12
  288. data/tests/vsphere/requests/compute/get_network_tests.rb +0 -48
  289. data/tests/vsphere/requests/compute/list_child_snapshots_tests.rb +0 -10
  290. data/tests/vsphere/requests/compute/list_clusters_tests.rb +0 -11
  291. data/tests/vsphere/requests/compute/list_virtual_machines_tests.rb +0 -38
  292. data/tests/vsphere/requests/compute/list_vm_snapshots_tests.rb +0 -10
  293. data/tests/vsphere/requests/compute/revert_to_snapshot_tests.rb +0 -15
  294. data/tests/vsphere/requests/compute/set_vm_customvalue_tests.rb +0 -20
  295. data/tests/vsphere/requests/compute/vm_clone_tests.rb +0 -50
  296. data/tests/vsphere/requests/compute/vm_config_vnc_tests.rb +0 -19
  297. data/tests/vsphere/requests/compute/vm_destroy_tests.rb +0 -17
  298. data/tests/vsphere/requests/compute/vm_migrate_tests.rb +0 -16
  299. data/tests/vsphere/requests/compute/vm_power_off_tests.rb +0 -26
  300. data/tests/vsphere/requests/compute/vm_power_on_tests.rb +0 -17
  301. data/tests/vsphere/requests/compute/vm_reboot_tests.rb +0 -26
  302. data/tests/vsphere/requests/compute/vm_reconfig_cpus_tests.rb +0 -19
  303. data/tests/vsphere/requests/compute/vm_reconfig_hardware_tests.rb +0 -19
  304. data/tests/vsphere/requests/compute/vm_reconfig_memory_tests.rb +0 -19
  305. data/tests/vsphere/requests/compute/vm_take_snapshot_tests.rb +0 -19
@@ -297,7 +297,7 @@ This returns a collection of `Fog::Compute::OpenStack::Flavor` models:
297
297
 
298
298
  To retrieve individual flavor:
299
299
 
300
- service.flavor.get 1
300
+ service.flavors.get 1
301
301
 
302
302
  This returns a `Fog::Compute::OpenStack::Flavor` instance:
303
303
 
@@ -22,43 +22,6 @@ module Fog
22
22
  @openstack_auth_uri && @openstack_auth_uri.path =~ /\/v3/
23
23
  end
24
24
 
25
- module Common
26
- attr_reader :unscoped_token
27
-
28
- include Fog::OpenStack::Core
29
-
30
- def request(params)
31
- retried = false
32
- begin
33
- response = @connection.request(params.merge({
34
- :headers => params.fetch(:headers,{}).merge({
35
- 'Content-Type' => 'application/json',
36
- 'Accept' => 'application/json',
37
- 'X-Auth-Token' => @auth_token
38
- }),
39
- :path => "#{@path}/#{params[:path]}"
40
- }))
41
- rescue Excon::Errors::Unauthorized => error
42
- raise if retried
43
- retried = true
44
-
45
- @openstack_must_reauthenticate = true
46
- authenticate
47
- retry
48
- rescue Excon::Errors::HTTPStatusError => error
49
- raise case error
50
- when Excon::Errors::NotFound
51
- Fog::Identity::OpenStack::NotFound.slurp(error)
52
- else
53
- error
54
- end
55
- end
56
- unless response.body.empty?
57
- response.body = Fog::JSON.decode(response.body)
58
- end
59
- response
60
- end
61
- end
62
25
  end
63
26
  end
64
27
  end
@@ -1,4 +1,5 @@
1
1
  require 'fog/openstack/core'
2
+ require 'fog/openstack/common'
2
3
  require 'fog/openstack/identity'
3
4
 
4
5
  module Fog
@@ -15,7 +16,8 @@ module Fog
15
16
  :openstack_endpoint_type,
16
17
  :openstack_project_name, :openstack_project_id,
17
18
  :openstack_project_domain, :openstack_user_domain, :openstack_domain_name,
18
- :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id
19
+ :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id,
20
+ :openstack_identity_prefix
19
21
 
20
22
  model_path 'fog/openstack/models/identity_v2'
21
23
  model :tenant
@@ -170,13 +172,17 @@ module Fog
170
172
  end
171
173
 
172
174
  class Real
173
- include Fog::Identity::OpenStack::Common
175
+ def self.not_found_class
176
+ Fog::Identity::OpenStack::NotFound
177
+ end
178
+ include Fog::OpenStack::Common
174
179
 
175
180
  def initialize(options={})
176
181
  initialize_identity options
177
182
 
178
183
  @openstack_service_type = options[:openstack_service_type] || ['identity']
179
184
  @openstack_service_name = options[:openstack_service_name]
185
+ @identity_prefix = options[:openstack_identity_prefix] ? "/#{options[:openstack_identity_prefix]}" : nil
180
186
 
181
187
  @connection_options = options[:connection_options] || {}
182
188
 
@@ -185,7 +191,7 @@ module Fog
185
191
  authenticate
186
192
 
187
193
  @persistent = options[:persistent] || false
188
- @connection = Fog::Core::Connection.new("#{@scheme}://#{@host}:#{@port}", @persistent, @connection_options)
194
+ @connection = Fog::Core::Connection.new("#{@scheme}://#{@host}:#{@port}#{@identity_prefix}", @persistent, @connection_options)
189
195
  end
190
196
  end
191
197
  end
@@ -1,4 +1,5 @@
1
1
  require 'fog/openstack/core'
2
+ require 'fog/openstack/common'
2
3
  require 'fog/openstack/identity'
3
4
 
4
5
  module Fog
@@ -14,7 +15,7 @@ module Fog
14
15
  :openstack_user_domain_id, :openstack_project_domain_id,
15
16
  :openstack_api_key, :openstack_current_user_id, :openstack_userid, :openstack_username,
16
17
  :current_user, :current_user_id, :current_tenant,
17
- :provider
18
+ :provider, :openstack_identity_prefix
18
19
 
19
20
  model_path 'fog/openstack/models/identity_v3'
20
21
  model :domain
@@ -148,13 +149,17 @@ module Fog
148
149
  end
149
150
 
150
151
  class Real
151
- include Fog::Identity::OpenStack::Common
152
+ def self.not_found_class
153
+ Fog::Identity::OpenStack::NotFound
154
+ end
155
+ include Fog::OpenStack::Common
152
156
 
153
157
  def initialize(options={})
154
158
  initialize_identity options
155
159
 
156
160
  @openstack_service_type = options[:openstack_service_type] || ['identity_v3','identityv3','identity']
157
161
  @openstack_service_name = options[:openstack_service_name]
162
+ @identity_prefix = options[:openstack_identity_prefix] ? "/#{options[:openstack_identity_prefix]}" : nil
158
163
 
159
164
  @connection_options = options[:connection_options] || {}
160
165
 
@@ -164,7 +169,7 @@ module Fog
164
169
  authenticate
165
170
 
166
171
  @persistent = options[:persistent] || false
167
- @connection = Fog::Core::Connection.new("#{@scheme}://#{@host}:#{@port}", @persistent, @connection_options)
172
+ @connection = Fog::Core::Connection.new("#{@scheme}://#{@host}:#{@port}#{@identity_prefix}", @persistent, @connection_options)
168
173
  end
169
174
  end
170
175
  end
@@ -4,7 +4,7 @@ module Fog
4
4
  module Image
5
5
  class OpenStack < Fog::Service
6
6
 
7
- # Fog::Image::OpenStack.new() will return a Fog::Image::OpenStack::V2 or a Fog::Image::OpenStack::V3,
7
+ # Fog::Image::OpenStack.new() will return a Fog::Image::OpenStack::V2 or a Fog::Image::OpenStack::V1,
8
8
  # choosing the latest available
9
9
  def self.new(args = {})
10
10
  @openstack_auth_uri = URI.parse(args[:openstack_auth_url]) if args[:openstack_auth_url]
@@ -17,46 +17,6 @@ module Fog
17
17
  service
18
18
  end
19
19
 
20
- module Common
21
- attr_reader :unscoped_token
22
-
23
- include Fog::OpenStack::Core
24
-
25
- def request(params)
26
- retried = false
27
- begin
28
- std_headers = {
29
- 'Content-Type' => 'application/json',
30
- 'Accept' => 'application/json',
31
- 'X-Auth-Token' => @auth_token
32
- }
33
- param_headers = params.fetch(:headers,{})
34
-
35
- response = @connection.request(params.merge({
36
- :headers => std_headers.merge(param_headers),
37
- :path => "#{@path}/#{params[:path]}"
38
- }))
39
- rescue Excon::Errors::Unauthorized => error
40
- raise if retried
41
- retried = true
42
-
43
- @openstack_must_reauthenticate = true
44
- authenticate
45
- retry
46
- rescue Excon::Errors::HTTPStatusError => error
47
- raise case error
48
- when Excon::Errors::NotFound
49
- Fog::Image::OpenStack::NotFound.slurp(error)
50
- else
51
- error
52
- end
53
- end
54
- unless response.body.empty?
55
- response.body = Fog::JSON.decode(response.body) unless params[:raw_body]
56
- end
57
- response
58
- end
59
- end
60
20
  end
61
21
  end
62
22
  end
@@ -1,3 +1,4 @@
1
+ require 'fog/openstack/common'
1
2
  require 'fog/openstack/core'
2
3
  require 'fog/openstack/image'
3
4
 
@@ -17,7 +18,8 @@ module Fog
17
18
  :openstack_endpoint_type,
18
19
  :openstack_project_name, :openstack_project_id,
19
20
  :openstack_project_domain, :openstack_user_domain, :openstack_domain_name,
20
- :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id
21
+ :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id,
22
+ :openstack_identity_prefix
21
23
 
22
24
  model_path 'fog/openstack/models/image_v1'
23
25
 
@@ -98,8 +100,12 @@ module Fog
98
100
 
99
101
  class Real
100
102
  include Fog::OpenStack::Core
101
- include Fog::Image::OpenStack::Common
102
-
103
+
104
+ def self.not_found_class
105
+ Fog::Image::OpenStack::NotFound
106
+ end
107
+ include Fog::OpenStack::Common
108
+
103
109
  def initialize(options={})
104
110
  initialize_identity options
105
111
 
@@ -1,3 +1,4 @@
1
+ require 'fog/openstack/common'
1
2
  require 'fog/openstack/core'
2
3
  require 'fog/openstack/image'
3
4
 
@@ -17,7 +18,8 @@ module Fog
17
18
  :openstack_endpoint_type,
18
19
  :openstack_project_name, :openstack_project_id,
19
20
  :openstack_project_domain, :openstack_user_domain, :openstack_domain_name,
20
- :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id
21
+ :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id,
22
+ :openstack_identity_prefix
21
23
 
22
24
  model_path 'fog/openstack/models/image_v2'
23
25
 
@@ -104,7 +106,10 @@ module Fog
104
106
 
105
107
  class Real
106
108
  include Fog::OpenStack::Core
107
- include Fog::Image::OpenStack::Common
109
+ def self.not_found_class
110
+ Fog::Image::OpenStack::NotFound
111
+ end
112
+ include Fog::OpenStack::Common
108
113
 
109
114
  def initialize(options={})
110
115
  initialize_identity options
@@ -12,7 +12,8 @@ module Fog
12
12
  :openstack_endpoint_type,
13
13
  :openstack_project_name, :openstack_project_id,
14
14
  :openstack_project_domain, :openstack_user_domain, :openstack_domain_name,
15
- :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id
15
+ :openstack_project_domain_id, :openstack_user_domain_id, :openstack_domain_id,
16
+ :openstack_identity_prefix
16
17
 
17
18
  model_path 'fog/openstack/models/metering'
18
19
 
@@ -292,6 +292,11 @@ module Fog
292
292
  service.live_migrate_server(id, host, block_migration, disk_over_commit)
293
293
  end
294
294
 
295
+ def evacuate(host, on_shared_storage, admin_password = nil)
296
+ requires :id
297
+ service.evacuate_server(id, host, on_shared_storage, admin_password)
298
+ end
299
+
295
300
  def associate_address(floating_ip)
296
301
  requires :id
297
302
  service.associate_address id, floating_ip
@@ -22,7 +22,7 @@ module Fog
22
22
 
23
23
  def save
24
24
  raise Fog::Errors::Error.new('Resaving an existing object may create a duplicate') if persisted?
25
- requires :name, :tenant_id, :password
25
+ requires :name
26
26
  enabled = true if enabled.nil?
27
27
  data = service.create_user(name, password, email, tenant_id, enabled)
28
28
  merge_attributes(data.body['user'])
@@ -56,7 +56,11 @@ module Fog
56
56
  end
57
57
 
58
58
  def roles(tenant_id = self.tenant_id)
59
- service.list_roles_for_user_on_tenant(tenant_id, self.id).body['roles']
59
+ if tenant_id
60
+ service.list_roles_for_user_on_tenant(tenant_id, self.id).body['roles']
61
+ else
62
+ []
63
+ end
60
64
  end
61
65
  end # class User
62
66
  end # class V2
@@ -4,10 +4,7 @@ module Fog
4
4
  module Volume
5
5
  class OpenStack
6
6
  class AvailabilityZone < Fog::OpenStack::Model
7
- identity :zoneName
8
-
9
- attribute :zoneState
10
7
  end
11
8
  end
12
9
  end
13
- end
10
+ end
@@ -1,12 +1,9 @@
1
1
  require 'fog/openstack/models/collection'
2
- require 'fog/openstack/models/volume/availability_zone'
3
2
 
4
3
  module Fog
5
4
  module Volume
6
5
  class OpenStack
7
- class AvailabilityZones < Fog::OpenStack::Collection
8
- model Fog::Volume::OpenStack::AvailabilityZone
9
-
6
+ module AvailabilityZones
10
7
  def all(options = {})
11
8
  data = service.list_zones(options)
12
9
  load_response(data, 'availabilityZoneInfo')
@@ -4,13 +4,6 @@ module Fog
4
4
  module Volume
5
5
  class OpenStack
6
6
  class Transfer < Fog::OpenStack::Model
7
- identity :id
8
-
9
- attribute :auth_key, :aliases => 'authKey'
10
- attribute :created_at, :aliases => 'createdAt'
11
- attribute :name
12
- attribute :volume_id, :aliases => 'volumeId'
13
-
14
7
  def save
15
8
  requires :name, :volume_id
16
9
  data = service.create_transfer(volume_id, :name => name)
@@ -29,8 +22,7 @@ module Fog
29
22
  prepare_service_value(attributes)
30
23
  super
31
24
  end
32
-
33
25
  end
34
26
  end
35
27
  end
36
- end
28
+ end
@@ -1,11 +1,9 @@
1
1
  require 'fog/openstack/models/collection'
2
- require 'fog/openstack/models/volume/transfer'
3
2
 
4
3
  module Fog
5
4
  module Volume
6
5
  class OpenStack
7
- class Transfers < Fog::OpenStack::Collection
8
- model Fog::Volume::OpenStack::Transfer
6
+ module Transfers
9
7
 
10
8
  def all(options = {})
11
9
  load_response(service.list_transfers_detailed(options), 'transfers')
@@ -31,7 +29,6 @@ module Fog
31
29
  new(transfer)
32
30
  end
33
31
  end
34
-
35
32
  end
36
33
  end
37
34
  end
@@ -4,28 +4,16 @@ module Fog
4
4
  module Volume
5
5
  class OpenStack
6
6
  class Volume < Fog::OpenStack::Model
7
- identity :id
8
-
9
- attribute :display_name, :aliases => 'displayName'
10
- attribute :display_description, :aliases => 'displayDescription'
11
7
  attribute :metadata
12
8
  attribute :status
13
9
  attribute :size
14
- attribute :volume_type, :aliases => ['volumeType', 'type']
15
- attribute :snapshot_id, :aliases => 'snapshotId'
16
- attribute :imageRef, :aliases => 'image_id'
17
- attribute :availability_zone, :aliases => 'availabilityZone'
18
- attribute :created_at, :aliases => 'createdAt'
10
+ attribute :volume_type, :aliases => ['volumeType', 'type']
11
+ attribute :snapshot_id, :aliases => 'snapshotId'
12
+ attribute :imageRef, :aliases => 'image_id'
13
+ attribute :availability_zone, :aliases => 'availabilityZone'
14
+ attribute :created_at, :aliases => 'createdAt'
19
15
  attribute :attachments
20
16
  attribute :source_volid
21
- attribute :tenant_id, :aliases => 'os-vol-tenant-attr:tenant_id'
22
-
23
- def save
24
- requires :display_name, :size
25
- data = service.create_volume(display_name, display_description, size, attributes)
26
- merge_attributes(data.body['volume'])
27
- true
28
- end
29
17
 
30
18
  def destroy
31
19
  requires :id
@@ -45,4 +33,4 @@ module Fog
45
33
  end
46
34
  end
47
35
  end
48
- end
36
+ end
@@ -4,10 +4,7 @@ module Fog
4
4
  module Volume
5
5
  class OpenStack
6
6
  class VolumeType < Fog::OpenStack::Model
7
- identity :id
8
7
 
9
- attribute :name
10
- attribute :volume_backend_name
11
8
  attribute :extra_specs
12
9
 
13
10
  def create
@@ -1,12 +1,9 @@
1
1
  require 'fog/openstack/models/collection'
2
- require 'fog/openstack/models/volume/volume_type'
3
2
 
4
3
  module Fog
5
4
  module Volume
6
5
  class OpenStack
7
- class VolumeTypes < Fog::OpenStack::Collection
8
- model Fog::Volume::OpenStack::VolumeType
9
-
6
+ module VolumeTypes
10
7
  def all(options = {})
11
8
  response = service.list_volume_types(options)
12
9
  load_response(response, 'volume_types')
@@ -1,12 +1,9 @@
1
1
  require 'fog/openstack/models/collection'
2
- require 'fog/openstack/models/volume/volume'
3
2
 
4
3
  module Fog
5
4
  module Volume
6
5
  class OpenStack
7
- class Volumes < Fog::OpenStack::Collection
8
- model Fog::Volume::OpenStack::Volume
9
-
6
+ module Volumes
10
7
  def all(options = {})
11
8
  # the parameter has been "detailed = true" before. Make sure we are
12
9
  # backwards compatible