fog 1.31.0 → 1.37.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (890) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +12 -24
  3. data/CHANGELOG.md +354 -0
  4. data/CONTRIBUTING.md +1 -1
  5. data/Gemfile +1 -0
  6. data/README.md +4 -20
  7. data/Rakefile +7 -7
  8. data/fog.gemspec +14 -9
  9. data/lib/fog/bin.rb +1 -0
  10. data/lib/fog/cloudstack/models/compute/network.rb +1 -0
  11. data/lib/fog/digitalocean/compute_v2.rb +109 -0
  12. data/lib/fog/digitalocean/examples/getting_started.md +24 -48
  13. data/lib/fog/digitalocean/models/compute/server.rb +0 -1
  14. data/lib/fog/digitalocean/models/compute_v2/flavor.rb +17 -0
  15. data/lib/fog/digitalocean/models/compute_v2/flavors.rb +21 -0
  16. data/lib/fog/digitalocean/models/compute_v2/image.rb +25 -0
  17. data/lib/fog/digitalocean/models/compute_v2/images.rb +36 -0
  18. data/lib/fog/digitalocean/models/compute_v2/region.rb +13 -0
  19. data/lib/fog/digitalocean/models/compute_v2/regions.rb +21 -0
  20. data/lib/fog/digitalocean/models/compute_v2/server.rb +170 -0
  21. data/lib/fog/digitalocean/models/compute_v2/servers.rb +39 -0
  22. data/lib/fog/digitalocean/models/compute_v2/ssh_key.rb +31 -0
  23. data/lib/fog/digitalocean/models/compute_v2/ssh_keys.rb +35 -0
  24. data/lib/fog/digitalocean/requests/compute_v2/change_kernel.rb +44 -0
  25. data/lib/fog/digitalocean/requests/compute_v2/convert_to_snapshot.rb +44 -0
  26. data/lib/fog/digitalocean/requests/compute_v2/create_server.rb +93 -0
  27. data/lib/fog/digitalocean/requests/compute_v2/create_ssh_key.rb +49 -0
  28. data/lib/fog/digitalocean/requests/compute_v2/delete_server.rb +28 -0
  29. data/lib/fog/digitalocean/requests/compute_v2/delete_ssh_key.rb +32 -0
  30. data/lib/fog/digitalocean/requests/compute_v2/disable_backups.rb +45 -0
  31. data/lib/fog/digitalocean/requests/compute_v2/enable_ipv6.rb +44 -0
  32. data/lib/fog/digitalocean/requests/compute_v2/enable_private_networking.rb +44 -0
  33. data/lib/fog/digitalocean/requests/compute_v2/get_droplet_action.rb +36 -0
  34. data/lib/fog/digitalocean/requests/compute_v2/get_image_details.rb +42 -0
  35. data/lib/fog/digitalocean/requests/compute_v2/get_server_details.rb +84 -0
  36. data/lib/fog/digitalocean/requests/compute_v2/get_ssh_key.rb +34 -0
  37. data/lib/fog/digitalocean/requests/compute_v2/list_droplet_actions.rb +38 -0
  38. data/lib/fog/digitalocean/requests/compute_v2/list_flavors.rb +131 -0
  39. data/lib/fog/digitalocean/requests/compute_v2/list_images.rb +50 -0
  40. data/lib/fog/digitalocean/requests/compute_v2/list_regions.rb +94 -0
  41. data/lib/fog/digitalocean/requests/compute_v2/list_servers.rb +28 -0
  42. data/lib/fog/digitalocean/requests/compute_v2/list_ssh_keys.rb +31 -0
  43. data/lib/fog/digitalocean/requests/compute_v2/password_reset.rb +44 -0
  44. data/lib/fog/digitalocean/requests/compute_v2/power_cycle.rb +44 -0
  45. data/lib/fog/digitalocean/requests/compute_v2/power_off.rb +44 -0
  46. data/lib/fog/digitalocean/requests/compute_v2/power_on.rb +44 -0
  47. data/lib/fog/digitalocean/requests/compute_v2/reboot_server.rb +44 -0
  48. data/lib/fog/digitalocean/requests/compute_v2/rebuild.rb +44 -0
  49. data/lib/fog/digitalocean/requests/compute_v2/rename.rb +44 -0
  50. data/lib/fog/digitalocean/requests/compute_v2/resize.rb +48 -0
  51. data/lib/fog/digitalocean/requests/compute_v2/restore.rb +44 -0
  52. data/lib/fog/digitalocean/requests/compute_v2/shutdown.rb +44 -0
  53. data/lib/fog/digitalocean/requests/compute_v2/snapshot.rb +44 -0
  54. data/lib/fog/digitalocean/requests/compute_v2/transfer_image.rb +44 -0
  55. data/lib/fog/digitalocean/requests/compute_v2/update_ssh_key.rb +46 -0
  56. data/lib/fog/digitalocean/requests/compute_v2/upgrade.rb +44 -0
  57. data/lib/fog/digitalocean/service.rb +51 -0
  58. data/lib/fog/glesys/models/compute/server.rb +0 -1
  59. data/lib/fog/joyent/compute.rb +6 -1
  60. data/lib/fog/linode/compute.rb +3 -0
  61. data/lib/fog/linode/models/compute/data_center.rb +1 -0
  62. data/lib/fog/linode/models/compute/flavor.rb +3 -0
  63. data/lib/fog/linode/models/compute/flavors.rb +8 -1
  64. data/lib/fog/linode/models/compute/image.rb +2 -0
  65. data/lib/fog/linode/models/compute/images.rb +2 -1
  66. data/lib/fog/linode/models/compute/kernel.rb +3 -0
  67. data/lib/fog/linode/models/compute/kernels.rb +14 -8
  68. data/lib/fog/linode/models/compute/node_balancer_flavor.rb +13 -0
  69. data/lib/fog/linode/models/compute/node_balancer_flavors.rb +27 -0
  70. data/lib/fog/linode/requests/compute/avail_datacenters.rb +8 -7
  71. data/lib/fog/linode/requests/compute/avail_kernels.rb +17 -18
  72. data/lib/fog/linode/requests/compute/avail_linodeplans.rb +4 -2
  73. data/lib/fog/linode/requests/compute/avail_nodebalancers.rb +42 -0
  74. data/lib/fog/linode/requests/compute/avail_stackscripts.rb +6 -11
  75. data/lib/fog/opennebula/models/compute/flavor.rb +13 -13
  76. data/lib/fog/opennebula/requests/compute/template_pool.rb +14 -11
  77. data/lib/fog/openstack/baremetal.rb +20 -82
  78. data/lib/fog/openstack/common.rb +46 -0
  79. data/lib/fog/openstack/compute.rb +50 -122
  80. data/lib/fog/openstack/core.rb +304 -124
  81. data/lib/fog/openstack/docs/compute.md +1 -1
  82. data/lib/fog/openstack/identity.rb +6 -48
  83. data/lib/fog/openstack/identity_v2.rb +22 -86
  84. data/lib/fog/openstack/identity_v3.rb +21 -92
  85. data/lib/fog/openstack/image.rb +11 -207
  86. data/lib/fog/openstack/image_v1.rb +148 -0
  87. data/lib/fog/openstack/image_v2.rb +142 -0
  88. data/lib/fog/openstack/metering.rb +16 -76
  89. data/lib/fog/openstack/models/baremetal/chassis.rb +3 -14
  90. data/lib/fog/openstack/models/baremetal/chassis_collection.rb +12 -6
  91. data/lib/fog/openstack/models/baremetal/driver.rb +2 -8
  92. data/lib/fog/openstack/models/baremetal/drivers.rb +4 -4
  93. data/lib/fog/openstack/models/baremetal/node.rb +3 -14
  94. data/lib/fog/openstack/models/baremetal/nodes.rb +13 -7
  95. data/lib/fog/openstack/models/baremetal/port.rb +3 -14
  96. data/lib/fog/openstack/models/baremetal/ports.rb +12 -6
  97. data/lib/fog/openstack/models/collection.rb +45 -0
  98. data/lib/fog/openstack/models/compute/address.rb +2 -2
  99. data/lib/fog/openstack/models/compute/addresses.rb +4 -4
  100. data/lib/fog/openstack/models/compute/aggregate.rb +58 -0
  101. data/lib/fog/openstack/models/compute/aggregates.rb +26 -0
  102. data/lib/fog/openstack/models/compute/availability_zone.rb +14 -0
  103. data/lib/fog/openstack/models/compute/availability_zones.rb +22 -0
  104. data/lib/fog/openstack/models/compute/flavor.rb +2 -8
  105. data/lib/fog/openstack/models/compute/flavors.rb +9 -4
  106. data/lib/fog/openstack/models/compute/host.rb +1 -1
  107. data/lib/fog/openstack/models/compute/hosts.rb +5 -5
  108. data/lib/fog/openstack/models/compute/image.rb +2 -8
  109. data/lib/fog/openstack/models/compute/images.rb +4 -4
  110. data/lib/fog/openstack/models/compute/key_pair.rb +2 -2
  111. data/lib/fog/openstack/models/compute/key_pairs.rb +5 -4
  112. data/lib/fog/openstack/models/compute/metadata.rb +3 -2
  113. data/lib/fog/openstack/models/compute/metadatum.rb +2 -2
  114. data/lib/fog/openstack/models/compute/network.rb +2 -2
  115. data/lib/fog/openstack/models/compute/networks.rb +3 -2
  116. data/lib/fog/openstack/models/compute/security_group.rb +2 -2
  117. data/lib/fog/openstack/models/compute/security_group_rule.rb +2 -2
  118. data/lib/fog/openstack/models/compute/security_group_rules.rb +2 -2
  119. data/lib/fog/openstack/models/compute/security_groups.rb +4 -4
  120. data/lib/fog/openstack/models/compute/server.rb +26 -2
  121. data/lib/fog/openstack/models/compute/servers.rb +10 -4
  122. data/lib/fog/openstack/models/compute/service.rb +2 -8
  123. data/lib/fog/openstack/models/compute/services.rb +9 -6
  124. data/lib/fog/openstack/models/compute/snapshot.rb +2 -8
  125. data/lib/fog/openstack/models/compute/snapshots.rb +17 -4
  126. data/lib/fog/openstack/models/compute/tenant.rb +2 -2
  127. data/lib/fog/openstack/models/compute/tenants.rb +3 -4
  128. data/lib/fog/openstack/models/compute/volume.rb +2 -8
  129. data/lib/fog/openstack/models/compute/volumes.rb +17 -4
  130. data/lib/fog/openstack/models/identity_v2/ec2_credential.rb +3 -9
  131. data/lib/fog/openstack/models/identity_v2/ec2_credentials.rb +7 -6
  132. data/lib/fog/openstack/models/identity_v2/role.rb +3 -3
  133. data/lib/fog/openstack/models/identity_v2/roles.rb +5 -5
  134. data/lib/fog/openstack/models/identity_v2/tenant.rb +5 -9
  135. data/lib/fog/openstack/models/identity_v2/tenants.rb +5 -5
  136. data/lib/fog/openstack/models/identity_v2/user.rb +8 -10
  137. data/lib/fog/openstack/models/identity_v2/users.rb +7 -5
  138. data/lib/fog/openstack/models/identity_v3/domain.rb +11 -9
  139. data/lib/fog/openstack/models/identity_v3/domains.rb +24 -10
  140. data/lib/fog/openstack/models/identity_v3/endpoint.rb +5 -9
  141. data/lib/fog/openstack/models/identity_v3/endpoints.rb +5 -6
  142. data/lib/fog/openstack/models/identity_v3/group.rb +5 -9
  143. data/lib/fog/openstack/models/identity_v3/groups.rb +5 -5
  144. data/lib/fog/openstack/models/identity_v3/os_credential.rb +3 -3
  145. data/lib/fog/openstack/models/identity_v3/os_credentials.rb +5 -5
  146. data/lib/fog/openstack/models/identity_v3/policies.rb +5 -5
  147. data/lib/fog/openstack/models/identity_v3/policy.rb +5 -9
  148. data/lib/fog/openstack/models/identity_v3/project.rb +16 -8
  149. data/lib/fog/openstack/models/identity_v3/projects.rb +39 -13
  150. data/lib/fog/openstack/models/identity_v3/role.rb +3 -8
  151. data/lib/fog/openstack/models/identity_v3/role_assignment.rb +3 -3
  152. data/lib/fog/openstack/models/identity_v3/role_assignments.rb +10 -7
  153. data/lib/fog/openstack/models/identity_v3/roles.rb +11 -7
  154. data/lib/fog/openstack/models/identity_v3/service.rb +3 -3
  155. data/lib/fog/openstack/models/identity_v3/services.rb +5 -5
  156. data/lib/fog/openstack/models/identity_v3/token.rb +3 -3
  157. data/lib/fog/openstack/models/identity_v3/tokens.rb +4 -3
  158. data/lib/fog/openstack/models/identity_v3/user.rb +3 -9
  159. data/lib/fog/openstack/models/identity_v3/users.rb +4 -4
  160. data/lib/fog/openstack/models/image_v1/image.rb +78 -0
  161. data/lib/fog/openstack/models/image_v1/images.rb +70 -0
  162. data/lib/fog/openstack/models/image_v2/image.rb +149 -0
  163. data/lib/fog/openstack/models/image_v2/images.rb +67 -0
  164. data/lib/fog/openstack/models/metering/resource.rb +2 -7
  165. data/lib/fog/openstack/models/metering/resources.rb +3 -3
  166. data/lib/fog/openstack/models/model.rb +44 -0
  167. data/lib/fog/openstack/models/network/floating_ip.rb +2 -7
  168. data/lib/fog/openstack/models/network/floating_ips.rb +3 -3
  169. data/lib/fog/openstack/models/network/lb_health_monitor.rb +2 -12
  170. data/lib/fog/openstack/models/network/lb_health_monitors.rb +3 -3
  171. data/lib/fog/openstack/models/network/lb_member.rb +2 -12
  172. data/lib/fog/openstack/models/network/lb_members.rb +3 -3
  173. data/lib/fog/openstack/models/network/lb_pool.rb +2 -12
  174. data/lib/fog/openstack/models/network/lb_pools.rb +3 -3
  175. data/lib/fog/openstack/models/network/lb_vip.rb +2 -12
  176. data/lib/fog/openstack/models/network/lb_vips.rb +3 -3
  177. data/lib/fog/openstack/models/network/network.rb +2 -12
  178. data/lib/fog/openstack/models/network/networks.rb +3 -3
  179. data/lib/fog/openstack/models/network/port.rb +3 -13
  180. data/lib/fog/openstack/models/network/ports.rb +3 -3
  181. data/lib/fog/openstack/models/network/router.rb +2 -13
  182. data/lib/fog/openstack/models/network/routers.rb +3 -3
  183. data/lib/fog/openstack/models/network/security_group.rb +2 -2
  184. data/lib/fog/openstack/models/network/security_group_rule.rb +2 -2
  185. data/lib/fog/openstack/models/network/security_group_rules.rb +3 -3
  186. data/lib/fog/openstack/models/network/security_groups.rb +3 -3
  187. data/lib/fog/openstack/models/network/subnet.rb +3 -14
  188. data/lib/fog/openstack/models/network/subnets.rb +3 -3
  189. data/lib/fog/openstack/models/orchestration/event.rb +2 -2
  190. data/lib/fog/openstack/models/orchestration/events.rb +11 -8
  191. data/lib/fog/openstack/models/orchestration/resource.rb +2 -2
  192. data/lib/fog/openstack/models/orchestration/resource_schemas.rb +2 -2
  193. data/lib/fog/openstack/models/orchestration/resources.rb +5 -4
  194. data/lib/fog/openstack/models/orchestration/stack.rb +10 -9
  195. data/lib/fog/openstack/models/orchestration/stacks.rb +13 -4
  196. data/lib/fog/openstack/models/orchestration/template.rb +2 -2
  197. data/lib/fog/openstack/models/orchestration/templates.rb +2 -1
  198. data/lib/fog/openstack/models/planning/plan.rb +2 -13
  199. data/lib/fog/openstack/models/planning/plans.rb +4 -4
  200. data/lib/fog/openstack/models/planning/role.rb +2 -8
  201. data/lib/fog/openstack/models/planning/roles.rb +4 -4
  202. data/lib/fog/openstack/models/storage/directories.rb +5 -5
  203. data/lib/fog/openstack/models/storage/directory.rb +2 -2
  204. data/lib/fog/openstack/models/storage/file.rb +24 -2
  205. data/lib/fog/openstack/models/storage/files.rb +7 -6
  206. data/lib/fog/openstack/models/volume/availability_zone.rb +10 -0
  207. data/lib/fog/openstack/models/volume/availability_zones.rb +14 -0
  208. data/lib/fog/openstack/models/volume/transfer.rb +28 -0
  209. data/lib/fog/openstack/models/volume/transfers.rb +35 -0
  210. data/lib/fog/openstack/models/volume/volume.rb +14 -24
  211. data/lib/fog/openstack/models/volume/volume_type.rb +25 -9
  212. data/lib/fog/openstack/models/volume/volume_types.rb +3 -7
  213. data/lib/fog/openstack/models/volume/volumes.rb +15 -8
  214. data/lib/fog/openstack/models/volume_v1/availability_zone.rb +15 -0
  215. data/lib/fog/openstack/models/volume_v1/availability_zones.rb +16 -0
  216. data/lib/fog/openstack/models/volume_v1/transfer.rb +18 -0
  217. data/lib/fog/openstack/models/volume_v1/transfers.rb +16 -0
  218. data/lib/fog/openstack/models/volume_v1/volume.rb +26 -0
  219. data/lib/fog/openstack/models/volume_v1/volume_type.rb +16 -0
  220. data/lib/fog/openstack/models/volume_v1/volume_types.rb +16 -0
  221. data/lib/fog/openstack/models/volume_v1/volumes.rb +16 -0
  222. data/lib/fog/openstack/models/volume_v2/availability_zone.rb +15 -0
  223. data/lib/fog/openstack/models/volume_v2/availability_zones.rb +16 -0
  224. data/lib/fog/openstack/models/volume_v2/transfer.rb +19 -0
  225. data/lib/fog/openstack/models/volume_v2/transfers.rb +16 -0
  226. data/lib/fog/openstack/models/volume_v2/volume.rb +27 -0
  227. data/lib/fog/openstack/models/volume_v2/volume_type.rb +16 -0
  228. data/lib/fog/openstack/models/volume_v2/volume_types.rb +16 -0
  229. data/lib/fog/openstack/models/volume_v2/volumes.rb +16 -0
  230. data/lib/fog/openstack/network.rb +24 -102
  231. data/lib/fog/openstack/orchestration.rb +15 -91
  232. data/lib/fog/openstack/planning.rb +20 -81
  233. data/lib/fog/openstack/requests/baremetal/delete_node.rb +1 -1
  234. data/lib/fog/openstack/requests/baremetal/list_chassis.rb +2 -8
  235. data/lib/fog/openstack/requests/baremetal/list_chassis_detailed.rb +3 -9
  236. data/lib/fog/openstack/requests/baremetal/list_drivers.rb +4 -3
  237. data/lib/fog/openstack/requests/baremetal/list_nodes.rb +3 -9
  238. data/lib/fog/openstack/requests/baremetal/list_nodes_detailed.rb +3 -9
  239. data/lib/fog/openstack/requests/baremetal/list_ports.rb +3 -9
  240. data/lib/fog/openstack/requests/baremetal/list_ports_detailed.rb +3 -9
  241. data/lib/fog/openstack/requests/compute/add_aggregate_host.rb +30 -0
  242. data/lib/fog/openstack/requests/compute/create_aggregate.rb +42 -0
  243. data/lib/fog/openstack/requests/compute/delete_aggregate.rb +28 -0
  244. data/lib/fog/openstack/requests/compute/evacuate_server.rb +26 -0
  245. data/lib/fog/openstack/requests/compute/get_aggregate.rb +26 -0
  246. data/lib/fog/openstack/requests/compute/list_aggregates.rb +36 -0
  247. data/lib/fog/openstack/requests/compute/list_all_addresses.rb +4 -3
  248. data/lib/fog/openstack/requests/compute/list_flavors.rb +6 -5
  249. data/lib/fog/openstack/requests/compute/list_hosts.rb +4 -3
  250. data/lib/fog/openstack/requests/compute/list_key_pairs.rb +4 -3
  251. data/lib/fog/openstack/requests/compute/list_security_groups.rb +24 -3
  252. data/lib/fog/openstack/requests/compute/list_servers.rb +8 -5
  253. data/lib/fog/openstack/requests/compute/list_servers_detail.rb +9 -6
  254. data/lib/fog/openstack/requests/compute/list_snapshots.rb +18 -4
  255. data/lib/fog/openstack/requests/compute/list_snapshots_detail.rb +27 -0
  256. data/lib/fog/openstack/requests/compute/list_volumes.rb +18 -4
  257. data/lib/fog/openstack/requests/compute/list_volumes_detail.rb +25 -0
  258. data/lib/fog/openstack/requests/compute/list_zones.rb +6 -5
  259. data/lib/fog/openstack/requests/compute/list_zones_detailed.rb +55 -0
  260. data/lib/fog/openstack/requests/compute/remove_aggregate_host.rb +30 -0
  261. data/lib/fog/openstack/requests/compute/server_actions.rb +14 -3
  262. data/lib/fog/openstack/requests/compute/shelve_offload_server.rb +24 -0
  263. data/lib/fog/openstack/requests/compute/shelve_server.rb +24 -0
  264. data/lib/fog/openstack/requests/compute/unshelve_server.rb +24 -0
  265. data/lib/fog/openstack/requests/compute/update_aggregate.rb +37 -0
  266. data/lib/fog/openstack/requests/compute/update_aggregate_metadata.rb +30 -0
  267. data/lib/fog/openstack/requests/identity_v2/list_ec2_credentials.rb +23 -7
  268. data/lib/fog/openstack/requests/identity_v2/list_roles.rb +5 -4
  269. data/lib/fog/openstack/requests/identity_v2/list_tenants.rb +14 -8
  270. data/lib/fog/openstack/requests/identity_v2/list_users.rb +16 -4
  271. data/lib/fog/openstack/requests/identity_v3/auth_domains.rb +2 -7
  272. data/lib/fog/openstack/requests/identity_v3/auth_projects.rb +6 -11
  273. data/lib/fog/openstack/requests/identity_v3/get_project.rb +2 -2
  274. data/lib/fog/openstack/requests/identity_v3/list_domains.rb +7 -14
  275. data/lib/fog/openstack/requests/identity_v3/list_endpoints.rb +7 -14
  276. data/lib/fog/openstack/requests/identity_v3/list_group_users.rb +5 -13
  277. data/lib/fog/openstack/requests/identity_v3/list_groups.rb +14 -24
  278. data/lib/fog/openstack/requests/identity_v3/list_os_credentials.rb +7 -12
  279. data/lib/fog/openstack/requests/identity_v3/list_policies.rb +7 -11
  280. data/lib/fog/openstack/requests/identity_v3/list_projects.rb +14 -25
  281. data/lib/fog/openstack/requests/identity_v3/list_role_assignments.rb +21 -17
  282. data/lib/fog/openstack/requests/identity_v3/list_roles.rb +7 -25
  283. data/lib/fog/openstack/requests/identity_v3/list_services.rb +7 -13
  284. data/lib/fog/openstack/requests/identity_v3/list_users.rb +7 -15
  285. data/lib/fog/openstack/requests/{image → image_v1}/add_member_to_image.rb +2 -0
  286. data/lib/fog/openstack/requests/image_v1/create_image.rb +78 -0
  287. data/lib/fog/openstack/requests/image_v1/delete_image.rb +25 -0
  288. data/lib/fog/openstack/requests/image_v1/get_image.rb +47 -0
  289. data/lib/fog/openstack/requests/image_v1/get_image_by_id.rb +34 -0
  290. data/lib/fog/openstack/requests/image_v1/get_image_members.rb +31 -0
  291. data/lib/fog/openstack/requests/image_v1/get_shared_images.rb +31 -0
  292. data/lib/fog/openstack/requests/image_v1/list_public_images.rb +35 -0
  293. data/lib/fog/openstack/requests/image_v1/list_public_images_detailed.rb +37 -0
  294. data/lib/fog/openstack/requests/image_v1/remove_member_from_image.rb +25 -0
  295. data/lib/fog/openstack/requests/image_v1/set_tenant.rb +21 -0
  296. data/lib/fog/openstack/requests/image_v1/update_image.rb +66 -0
  297. data/lib/fog/openstack/requests/image_v1/update_image_members.rb +39 -0
  298. data/lib/fog/openstack/requests/image_v2/add_member_to_image.rb +26 -0
  299. data/lib/fog/openstack/requests/image_v2/add_tag_to_image.rb +25 -0
  300. data/lib/fog/openstack/requests/image_v2/create_image.rb +54 -0
  301. data/lib/fog/openstack/requests/image_v2/deactivate_image.rb +25 -0
  302. data/lib/fog/openstack/requests/image_v2/delete_image.rb +25 -0
  303. data/lib/fog/openstack/requests/image_v2/download_image.rb +29 -0
  304. data/lib/fog/openstack/requests/image_v2/get_image.rb +47 -0
  305. data/lib/fog/openstack/requests/image_v2/get_image_by_id.rb +34 -0
  306. data/lib/fog/openstack/requests/image_v2/get_image_members.rb +31 -0
  307. data/lib/fog/openstack/requests/image_v2/get_member_details.rb +33 -0
  308. data/lib/fog/openstack/requests/image_v2/get_shared_images.rb +31 -0
  309. data/lib/fog/openstack/requests/image_v2/list_images.rb +35 -0
  310. data/lib/fog/openstack/requests/image_v2/reactivate_image.rb +25 -0
  311. data/lib/fog/openstack/requests/image_v2/remove_member_from_image.rb +25 -0
  312. data/lib/fog/openstack/requests/image_v2/remove_tag_from_image.rb +25 -0
  313. data/lib/fog/openstack/requests/image_v2/set_tenant.rb +21 -0
  314. data/lib/fog/openstack/requests/image_v2/update_image.rb +49 -0
  315. data/lib/fog/openstack/requests/image_v2/update_image_member.rb +34 -0
  316. data/lib/fog/openstack/requests/image_v2/upload_image.rb +30 -0
  317. data/lib/fog/openstack/requests/network/add_router_interface.rb +12 -4
  318. data/lib/fog/openstack/requests/network/create_port.rb +14 -11
  319. data/lib/fog/openstack/requests/network/create_subnet.rb +7 -7
  320. data/lib/fog/openstack/requests/network/get_port.rb +5 -0
  321. data/lib/fog/openstack/requests/network/set_tenant.rb +1 -0
  322. data/lib/fog/openstack/requests/network/update_port.rb +7 -6
  323. data/lib/fog/openstack/requests/network/update_subnet.rb +8 -7
  324. data/lib/fog/openstack/requests/orchestration/list_events.rb +46 -0
  325. data/lib/fog/openstack/requests/orchestration/list_resource_events.rb +7 -2
  326. data/lib/fog/openstack/requests/orchestration/list_resource_types.rb +3 -2
  327. data/lib/fog/openstack/requests/orchestration/list_resources.rb +27 -4
  328. data/lib/fog/openstack/requests/orchestration/list_stack_data.rb +2 -2
  329. data/lib/fog/openstack/requests/orchestration/list_stack_data_detailed.rb +49 -0
  330. data/lib/fog/openstack/requests/orchestration/list_stack_events.rb +6 -2
  331. data/lib/fog/openstack/requests/orchestration/patch_stack.rb +37 -0
  332. data/lib/fog/openstack/requests/planning/list_plans.rb +4 -3
  333. data/lib/fog/openstack/requests/planning/list_roles.rb +3 -9
  334. data/lib/fog/openstack/requests/volume/accept_transfer.rb +22 -0
  335. data/lib/fog/openstack/requests/volume/create_transfer.rb +25 -0
  336. data/lib/fog/openstack/requests/volume/create_volume.rb +9 -39
  337. data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +13 -31
  338. data/lib/fog/openstack/requests/volume/create_volume_type.rb +41 -0
  339. data/lib/fog/openstack/requests/volume/delete_snapshot.rb +2 -2
  340. data/lib/fog/openstack/requests/volume/delete_transfer.rb +15 -0
  341. data/lib/fog/openstack/requests/volume/delete_volume.rb +2 -2
  342. data/lib/fog/openstack/requests/volume/delete_volume_type.rb +23 -0
  343. data/lib/fog/openstack/requests/volume/extend_volume.rb +25 -0
  344. data/lib/fog/openstack/requests/volume/get_quota.rb +2 -2
  345. data/lib/fog/openstack/requests/volume/get_quota_defaults.rb +7 -7
  346. data/lib/fog/openstack/requests/volume/get_quota_usage.rb +44 -0
  347. data/lib/fog/openstack/requests/volume/get_snapshot_details.rb +1 -20
  348. data/lib/fog/openstack/requests/volume/get_transfer_details.rb +17 -0
  349. data/lib/fog/openstack/requests/volume/get_volume_details.rb +1 -22
  350. data/lib/fog/openstack/requests/volume/get_volume_type_details.rb +3 -3
  351. data/lib/fog/openstack/requests/volume/list_snapshots.rb +18 -5
  352. data/lib/fog/openstack/requests/volume/list_snapshots_detailed.rb +27 -0
  353. data/lib/fog/openstack/requests/volume/list_transfers.rb +18 -0
  354. data/lib/fog/openstack/requests/volume/list_transfers_detailed.rb +18 -0
  355. data/lib/fog/openstack/requests/volume/list_volume_types.rb +8 -8
  356. data/lib/fog/openstack/requests/volume/list_volumes.rb +20 -40
  357. data/lib/fog/openstack/requests/volume/list_volumes_detailed.rb +16 -0
  358. data/lib/fog/openstack/requests/volume/list_zones.rb +32 -0
  359. data/lib/fog/openstack/requests/volume/set_tenant.rb +2 -2
  360. data/lib/fog/openstack/requests/volume/update_quota.rb +2 -2
  361. data/lib/fog/openstack/requests/volume/update_volume_type.rb +41 -0
  362. data/lib/fog/openstack/requests/volume_v1/accept_transfer.rb +2 -0
  363. data/lib/fog/openstack/requests/volume_v1/create_transfer.rb +2 -0
  364. data/lib/fog/openstack/requests/volume_v1/create_volume.rb +49 -0
  365. data/lib/fog/openstack/requests/volume_v1/create_volume_snapshot.rb +44 -0
  366. data/lib/fog/openstack/requests/volume_v1/create_volume_type.rb +2 -0
  367. data/lib/fog/openstack/requests/volume_v1/delete_snapshot.rb +2 -0
  368. data/lib/fog/openstack/requests/volume_v1/delete_transfer.rb +2 -0
  369. data/lib/fog/openstack/requests/volume_v1/delete_volume.rb +2 -0
  370. data/lib/fog/openstack/requests/volume_v1/delete_volume_type.rb +2 -0
  371. data/lib/fog/openstack/requests/volume_v1/extend_volume.rb +2 -0
  372. data/lib/fog/openstack/requests/volume_v1/get_quota.rb +2 -0
  373. data/lib/fog/openstack/requests/volume_v1/get_quota_defaults.rb +2 -0
  374. data/lib/fog/openstack/requests/volume_v1/get_quota_usage.rb +2 -0
  375. data/lib/fog/openstack/requests/volume_v1/get_snapshot_details.rb +32 -0
  376. data/lib/fog/openstack/requests/volume_v1/get_transfer_details.rb +2 -0
  377. data/lib/fog/openstack/requests/volume_v1/get_volume_details.rb +35 -0
  378. data/lib/fog/openstack/requests/volume_v1/get_volume_type_details.rb +2 -0
  379. data/lib/fog/openstack/requests/volume_v1/list_snapshots.rb +2 -0
  380. data/lib/fog/openstack/requests/volume_v1/list_snapshots_detailed.rb +2 -0
  381. data/lib/fog/openstack/requests/volume_v1/list_transfers.rb +2 -0
  382. data/lib/fog/openstack/requests/volume_v1/list_transfers_detailed.rb +2 -0
  383. data/lib/fog/openstack/requests/volume_v1/list_volume_types.rb +2 -0
  384. data/lib/fog/openstack/requests/volume_v1/list_volumes.rb +46 -0
  385. data/lib/fog/openstack/requests/volume_v1/list_volumes_detailed.rb +46 -0
  386. data/lib/fog/openstack/requests/volume_v1/list_zones.rb +2 -0
  387. data/lib/fog/openstack/requests/volume_v1/real.rb +11 -0
  388. data/lib/fog/openstack/requests/volume_v1/real_mock.rb +14 -0
  389. data/lib/fog/openstack/requests/volume_v1/set_tenant.rb +2 -0
  390. data/lib/fog/openstack/requests/volume_v1/update_quota.rb +2 -0
  391. data/lib/fog/openstack/requests/volume_v2/accept_transfer.rb +2 -0
  392. data/lib/fog/openstack/requests/volume_v2/create_transfer.rb +2 -0
  393. data/lib/fog/openstack/requests/volume_v2/create_volume.rb +49 -0
  394. data/lib/fog/openstack/requests/volume_v2/create_volume_snapshot.rb +43 -0
  395. data/lib/fog/openstack/requests/volume_v2/create_volume_type.rb +2 -0
  396. data/lib/fog/openstack/requests/volume_v2/delete_snapshot.rb +2 -0
  397. data/lib/fog/openstack/requests/volume_v2/delete_transfer.rb +2 -0
  398. data/lib/fog/openstack/requests/volume_v2/delete_volume.rb +2 -0
  399. data/lib/fog/openstack/requests/volume_v2/delete_volume_type.rb +2 -0
  400. data/lib/fog/openstack/requests/volume_v2/extend_volume.rb +2 -0
  401. data/lib/fog/openstack/requests/volume_v2/get_quota.rb +2 -0
  402. data/lib/fog/openstack/requests/volume_v2/get_quota_defaults.rb +2 -0
  403. data/lib/fog/openstack/requests/volume_v2/get_quota_usage.rb +2 -0
  404. data/lib/fog/openstack/requests/volume_v2/get_snapshot_details.rb +32 -0
  405. data/lib/fog/openstack/requests/volume_v2/get_transfer_details.rb +2 -0
  406. data/lib/fog/openstack/requests/volume_v2/get_volume_details.rb +35 -0
  407. data/lib/fog/openstack/requests/volume_v2/get_volume_type_details.rb +2 -0
  408. data/lib/fog/openstack/requests/volume_v2/list_snapshots.rb +2 -0
  409. data/lib/fog/openstack/requests/volume_v2/list_snapshots_detailed.rb +2 -0
  410. data/lib/fog/openstack/requests/volume_v2/list_transfers.rb +2 -0
  411. data/lib/fog/openstack/requests/volume_v2/list_transfers_detailed.rb +2 -0
  412. data/lib/fog/openstack/requests/volume_v2/list_volume_types.rb +2 -0
  413. data/lib/fog/openstack/requests/volume_v2/list_volumes.rb +46 -0
  414. data/lib/fog/openstack/requests/volume_v2/list_volumes_detailed.rb +46 -0
  415. data/lib/fog/openstack/requests/volume_v2/list_zones.rb +2 -0
  416. data/lib/fog/openstack/requests/volume_v2/real.rb +11 -0
  417. data/lib/fog/openstack/requests/volume_v2/real_mock.rb +14 -0
  418. data/lib/fog/openstack/requests/volume_v2/set_tenant.rb +2 -0
  419. data/lib/fog/openstack/requests/volume_v2/update_quota.rb +2 -0
  420. data/lib/fog/openstack/requests/volume_v2/update_volume_type.rb +2 -0
  421. data/lib/fog/openstack/storage.rb +19 -55
  422. data/lib/fog/openstack/volume.rb +21 -216
  423. data/lib/fog/openstack/volume_v1.rb +163 -0
  424. data/lib/fog/openstack/volume_v2.rb +164 -0
  425. data/lib/fog/openstack.rb +5 -0
  426. data/lib/fog/ovirt/models/compute/server.rb +1 -0
  427. data/lib/fog/ovirt/models/compute/template.rb +1 -0
  428. data/lib/fog/rackspace/compute_v2.rb +1 -0
  429. data/lib/fog/rackspace/docs/compute_v2.md +1 -1
  430. data/lib/fog/rackspace/docs/queues.md +2 -2
  431. data/lib/fog/rackspace/examples/compute_v2/create_network.rb +1 -1
  432. data/lib/fog/rackspace/models/block_storage/snapshot.rb +5 -1
  433. data/lib/fog/rackspace/models/compute_v2/server.rb +25 -1
  434. data/lib/fog/rackspace/models/compute_v2/servers.rb +2 -2
  435. data/lib/fog/rackspace/requests/compute_v2/create_server.rb +7 -2
  436. data/lib/fog/rackspace/requests/compute_v2/get_vnc_console.rb +45 -0
  437. data/lib/fog/rackspace/requests/load_balancers/create_node.rb +1 -1
  438. data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +13 -2
  439. data/lib/fog/rackspace/requests/storage/put_container.rb +10 -6
  440. data/lib/fog/vcloud_director/compute.rb +18 -2
  441. data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +32 -30
  442. data/lib/fog/vcloud_director/models/compute/disks.rb +6 -0
  443. data/lib/fog/vcloud_director/models/compute/networks.rb +7 -2
  444. data/lib/fog/vcloud_director/models/compute/task.rb +2 -2
  445. data/lib/fog/vcloud_director/models/compute/vdc.rb +5 -0
  446. data/lib/fog/vcloud_director/models/compute/vm.rb +15 -1
  447. data/lib/fog/vcloud_director/models/compute/vm_customizations.rb +15 -0
  448. data/lib/fog/vcloud_director/parsers/compute/vm.rb +4 -0
  449. data/lib/fog/vcloud_director/parsers/compute/vms.rb +4 -0
  450. data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +30 -0
  451. data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +24 -3
  452. data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +23 -0
  453. data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +13 -10
  454. data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +11 -0
  455. data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +1 -0
  456. data/lib/fog/vcloud_director/requests/compute/get_vm.rb +46 -0
  457. data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +20 -0
  458. data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +25 -0
  459. data/lib/fog/vcloud_director/requests/compute/get_vms.rb +13 -0
  460. data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +70 -0
  461. data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +35 -0
  462. data/lib/fog/vcloud_director/requests/compute/post_reconfigure_vm.rb +118 -0
  463. data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +34 -0
  464. data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +2 -1
  465. data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +31 -0
  466. data/lib/fog/version.rb +1 -1
  467. data/lib/fog.rb +1 -0
  468. data/lib/tasks/changelog_task.rb +6 -0
  469. data/spec/fog/openstack/identity_v3/authv3_a.yml +50 -37
  470. data/spec/fog/openstack/identity_v3/authv3_b.yml +50 -37
  471. data/spec/fog/openstack/identity_v3/authv3_c.yml +393 -35
  472. data/spec/fog/openstack/identity_v3/authv3_token.yml +421 -82
  473. data/spec/fog/openstack/identity_v3/authv3_unscoped.yml +471 -213
  474. data/spec/fog/openstack/identity_v3/authv3_unscoped_reauth.yml +835 -0
  475. data/spec/fog/openstack/identity_v3/common_setup.yml +98 -0
  476. data/spec/fog/openstack/identity_v3/idv3_credential.yml +71 -35
  477. data/spec/fog/openstack/identity_v3/idv3_credential_crud.yml +620 -210
  478. data/spec/fog/openstack/identity_v3/idv3_domain.yml +78 -117
  479. data/spec/fog/openstack/identity_v3/idv3_domain_crud.yml +277 -427
  480. data/spec/fog/openstack/identity_v3/idv3_domain_group_roles_mutation.yml +511 -404
  481. data/spec/fog/openstack/identity_v3/idv3_domain_roles_mutation.yml +555 -219
  482. data/spec/fog/openstack/identity_v3/idv3_endpoint.yml +499 -179
  483. data/spec/fog/openstack/identity_v3/idv3_endpoints_crud.yml +734 -447
  484. data/spec/fog/openstack/identity_v3/idv3_group_crud_mutation.yml +682 -332
  485. data/spec/fog/openstack/identity_v3/idv3_policy.yml +99 -51
  486. data/spec/fog/openstack/identity_v3/idv3_policy_crud.yml +249 -129
  487. data/spec/fog/openstack/identity_v3/idv3_project.yml +322 -136
  488. data/spec/fog/openstack/identity_v3/idv3_project_crud.yml +250 -423
  489. data/spec/fog/openstack/identity_v3/idv3_project_group_user_roles_mutation.yml +757 -616
  490. data/spec/fog/openstack/identity_v3/idv3_project_hier_crud_list.yml +1405 -0
  491. data/spec/fog/openstack/identity_v3/idv3_role.yml +159 -79
  492. data/spec/fog/openstack/identity_v3/idv3_role_crud.yml +329 -343
  493. data/spec/fog/openstack/identity_v3/idv3_service.yml +208 -100
  494. data/spec/fog/openstack/identity_v3/idv3_services_crud.yml +359 -321
  495. data/spec/fog/openstack/identity_v3/idv3_token.yml +246 -116
  496. data/spec/fog/openstack/identity_v3/idv3_user_crud.yml +465 -210
  497. data/spec/fog/openstack/identity_v3/idv3_users.yml +244 -228
  498. data/spec/fog/openstack/identity_v3_spec.rb +673 -568
  499. data/spec/fog/openstack/image_v1/common_setup.yml +144 -0
  500. data/spec/fog/openstack/image_v1/list_images.yml +54 -0
  501. data/spec/fog/openstack/image_v1_spec.rb +24 -0
  502. data/spec/fog/openstack/image_v2/common_setup.yml +144 -0
  503. data/spec/fog/openstack/image_v2/image_schema.json +190 -0
  504. data/spec/fog/openstack/image_v2/image_v2_activation.yml +3988 -0
  505. data/spec/fog/openstack/image_v2/image_v2_create_id.yml +291 -0
  506. data/spec/fog/openstack/image_v2/image_v2_crud.yml +437 -0
  507. data/spec/fog/openstack/image_v2/image_v2_member_crudl.yml +451 -0
  508. data/spec/fog/openstack/image_v2/image_v2_tags.yml +532 -0
  509. data/spec/fog/openstack/image_v2/image_v2_upload_download.yml +3966 -0
  510. data/spec/fog/openstack/image_v2/minimal.ova +0 -0
  511. data/spec/fog/openstack/image_v2_spec.rb +285 -0
  512. data/spec/fog/openstack/image_v2_upload_spec.rb +74 -0
  513. data/spec/fog/openstack/network/common_setup.yml +140 -0
  514. data/spec/fog/openstack/network/subnets_crud.yml +180 -0
  515. data/spec/fog/openstack/network_spec.rb +43 -0
  516. data/spec/fog/openstack/shared_context.rb +115 -0
  517. data/spec/fog/openstack/volume/common_setup.yml +100 -0
  518. data/spec/fog/openstack/volume/volume_crud.yml +611 -0
  519. data/spec/fog/openstack/volume/volume_extend.yml +669 -0
  520. data/spec/fog/openstack/volume/volume_transfer_and_accept.yml +1072 -0
  521. data/spec/fog/openstack/volume/volume_transfer_and_delete.yml +666 -0
  522. data/spec/fog/openstack/volume/volume_type_read.yml +114 -0
  523. data/spec/fog/openstack/volume_spec.rb +362 -0
  524. data/spec/fog/openstack/volume_v1/common_setup.yml +100 -0
  525. data/spec/fog/openstack/volume_v1/volume_crud.yml +535 -0
  526. data/spec/fog/openstack/volume_v1/volume_extend.yml +596 -0
  527. data/spec/fog/openstack/volume_v1/volume_transfer_and_accept.yml +1010 -0
  528. data/spec/fog/openstack/volume_v1/volume_transfer_and_delete.yml +645 -0
  529. data/spec/fog/openstack/volume_v1/volume_type_read.yml +114 -0
  530. data/spec/fog/openstack/volume_v2/common_setup.yml +100 -0
  531. data/spec/fog/openstack/volume_v2/volume_crud.yml +611 -0
  532. data/spec/fog/openstack/volume_v2/volume_extend.yml +669 -0
  533. data/spec/fog/openstack/volume_v2/volume_transfer_and_accept.yml +1072 -0
  534. data/spec/fog/openstack/volume_v2/volume_transfer_and_delete.yml +666 -0
  535. data/spec/fog/openstack/volume_v2/volume_type_read.yml +114 -0
  536. data/tests/compute/helper.rb +0 -9
  537. data/tests/digitalocean/requests/compute_v2/list_flavors_tests.rb +25 -0
  538. data/tests/digitalocean/requests/compute_v2/list_images_tests.rb +25 -0
  539. data/tests/digitalocean/requests/compute_v2/list_regions_tests.rb +21 -0
  540. data/tests/digitalocean/requests/compute_v2/server_tests.rb +77 -0
  541. data/tests/helper.rb +1 -0
  542. data/tests/helpers/mock_helper.rb +1 -4
  543. data/tests/linode/requests/compute/datacenter_tests.rb +2 -1
  544. data/tests/linode/requests/compute/kernel_tests.rb +2 -10
  545. data/tests/linode/requests/compute/linodeplans_tests.rb +10 -7
  546. data/tests/linode/requests/compute/nodebalancers_tests.rb +20 -0
  547. data/tests/opennebula/models/compute/flavor_tests.rb +1 -1
  548. data/tests/openstack/authenticate_tests.rb +4 -0
  549. data/tests/openstack/models/storage/file_tests.rb +55 -0
  550. data/tests/openstack/requests/compute/aggregate_tests.rb +59 -0
  551. data/tests/openstack/requests/compute/availability_zone_tests.rb +18 -0
  552. data/tests/openstack/requests/compute/server_tests.rb +12 -0
  553. data/tests/openstack/requests/network/port_tests.rb +14 -11
  554. data/tests/openstack/requests/network/subnet_tests.rb +2 -2
  555. data/tests/openstack/requests/orchestration/stack_tests.rb +30 -1
  556. data/tests/openstack/requests/volume/availability_zone_tests.rb +13 -0
  557. data/tests/openstack/requests/volume/volume_type_tests.rb +32 -0
  558. data/tests/openstack/volume_tests.rb +4 -0
  559. data/tests/rackspace/models/compute_v2/server_tests.rb +7 -7
  560. data/tests/rackspace/requests/compute_v2/server_tests.rb +4 -0
  561. data/tests/rackspace/requests/load_balancers/node_tests.rb +7 -0
  562. data/tests/rackspace/requests/storage/object_tests.rb +46 -4
  563. data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +4 -4
  564. metadata +403 -457
  565. data/gemfiles/Gemfile-ruby-1.8.7 +0 -17
  566. data/lib/fog/bin/dynect.rb +0 -28
  567. data/lib/fog/bin/vsphere.rb +0 -28
  568. data/lib/fog/bin/xenserver.rb +0 -29
  569. data/lib/fog/dynect/core.rb +0 -26
  570. data/lib/fog/dynect/dns.rb +0 -157
  571. data/lib/fog/dynect/models/dns/record.rb +0 -67
  572. data/lib/fog/dynect/models/dns/records.rb +0 -48
  573. data/lib/fog/dynect/models/dns/zone.rb +0 -56
  574. data/lib/fog/dynect/models/dns/zones.rb +0 -25
  575. data/lib/fog/dynect/requests/dns/delete_record.rb +0 -55
  576. data/lib/fog/dynect/requests/dns/delete_zone.rb +0 -41
  577. data/lib/fog/dynect/requests/dns/get_all_records.rb +0 -56
  578. data/lib/fog/dynect/requests/dns/get_node_list.rb +0 -55
  579. data/lib/fog/dynect/requests/dns/get_record.rb +0 -83
  580. data/lib/fog/dynect/requests/dns/get_zone.rb +0 -57
  581. data/lib/fog/dynect/requests/dns/post_record.rb +0 -71
  582. data/lib/fog/dynect/requests/dns/post_session.rb +0 -43
  583. data/lib/fog/dynect/requests/dns/post_zone.rb +0 -70
  584. data/lib/fog/dynect/requests/dns/put_record.rb +0 -76
  585. data/lib/fog/dynect/requests/dns/put_zone.rb +0 -76
  586. data/lib/fog/dynect.rb +0 -1
  587. data/lib/fog/openstack/models/image/image.rb +0 -87
  588. data/lib/fog/openstack/models/image/images.rb +0 -61
  589. data/lib/fog/openstack/requests/image/create_image.rb +0 -76
  590. data/lib/fog/openstack/requests/image/delete_image.rb +0 -23
  591. data/lib/fog/openstack/requests/image/get_image.rb +0 -45
  592. data/lib/fog/openstack/requests/image/get_image_by_id.rb +0 -32
  593. data/lib/fog/openstack/requests/image/get_image_members.rb +0 -29
  594. data/lib/fog/openstack/requests/image/get_shared_images.rb +0 -29
  595. data/lib/fog/openstack/requests/image/list_public_images.rb +0 -32
  596. data/lib/fog/openstack/requests/image/list_public_images_detailed.rb +0 -32
  597. data/lib/fog/openstack/requests/image/remove_member_from_image.rb +0 -23
  598. data/lib/fog/openstack/requests/image/set_tenant.rb +0 -19
  599. data/lib/fog/openstack/requests/image/update_image.rb +0 -64
  600. data/lib/fog/openstack/requests/image/update_image_members.rb +0 -37
  601. data/lib/fog/vsphere/compute.rb +0 -465
  602. data/lib/fog/vsphere/core.rb +0 -39
  603. data/lib/fog/vsphere/models/compute/cluster.rb +0 -28
  604. data/lib/fog/vsphere/models/compute/clusters.rb +0 -23
  605. data/lib/fog/vsphere/models/compute/customfield.rb +0 -16
  606. data/lib/fog/vsphere/models/compute/customfields.rb +0 -24
  607. data/lib/fog/vsphere/models/compute/customvalue.rb +0 -14
  608. data/lib/fog/vsphere/models/compute/customvalues.rb +0 -34
  609. data/lib/fog/vsphere/models/compute/datacenter.rb +0 -44
  610. data/lib/fog/vsphere/models/compute/datacenters.rb +0 -20
  611. data/lib/fog/vsphere/models/compute/datastore.rb +0 -21
  612. data/lib/fog/vsphere/models/compute/datastores.rb +0 -22
  613. data/lib/fog/vsphere/models/compute/folder.rb +0 -24
  614. data/lib/fog/vsphere/models/compute/folders.rb +0 -24
  615. data/lib/fog/vsphere/models/compute/interface.rb +0 -91
  616. data/lib/fog/vsphere/models/compute/interfaces.rb +0 -67
  617. data/lib/fog/vsphere/models/compute/interfacetype.rb +0 -22
  618. data/lib/fog/vsphere/models/compute/interfacetypes.rb +0 -35
  619. data/lib/fog/vsphere/models/compute/network.rb +0 -17
  620. data/lib/fog/vsphere/models/compute/networks.rb +0 -23
  621. data/lib/fog/vsphere/models/compute/resource_pool.rb +0 -19
  622. data/lib/fog/vsphere/models/compute/resource_pools.rb +0 -23
  623. data/lib/fog/vsphere/models/compute/scsicontroller.rb +0 -16
  624. data/lib/fog/vsphere/models/compute/server.rb +0 -296
  625. data/lib/fog/vsphere/models/compute/servers.rb +0 -37
  626. data/lib/fog/vsphere/models/compute/servertype.rb +0 -36
  627. data/lib/fog/vsphere/models/compute/servertypes.rb +0 -24
  628. data/lib/fog/vsphere/models/compute/template.rb +0 -11
  629. data/lib/fog/vsphere/models/compute/templates.rb +0 -20
  630. data/lib/fog/vsphere/models/compute/volume.rb +0 -99
  631. data/lib/fog/vsphere/models/compute/volumes.rb +0 -54
  632. data/lib/fog/vsphere/requests/compute/cloudinit_to_customspec.rb +0 -65
  633. data/lib/fog/vsphere/requests/compute/create_folder.rb +0 -22
  634. data/lib/fog/vsphere/requests/compute/create_vm.rb +0 -164
  635. data/lib/fog/vsphere/requests/compute/current_time.rb +0 -18
  636. data/lib/fog/vsphere/requests/compute/get_cluster.rb +0 -25
  637. data/lib/fog/vsphere/requests/compute/get_compute_resource.rb +0 -41
  638. data/lib/fog/vsphere/requests/compute/get_datacenter.rb +0 -31
  639. data/lib/fog/vsphere/requests/compute/get_datastore.rb +0 -30
  640. data/lib/fog/vsphere/requests/compute/get_folder.rb +0 -74
  641. data/lib/fog/vsphere/requests/compute/get_interface_type.rb +0 -15
  642. data/lib/fog/vsphere/requests/compute/get_network.rb +0 -59
  643. data/lib/fog/vsphere/requests/compute/get_resource_pool.rb +0 -26
  644. data/lib/fog/vsphere/requests/compute/get_server_type.rb +0 -32
  645. data/lib/fog/vsphere/requests/compute/get_template.rb +0 -16
  646. data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +0 -56
  647. data/lib/fog/vsphere/requests/compute/get_vm_first_scsi_controller.rb +0 -26
  648. data/lib/fog/vsphere/requests/compute/list_clusters.rb +0 -72
  649. data/lib/fog/vsphere/requests/compute/list_compute_resources.rb +0 -92
  650. data/lib/fog/vsphere/requests/compute/list_customfields.rb +0 -21
  651. data/lib/fog/vsphere/requests/compute/list_datacenters.rb +0 -53
  652. data/lib/fog/vsphere/requests/compute/list_datastores.rb +0 -40
  653. data/lib/fog/vsphere/requests/compute/list_folders.rb +0 -44
  654. data/lib/fog/vsphere/requests/compute/list_interface_types.rb +0 -25
  655. data/lib/fog/vsphere/requests/compute/list_networks.rb +0 -37
  656. data/lib/fog/vsphere/requests/compute/list_resource_pools.rb +0 -38
  657. data/lib/fog/vsphere/requests/compute/list_server_types.rb +0 -54
  658. data/lib/fog/vsphere/requests/compute/list_templates.rb +0 -48
  659. data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +0 -80
  660. data/lib/fog/vsphere/requests/compute/list_vm_customvalues.rb +0 -20
  661. data/lib/fog/vsphere/requests/compute/list_vm_interfaces.rb +0 -63
  662. data/lib/fog/vsphere/requests/compute/list_vm_volumes.rb +0 -52
  663. data/lib/fog/vsphere/requests/compute/modify_vm_interface.rb +0 -59
  664. data/lib/fog/vsphere/requests/compute/modify_vm_volume.rb +0 -25
  665. data/lib/fog/vsphere/requests/compute/set_vm_customvalue.rb +0 -17
  666. data/lib/fog/vsphere/requests/compute/vm_clone.rb +0 -659
  667. data/lib/fog/vsphere/requests/compute/vm_config_vnc.rb +0 -45
  668. data/lib/fog/vsphere/requests/compute/vm_destroy.rb +0 -23
  669. data/lib/fog/vsphere/requests/compute/vm_migrate.rb +0 -33
  670. data/lib/fog/vsphere/requests/compute/vm_power_off.rb +0 -39
  671. data/lib/fog/vsphere/requests/compute/vm_power_on.rb +0 -26
  672. data/lib/fog/vsphere/requests/compute/vm_reboot.rb +0 -31
  673. data/lib/fog/vsphere/requests/compute/vm_reconfig_cpus.rb +0 -23
  674. data/lib/fog/vsphere/requests/compute/vm_reconfig_hardware.rb +0 -24
  675. data/lib/fog/vsphere/requests/compute/vm_reconfig_memory.rb +0 -23
  676. data/lib/fog/vsphere.rb +0 -1
  677. data/lib/fog/xenserver/CHANGELOG.md +0 -77
  678. data/lib/fog/xenserver/compute.rb +0 -186
  679. data/lib/fog/xenserver/core.rb +0 -94
  680. data/lib/fog/xenserver/examples/README.md +0 -11
  681. data/lib/fog/xenserver/examples/chage_default_storage_repository.md +0 -99
  682. data/lib/fog/xenserver/examples/creating_servers.md +0 -168
  683. data/lib/fog/xenserver/examples/getting_started.md +0 -163
  684. data/lib/fog/xenserver/examples/networks-and-vlans.rb +0 -44
  685. data/lib/fog/xenserver/examples/storage_repositories.md +0 -94
  686. data/lib/fog/xenserver/models/compute/blob.rb +0 -22
  687. data/lib/fog/xenserver/models/compute/blobs.rb +0 -25
  688. data/lib/fog/xenserver/models/compute/bond.rb +0 -23
  689. data/lib/fog/xenserver/models/compute/bonds.rb +0 -25
  690. data/lib/fog/xenserver/models/compute/console.rb +0 -29
  691. data/lib/fog/xenserver/models/compute/consoles.rb +0 -25
  692. data/lib/fog/xenserver/models/compute/crash_dump.rb +0 -19
  693. data/lib/fog/xenserver/models/compute/crash_dumps.rb +0 -25
  694. data/lib/fog/xenserver/models/compute/dr_task.rb +0 -17
  695. data/lib/fog/xenserver/models/compute/dr_tasks.rb +0 -25
  696. data/lib/fog/xenserver/models/compute/gpu_group.rb +0 -22
  697. data/lib/fog/xenserver/models/compute/gpu_groups.rb +0 -25
  698. data/lib/fog/xenserver/models/compute/guest_metrics.rb +0 -26
  699. data/lib/fog/xenserver/models/compute/host.rb +0 -156
  700. data/lib/fog/xenserver/models/compute/host_cpu.rb +0 -34
  701. data/lib/fog/xenserver/models/compute/host_crash_dump.rb +0 -20
  702. data/lib/fog/xenserver/models/compute/host_crash_dumps.rb +0 -25
  703. data/lib/fog/xenserver/models/compute/host_metrics.rb +0 -26
  704. data/lib/fog/xenserver/models/compute/host_patch.rb +0 -25
  705. data/lib/fog/xenserver/models/compute/host_patchs.rb +0 -25
  706. data/lib/fog/xenserver/models/compute/hosts.rb +0 -25
  707. data/lib/fog/xenserver/models/compute/network.rb +0 -93
  708. data/lib/fog/xenserver/models/compute/networks.rb +0 -29
  709. data/lib/fog/xenserver/models/compute/pbd.rb +0 -37
  710. data/lib/fog/xenserver/models/compute/pbds.rb +0 -29
  711. data/lib/fog/xenserver/models/compute/pci.rb +0 -22
  712. data/lib/fog/xenserver/models/compute/pcis.rb +0 -25
  713. data/lib/fog/xenserver/models/compute/pgpu.rb +0 -20
  714. data/lib/fog/xenserver/models/compute/pgpus.rb +0 -25
  715. data/lib/fog/xenserver/models/compute/pif.rb +0 -54
  716. data/lib/fog/xenserver/models/compute/pif_metrics.rb +0 -28
  717. data/lib/fog/xenserver/models/compute/pifs.rb +0 -29
  718. data/lib/fog/xenserver/models/compute/pifs_metrics.rb +0 -25
  719. data/lib/fog/xenserver/models/compute/pool.rb +0 -75
  720. data/lib/fog/xenserver/models/compute/pool_patch.rb +0 -24
  721. data/lib/fog/xenserver/models/compute/pool_patchs.rb +0 -25
  722. data/lib/fog/xenserver/models/compute/pools.rb +0 -29
  723. data/lib/fog/xenserver/models/compute/role.rb +0 -19
  724. data/lib/fog/xenserver/models/compute/roles.rb +0 -25
  725. data/lib/fog/xenserver/models/compute/server.rb +0 -251
  726. data/lib/fog/xenserver/models/compute/server_appliance.rb +0 -21
  727. data/lib/fog/xenserver/models/compute/server_appliances.rb +0 -25
  728. data/lib/fog/xenserver/models/compute/servers.rb +0 -64
  729. data/lib/fog/xenserver/models/compute/storage_manager.rb +0 -28
  730. data/lib/fog/xenserver/models/compute/storage_managers.rb +0 -25
  731. data/lib/fog/xenserver/models/compute/storage_repositories.rb +0 -27
  732. data/lib/fog/xenserver/models/compute/storage_repository.rb +0 -90
  733. data/lib/fog/xenserver/models/compute/tunnel.rb +0 -20
  734. data/lib/fog/xenserver/models/compute/tunnels.rb +0 -25
  735. data/lib/fog/xenserver/models/compute/vbd.rb +0 -88
  736. data/lib/fog/xenserver/models/compute/vbd_metrics.rb +0 -25
  737. data/lib/fog/xenserver/models/compute/vbds.rb +0 -29
  738. data/lib/fog/xenserver/models/compute/vdi.rb +0 -102
  739. data/lib/fog/xenserver/models/compute/vdis.rb +0 -25
  740. data/lib/fog/xenserver/models/compute/vif.rb +0 -56
  741. data/lib/fog/xenserver/models/compute/vifs.rb +0 -25
  742. data/lib/fog/xenserver/models/compute/vlan.rb +0 -78
  743. data/lib/fog/xenserver/models/compute/vlans.rb +0 -35
  744. data/lib/fog/xenserver/models/compute/vmpp.rb +0 -35
  745. data/lib/fog/xenserver/models/compute/vmpps.rb +0 -25
  746. data/lib/fog/xenserver/models/compute/vtpm.rb +0 -18
  747. data/lib/fog/xenserver/models/compute/vtpms.rb +0 -25
  748. data/lib/fog/xenserver/parser.rb +0 -34
  749. data/lib/fog/xenserver/parsers/get_hosts.rb +0 -16
  750. data/lib/fog/xenserver/parsers/get_networks.rb +0 -16
  751. data/lib/fog/xenserver/parsers/get_pools.rb +0 -16
  752. data/lib/fog/xenserver/parsers/get_records.rb +0 -16
  753. data/lib/fog/xenserver/parsers/get_storage_repositories.rb +0 -16
  754. data/lib/fog/xenserver/parsers/get_vbds.rb +0 -16
  755. data/lib/fog/xenserver/parsers/get_vifs.rb +0 -16
  756. data/lib/fog/xenserver/parsers/get_vms.rb +0 -16
  757. data/lib/fog/xenserver/requests/compute/clone_server.rb +0 -30
  758. data/lib/fog/xenserver/requests/compute/create_network.rb +0 -46
  759. data/lib/fog/xenserver/requests/compute/create_server.rb +0 -144
  760. data/lib/fog/xenserver/requests/compute/create_sr.rb +0 -88
  761. data/lib/fog/xenserver/requests/compute/create_vbd.rb +0 -43
  762. data/lib/fog/xenserver/requests/compute/create_vdi.rb +0 -57
  763. data/lib/fog/xenserver/requests/compute/create_vif.rb +0 -62
  764. data/lib/fog/xenserver/requests/compute/create_vlan.rb +0 -43
  765. data/lib/fog/xenserver/requests/compute/destroy_network.rb +0 -31
  766. data/lib/fog/xenserver/requests/compute/destroy_record.rb +0 -11
  767. data/lib/fog/xenserver/requests/compute/destroy_server.rb +0 -20
  768. data/lib/fog/xenserver/requests/compute/destroy_sr.rb +0 -28
  769. data/lib/fog/xenserver/requests/compute/destroy_vdi.rb +0 -20
  770. data/lib/fog/xenserver/requests/compute/destroy_vif.rb +0 -20
  771. data/lib/fog/xenserver/requests/compute/destroy_vlan.rb +0 -30
  772. data/lib/fog/xenserver/requests/compute/disable_host.rb +0 -23
  773. data/lib/fog/xenserver/requests/compute/eject_vbd.rb +0 -17
  774. data/lib/fog/xenserver/requests/compute/enable_host.rb +0 -22
  775. data/lib/fog/xenserver/requests/compute/get_record.rb +0 -31
  776. data/lib/fog/xenserver/requests/compute/get_records.rb +0 -24
  777. data/lib/fog/xenserver/requests/compute/insert_vbd.rb +0 -17
  778. data/lib/fog/xenserver/requests/compute/provision_server.rb +0 -17
  779. data/lib/fog/xenserver/requests/compute/reboot_host.rb +0 -17
  780. data/lib/fog/xenserver/requests/compute/reboot_server.rb +0 -17
  781. data/lib/fog/xenserver/requests/compute/scan_sr.rb +0 -17
  782. data/lib/fog/xenserver/requests/compute/set_affinity.rb +0 -19
  783. data/lib/fog/xenserver/requests/compute/set_attribute.rb +0 -19
  784. data/lib/fog/xenserver/requests/compute/shutdown_host.rb +0 -17
  785. data/lib/fog/xenserver/requests/compute/shutdown_server.rb +0 -17
  786. data/lib/fog/xenserver/requests/compute/snapshot_revert.rb +0 -24
  787. data/lib/fog/xenserver/requests/compute/snapshot_server.rb +0 -17
  788. data/lib/fog/xenserver/requests/compute/start_server.rb +0 -17
  789. data/lib/fog/xenserver/requests/compute/start_vm.rb +0 -19
  790. data/lib/fog/xenserver/requests/compute/unplug_pbd.rb +0 -20
  791. data/lib/fog/xenserver/requests/compute/unplug_vbd.rb +0 -25
  792. data/lib/fog/xenserver/utilities.rb +0 -8
  793. data/lib/fog/xenserver.rb +0 -1
  794. data/spec/fog/openstack/identity_v3/authv3_project.yml +0 -61
  795. data/spec/fog/openstack/identity_v3/idv2_unscoped_token_v3.yml +0 -467
  796. data/spec/fog/openstack/identity_v3/idv3.yml +0 -61
  797. data/tests/brightbox/compute/helper.rb +0 -1
  798. data/tests/brightbox/compute/schema.rb +0 -799
  799. data/tests/brightbox/compute_tests.rb +0 -101
  800. data/tests/brightbox/helper.rb +0 -1
  801. data/tests/brightbox/models/compute/account_tests.rb +0 -17
  802. data/tests/brightbox/models/compute/cloud_ip_tests.rb +0 -32
  803. data/tests/brightbox/models/compute/database_server_tests.rb +0 -78
  804. data/tests/brightbox/models/compute/database_snapshot_tests.rb +0 -26
  805. data/tests/brightbox/models/compute/database_type_tests.rb +0 -27
  806. data/tests/brightbox/models/compute/server_tests.rb +0 -19
  807. data/tests/brightbox/oauth2_tests.rb +0 -110
  808. data/tests/brightbox/requests/compute/account_tests.rb +0 -65
  809. data/tests/brightbox/requests/compute/api_client_tests.rb +0 -64
  810. data/tests/brightbox/requests/compute/application_test.rb +0 -63
  811. data/tests/brightbox/requests/compute/cloud_ip_tests.rb +0 -85
  812. data/tests/brightbox/requests/compute/collaboration_tests.rb +0 -39
  813. data/tests/brightbox/requests/compute/database_server_tests.rb +0 -54
  814. data/tests/brightbox/requests/compute/database_snapsnot_tests.rb +0 -47
  815. data/tests/brightbox/requests/compute/database_type_tests.rb +0 -17
  816. data/tests/brightbox/requests/compute/firewall_policy_tests.rb +0 -40
  817. data/tests/brightbox/requests/compute/firewall_rule_tests.rb +0 -43
  818. data/tests/brightbox/requests/compute/helper.rb +0 -41
  819. data/tests/brightbox/requests/compute/image_tests.rb +0 -60
  820. data/tests/brightbox/requests/compute/interface_tests.rb +0 -33
  821. data/tests/brightbox/requests/compute/load_balancer_tests.rb +0 -121
  822. data/tests/brightbox/requests/compute/server_group_tests.rb +0 -96
  823. data/tests/brightbox/requests/compute/server_tests.rb +0 -99
  824. data/tests/brightbox/requests/compute/server_type_tests.rb +0 -34
  825. data/tests/brightbox/requests/compute/user_collaboration_tests.rb +0 -67
  826. data/tests/brightbox/requests/compute/user_tests.rb +0 -38
  827. data/tests/brightbox/requests/compute/zone_tests.rb +0 -34
  828. data/tests/dynect/requests/dns/dns_tests.rb +0 -258
  829. data/tests/vsphere/compute_tests.rb +0 -53
  830. data/tests/vsphere/models/compute/server_tests.rb +0 -44
  831. data/tests/vsphere/models/compute/servers_tests.rb +0 -15
  832. data/tests/vsphere/requests/compute/current_time_tests.rb +0 -12
  833. data/tests/vsphere/requests/compute/get_network_tests.rb +0 -48
  834. data/tests/vsphere/requests/compute/list_clusters_tests.rb +0 -11
  835. data/tests/vsphere/requests/compute/list_virtual_machines_tests.rb +0 -38
  836. data/tests/vsphere/requests/compute/set_vm_customvalue_tests.rb +0 -20
  837. data/tests/vsphere/requests/compute/vm_clone_tests.rb +0 -50
  838. data/tests/vsphere/requests/compute/vm_config_vnc_tests.rb +0 -19
  839. data/tests/vsphere/requests/compute/vm_destroy_tests.rb +0 -17
  840. data/tests/vsphere/requests/compute/vm_migrate_tests.rb +0 -16
  841. data/tests/vsphere/requests/compute/vm_power_off_tests.rb +0 -26
  842. data/tests/vsphere/requests/compute/vm_power_on_tests.rb +0 -17
  843. data/tests/vsphere/requests/compute/vm_reboot_tests.rb +0 -26
  844. data/tests/vsphere/requests/compute/vm_reconfig_cpus_tests.rb +0 -19
  845. data/tests/vsphere/requests/compute/vm_reconfig_hardware_tests.rb +0 -19
  846. data/tests/vsphere/requests/compute/vm_reconfig_memory_tests.rb +0 -19
  847. data/tests/xenserver/README +0 -21
  848. data/tests/xenserver/compute_tests.rb +0 -51
  849. data/tests/xenserver/helper.rb +0 -36
  850. data/tests/xenserver/models/compute/console_test.rb +0 -35
  851. data/tests/xenserver/models/compute/consoles_test.rb +0 -19
  852. data/tests/xenserver/models/compute/host_cpu_tests.rb +0 -58
  853. data/tests/xenserver/models/compute/host_metrics_tests.rb +0 -48
  854. data/tests/xenserver/models/compute/host_tests.rb +0 -98
  855. data/tests/xenserver/models/compute/hosts_tests.rb +0 -22
  856. data/tests/xenserver/models/compute/network_tests.rb +0 -79
  857. data/tests/xenserver/models/compute/networks_tests.rb +0 -22
  858. data/tests/xenserver/models/compute/pbd_tests.rb +0 -76
  859. data/tests/xenserver/models/compute/pbds_tests.rb +0 -22
  860. data/tests/xenserver/models/compute/pif_tests.rb +0 -58
  861. data/tests/xenserver/models/compute/pifs_tests.rb +0 -22
  862. data/tests/xenserver/models/compute/pool_tests.rb +0 -56
  863. data/tests/xenserver/models/compute/pools_tests.rb +0 -30
  864. data/tests/xenserver/models/compute/server_tests.rb +0 -184
  865. data/tests/xenserver/models/compute/servers_tests.rb +0 -89
  866. data/tests/xenserver/models/compute/storage_repositories_tests.rb +0 -30
  867. data/tests/xenserver/models/compute/storage_repository_tests.rb +0 -114
  868. data/tests/xenserver/models/compute/vbd_tests.rb +0 -115
  869. data/tests/xenserver/models/compute/vbds_tests.rb +0 -22
  870. data/tests/xenserver/models/compute/vif_tests.rb +0 -53
  871. data/tests/xenserver/models/compute/vifs_tests.rb +0 -22
  872. data/tests/xenserver/models/compute/vlan_tests.rb +0 -76
  873. data/tests/xenserver/models/compute/vlans_tests.rb +0 -36
  874. data/tests/xenserver/requests/compute/clone_server_tests.rb +0 -32
  875. data/tests/xenserver/requests/compute/create_network_tests.rb +0 -20
  876. data/tests/xenserver/requests/compute/create_server_tests.rb +0 -129
  877. data/tests/xenserver/requests/compute/create_sr_tests.rb +0 -54
  878. data/tests/xenserver/requests/compute/create_vdi_tests.rb +0 -80
  879. data/tests/xenserver/requests/compute/create_vif_tests.rb +0 -88
  880. data/tests/xenserver/requests/compute/create_vlan_tests.rb +0 -36
  881. data/tests/xenserver/requests/compute/destroy_network_tests.rb +0 -13
  882. data/tests/xenserver/requests/compute/destroy_sr_tests.rb +0 -46
  883. data/tests/xenserver/requests/compute/destroy_vdi_tests.rb +0 -25
  884. data/tests/xenserver/requests/compute/destroy_vlan_tests.rb +0 -36
  885. data/tests/xenserver/requests/compute/disable_host_tests.rb +0 -16
  886. data/tests/xenserver/requests/compute/enable_host_tests.rb +0 -16
  887. data/tests/xenserver/requests/compute/get_record_tests.rb +0 -15
  888. data/tests/xenserver/requests/compute/set_attribute_tests.rb +0 -66
  889. data/tests/xenserver/requests/compute/unplug_pbd_tests.rb +0 -48
  890. data/tests/xenserver/xenserver_tests.rb +0 -33
@@ -1,659 +0,0 @@
1
- module Fog
2
- module Compute
3
- class Vsphere
4
- module Shared
5
- private
6
- def vm_clone_check_options(options)
7
- default_options = {
8
- 'force' => false,
9
- 'linked_clone' => false,
10
- 'nic_type' => 'VirtualE1000',
11
- }
12
- options = default_options.merge(options)
13
- # Backwards compat for "path" option
14
- options["template_path"] ||= options["path"]
15
- options["path"] ||= options["template_path"]
16
- required_options = %w{ datacenter template_path name }
17
- required_options.each do |param|
18
- raise ArgumentError, "#{required_options.join(', ')} are required" unless options.key? param
19
- end
20
- raise Fog::Compute::Vsphere::NotFound, "Datacenter #{options["datacenter"]} Doesn't Exist!" unless get_datacenter(options["datacenter"])
21
- raise Fog::Compute::Vsphere::NotFound, "Template #{options["template_path"]} Doesn't Exist!" unless get_virtual_machine(options["template_path"], options["datacenter"])
22
- options
23
- end
24
- end
25
-
26
- class Real
27
- include Shared
28
-
29
- # Clones a VM from a template or existing machine on your vSphere
30
- # Server.
31
- #
32
- # ==== Parameters
33
- # * options<~Hash>:
34
- # * 'datacenter'<~String> - *REQUIRED* Datacenter name your cloning
35
- # in. Make sure this datacenter exists, should if you're using
36
- # the clone function in server.rb model.
37
- # * 'template_path'<~String> - *REQUIRED* The path to the machine you
38
- # want to clone FROM. Relative to Datacenter (Example:
39
- # "FolderNameHere/VMNameHere")
40
- # * 'name'<~String> - *REQUIRED* The VMName of the Destination
41
- # * 'dest_folder'<~String> - Destination Folder of where 'name' will
42
- # be placed on your cluster. Relative Path to Datacenter E.G.
43
- # "FolderPlaceHere/anotherSub Folder/onemore"
44
- # * 'power_on'<~Boolean> - Whether to power on machine after clone.
45
- # Defaults to true.
46
- # * 'wait'<~Boolean> - Whether the method should wait for the virtual
47
- # machine to finish cloning before returning information from
48
- # vSphere. Broken right now as you cannot return a model of a serer
49
- # that isn't finished cloning. Defaults to True
50
- # * 'resource_pool'<~Array> - The resource pool on your datacenter
51
- # cluster you want to use. Only works with clusters within same
52
- # same datacenter as where you're cloning from. Datacenter grabbed
53
- # from template_path option.
54
- # Example: ['cluster_name_here','resource_pool_name_here']
55
- # * 'datastore'<~String> - The datastore you'd like to use.
56
- # (datacenterObj.datastoreFolder.find('name') in API)
57
- # * 'transform'<~String> - Not documented - see http://www.vmware.com/support/developer/vc-sdk/visdk41pubs/ApiReference/vim.vm.RelocateSpec.html
58
- # * 'numCPUs'<~Integer> - the number of Virtual CPUs of the Destination VM
59
- # * 'memoryMB'<~Integer> - the size of memory of the Destination VM in MB
60
- # * customization_spec<~Hash>: Options are marked as required if you
61
- # use this customization_spec.
62
- # As defined https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Specification.html
63
- # * encryptionKey <~array of bytes> Used to encrypt/decrypt password
64
- # * globalIPSettings expects a hash, REQUIRED
65
- # * identity expects a hash, REQUIRED - either LinuxPrep, Sysprep or SysprepText
66
- # * nicSettingMap expects an array
67
- # * options expects a hash
68
- # * All options can be parsed using a yaml template with cloudinit_to_customspec.rb
69
- #
70
- # OLD Values still supported:
71
- # This only support cloning and setting DHCP on the first interface
72
- # * 'domain'<~String> - *REQUIRED* This is put into
73
- # /etc/resolve.conf (we hope)
74
- # * 'hostname'<~String> - Hostname of the Guest Os - default is
75
- # options['name']
76
- # * 'hw_utc_clock'<~Boolean> - *REQUIRED* Is hardware clock UTC?
77
- # Default true
78
- # * 'time_zone'<~String> - *REQUIRED* Only valid linux options
79
- # are valid - example: 'America/Denver'
80
- def vm_clone(options = {})
81
- # Option handling
82
- options = vm_clone_check_options(options)
83
-
84
- # Added for people still using options['path']
85
- template_path = options['path'] || options['template_path']
86
-
87
- # Options['template_path']<~String>
88
- # Added for people still using options['path']
89
- template_path = options['path'] || options['template_path']
90
- # Now find the template itself using the efficient find method
91
- vm_mob_ref = get_vm_ref(template_path, options['datacenter'])
92
-
93
- # Options['dest_folder']<~String>
94
- # Grab the destination folder object if it exists else use cloned mach
95
- dest_folder_path = options.fetch('dest_folder','/') # default to root path ({dc_name}/vm/)
96
- dest_folder = get_raw_vmfolder(dest_folder_path, options['datacenter'])
97
-
98
- # Options['resource_pool']<~Array>
99
- # Now find _a_ resource pool to use for the clone if one is not specified
100
- if ( options.key?('resource_pool') && options['resource_pool'].is_a?(Array) && options['resource_pool'].length == 2 )
101
- cluster_name = options['resource_pool'][0]
102
- pool_name = options['resource_pool'][1]
103
- resource_pool = get_raw_resource_pool(pool_name, cluster_name, options['datacenter'])
104
- elsif ( vm_mob_ref.resourcePool == nil )
105
- # If the template is really a template then there is no associated resource pool,
106
- # so we need to find one using the template's parent host or cluster
107
- esx_host = vm_mob_ref.collect!('runtime.host')['runtime.host']
108
- # The parent of the ESX host itself is a ComputeResource which has a resourcePool
109
- resource_pool = esx_host.parent.resourcePool
110
- end
111
- # If the vm given did return a valid resource pool, default to using it for the clone.
112
- # Even if specific pools aren't implemented in this environment, we will still get back
113
- # at least the cluster or host we can pass on to the clone task
114
- # This catches if resource_pool option is set but comes back nil and if resourcePool is
115
- # already set.
116
- resource_pool ||= vm_mob_ref.resourcePool.nil? ? esx_host.parent.resourcePool : vm_mob_ref.resourcePool
117
-
118
- # Options['datastore']<~String>
119
- # Grab the datastore object if option is set
120
- datastore_obj = get_raw_datastore(options['datastore'], options['datacenter']) if options.key?('datastore')
121
- # confirm nil if nil or option is not set
122
- datastore_obj ||= nil
123
- virtual_machine_config_spec = RbVmomi::VIM::VirtualMachineConfigSpec()
124
-
125
- # Options['network']
126
- # Build up the config spec
127
- if ( options.key?('network_label') )
128
- config_spec_operation = RbVmomi::VIM::VirtualDeviceConfigSpecOperation('edit')
129
- # Get the portgroup and handle it from there.
130
- network = get_raw_network(options['network_label'],options['datacenter'])
131
- if ( network.kind_of? RbVmomi::VIM::DistributedVirtualPortgroup)
132
- # Create the NIC backing for the distributed virtual portgroup
133
- nic_backing_info = RbVmomi::VIM::VirtualEthernetCardDistributedVirtualPortBackingInfo(
134
- :port => RbVmomi::VIM::DistributedVirtualSwitchPortConnection(
135
- :portgroupKey => network.key,
136
- :switchUuid => network.config.distributedVirtualSwitch.uuid
137
- )
138
- )
139
- else
140
- # Otherwise it's a non distributed port group
141
- nic_backing_info = RbVmomi::VIM::VirtualEthernetCardNetworkBackingInfo(:deviceName => options['network_label'])
142
- end
143
- connectable = RbVmomi::VIM::VirtualDeviceConnectInfo(
144
- :allowGuestControl => true,
145
- :connected => true,
146
- :startConnected => true)
147
- device = RbVmomi::VIM.public_send "#{options['nic_type']}",
148
- :backing => nic_backing_info,
149
- :deviceInfo => RbVmomi::VIM::Description(:label => "Network adapter 1", :summary => options['network_label']),
150
- :key => options['network_adapter_device_key'],
151
- :connectable => connectable
152
- device_spec = RbVmomi::VIM::VirtualDeviceConfigSpec(
153
- :operation => config_spec_operation,
154
- :device => device)
155
- virtual_machine_config_spec.deviceChange = [device_spec]
156
- end
157
- # Options['numCPUs'] or Options['memoryMB']
158
- # Build up the specification for Hardware, for more details see ____________
159
- # https://github.com/rlane/rbvmomi/blob/master/test/test_serialization.rb
160
- # http://www.vmware.com/support/developer/vc-sdk/visdk41pubs/ApiReference/vim.vm.ConfigSpec.html
161
- # FIXME: pad this out with the rest of the useful things in VirtualMachineConfigSpec
162
- virtual_machine_config_spec.numCPUs = options['numCPUs'] if ( options.key?('numCPUs') )
163
- virtual_machine_config_spec.memoryMB = options['memoryMB'] if ( options.key?('memoryMB') )
164
- virtual_machine_config_spec.cpuHotAddEnabled = options['cpuHotAddEnabled'] if ( options.key?('cpuHotAddEnabled') )
165
- virtual_machine_config_spec.memoryHotAddEnabled = options['memoryHotAddEnabled'] if ( options.key?('memoryHotAddEnabled') )
166
- virtual_machine_config_spec.firmware = options['firmware'] if ( options.key?('firmware') )
167
- # Options['customization_spec']
168
- # OLD Options still supported
169
- # * domain <~String> - *REQUIRED* - Sets the server's domain for customization
170
- # * dnsSuffixList <~Array> - Optional - Sets the dns search paths in resolv - Example: ["dev.example.com", "example.com"]
171
- # * time_zone <~String> - Required - Only valid linux options are valid - example: 'America/Denver'
172
- # * ipsettings <~Hash> - Optional - If not set defaults to dhcp
173
- # * ip <~String> - *REQUIRED* Sets the ip address of the VM - Example: 10.0.0.10
174
- # * dnsServerList <~Array> - Optional - Sets the nameservers in resolv - Example: ["10.0.0.2", "10.0.0.3"]
175
- # * gateway <~Array> - Optional - Sets the gateway for the interface - Example: ["10.0.0.1"]
176
- # * subnetMask <~String> - *REQUIRED* - Set the netmask of the interface - Example: "255.255.255.0"
177
- # For other ip settings options see http://www.vmware.com/support/developer/vc-sdk/visdk41pubs/ApiReference/vim.vm.customization.IPSettings.html
178
- #
179
- # Implement complete customization spec as per https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Specification.html
180
- # * encryptionKey <~Array> - Optional, encryption key used to encypt any encrypted passwords
181
- # https://pubs.vmware.com/vsphere-51/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.GlobalIPSettings.html
182
- # * globalIPSettings <~Hash> - REQUIRED
183
- # * dnsServerList <~Array> - Optional, list of dns servers - Example: ["10.0.0.2", "10.0.0.3"]
184
- # * dnsSuffixList <~Array> - Optional, List of name resolution suffixes - Example: ["dev.example.com", "example.com"]
185
- # * identity <~Hash> - REQUIRED, Network identity and settings, similar to Microsoft's Sysprep tool. This is a Sysprep, LinuxPrep, or SysprepText object
186
- # * Sysprep <~Hash> - Optional, representation of a Windows sysprep.inf answer file.
187
- # * guiRunOnce: <~Hash> -Optional, representation of the sysprep GuiRunOnce key
188
- # * commandList: <~Array> - REQUIRED, list of commands to run at first user logon, after guest customization. - Example: ["c:\sysprep\runaftersysprep.cmd", "c:\sysprep\installpuppet.ps1"]
189
- # * guiUnattended: <~Hash> - REQUIRED, representation of the sysprep GuiUnattended key
190
- # * autoLogin: boolean - REQUIRED, Flag to determine whether or not the machine automatically logs on as Administrator.
191
- # * autoLogonCount: int - REQUIRED, specifies the number of times the machine should automatically log on as Administrator
192
- # * password: <~Hash> - REQUIRED, new administrator password for the machine
193
- # * plainText: boolean - REQUIRED, specify whether or not the password is in plain text, rather than encrypted
194
- # * value: <~String> - REQUIRED, password string
195
- # * timeZone: <~int> - REQUIRED, (see here for values https://msdn.microsoft.com/en-us/library/ms912391(v=winembedded.11).aspx)
196
- # * identification: <~Hash> - REQUIRED, representation of the sysprep Identification key
197
- # * domainAdmin: <~String> - Optional, domain user account used for authentication if the virtual machine is joining a domain
198
- # * domainAdminPassword: <~Hash> - Optional, password for the domain user account used for authentication
199
- # * plainText: boolean - REQUIRED, specify whether or not the password is in plain text, rather than encrypted
200
- # * value: <~String> - REQUIRED, password string
201
- # * joinDomain: <~String> - Optional, The domain that the virtual machine should join. If this value is supplied, then domainAdmin and domainAdminPassword must also be supplied
202
- # * joinWorkgroup: <~String> - Optional, The workgroup that the virtual machine should join.
203
- # * licenseFilePrintData: <~Hash> - Optional, representation of the sysprep LicenseFilePrintData key
204
- # * autoMode: <~String> - REQUIRED, Server licensing mode. Two strings are supported: 'perSeat' or 'perServer'
205
- # * autoUsers: <~Int> - Optional, This key is valid only if AutoMode = PerServer. The integer value indicates the number of client licenses
206
- # * userData: <~Hash> - REQUIRED, representation of the sysprep UserData key
207
- # * computerName: <~String> - REQUIRED, The computer name of the (Windows) virtual machine. Will be truncates to 15 characters
208
- # * fullName: <~String> - REQUIRED, User's full name
209
- # * orgName: <~String> - REQUIRED, User's organization
210
- # * productId: <~String> - REQUIRED, serial number for os, ignored if using volume licensed instance
211
- # * LinuxPrep: <~Hash> - Optional, contains machine-wide settings (note the uppercase P)
212
- # * domain: <~String> - REQUIRED, The fully qualified domain name.
213
- # * hostName: <~String> - REQUIRED, the network host name
214
- # * hwClockUTC: <~Boolean> - Optional, Specifies whether the hardware clock is in UTC or local time
215
- # * timeZone: <~String> - Optional, Case sensistive timezone, valid values can be found at https://pubs.vmware.com/vsphere-51/topic/com.vmware.wssdk.apiref.doc/timezone.html
216
- # * SysprepText: <~Hash> - Optional, alternate way to specify the sysprep.inf answer file.
217
- # * value: <~String> - REQUIRED, Text for the sysprep.inf answer file.
218
- # * nicSettingMap: <~Array> - Optional, IP settings that are specific to a particular virtual network adapter
219
- # * Each item in array:
220
- # * adapter: <~Hash> - REQUIRED, IP settings for the associated virtual network adapter
221
- # * dnsDomain: <~String> - Optional, DNS domain suffix for adapter
222
- # * dnsServerList: <~Array> - Optional, list of dns server ip addresses - Example: ["10.0.0.2", "10.0.0.3"]
223
- # * gateway: <~Array> - Optional, list of gateways - Example: ["10.0.0.2", "10.0.0.3"]
224
- # * ip: <~String> - Optional, but required if static IP
225
- # * ipV6Spec: <~Hash> - Optional, IPv^ settings
226
- # * ipAddress: <~String> - Optional, but required if setting static IP
227
- # * gateway: <~Array> - Optional, list of ipv6 gateways
228
- # * netBIOS: <~String> - Optional, NetBIOS settings, if supplied must be one of: disableNetBIOS','enableNetBIOS','enableNetBIOSViaDhcp'
229
- # * primaryWINS: <~String> - Optional, IP address of primary WINS server
230
- # * secondaryWINS: <~String> - Optional, IP address of secondary WINS server
231
- # * subnetMask: <~String> - Optional, subnet mask for adapter
232
- # * macAddress: <~String> - Optional, MAC address of adapter being customized. This cannot be set by the client
233
- # * options: <~Hash> Optional operations, currently only win options have any value
234
- # * changeSID: <~Boolean> - REQUIRED, The customization process should modify the machine's security identifier
235
- # * deleteAccounts: <~Boolean> - REQUIRED, If deleteAccounts is true, then all user accounts are removed from the system
236
- # * reboot: <~String> - Optional, (defaults to reboot), Action to be taken after running sysprep, must be one of: 'noreboot', 'reboot', 'shutdown'
237
- #
238
- if ( options.key?('customization_spec') )
239
- custom_spec = options['customization_spec']
240
-
241
- # backwards compatablity
242
- if custom_spec.key?('domain')
243
- # doing this means the old options quash any new ones passed as well... might not be the best way to do it?
244
- # any 'old' options overwrite the following:
245
- # - custom_spec['identity']['LinuxPrep']
246
- # - custom_spec['globalIPSettings['['dnsServerList']
247
- # - custom_spec['globalIPSettings']['dnsSuffixList']
248
- # - custom_spec['nicSettingMap'][0]['adapter']['ip']
249
- # - custom_spec['nicSettingMap'][0]['adapter']['gateway']
250
- # - custom_spec['nicSettingMap'][0]['adapter']['subnetMask']
251
- # - custom_spec['nicSettingMap'][0]['adapter']['dnsDomain']
252
- # - custom_spec['nicSettingMap'][0]['adapter']['dnsServerList']
253
- #
254
- # we can assume old parameters being passed
255
- cust_hostname = custom_spec['hostname'] || options['name']
256
- custom_spec['identity'] = Hash.new unless custom_spec.key?('identity')
257
- custom_spec['identity']['LinuxPrep'] = {"domain" => custom_spec['domain'], "hostName" => cust_hostname, "timeZone" => custom_spec['time_zone']}
258
-
259
- if custom_spec.key?('ipsettings')
260
- custom_spec['globalIPSettings']=Hash.new unless custom_spec.key?('globalIPSettings')
261
- custom_spec['globalIPSettings']['dnsServerList'] = custom_spec['ipsettings']['dnsServerList'] if custom_spec['ipsettings'].key?('dnsServerList')
262
- custom_spec['globalIPSettings']['dnsSuffixList'] = custom_spec['dnsSuffixList'] || [custom_spec['domain']] if ( custom_spec['dnsSuffixList'] || custom_spec['domain'])
263
- end
264
-
265
- if (custom_spec['ipsettings'].key?('ip') or custom_spec['ipsettings'].key?('gateway') or custom_spec['ipsettings'].key?('subnetMask') or custom_spec['ipsettings'].key?('domain') or custom_spec['ipsettings'].key?('dnsServerList'))
266
- if custom_spec['ipsettings'].key?('ip')
267
- raise ArgumentError, "subnetMask is required for static ip" unless custom_spec["ipsettings"].key?("subnetMask")
268
- end
269
- custom_spec['nicSettingMap']=Array.new unless custom_spec.key?('nicSettingMap')
270
- custom_spec['nicSettingMap'][0]=Hash.new unless custom_spec['nicSettingMap'].length > 0
271
- custom_spec['nicSettingMap'][0]['adapter']=Hash.new unless custom_spec['nicSettingMap'][0].key?('adapter')
272
- custom_spec['nicSettingMap'][0]['adapter']['ip'] = custom_spec['ipsettings']['ip'] if custom_spec['ipsettings'].key?('ip')
273
- custom_spec['nicSettingMap'][0]['adapter']['gateway'] = custom_spec['ipsettings']['gateway'] if custom_spec['ipsettings'].key?('gateway')
274
- custom_spec['nicSettingMap'][0]['adapter']['subnetMask'] = custom_spec['ipsettings']['subnetMask'] if custom_spec['ipsettings'].key?('subnetMask')
275
- custom_spec['nicSettingMap'][0]['adapter']['dnsDomain'] = custom_spec['ipsettings']['domain'] if custom_spec['ipsettings'].key?('domain')
276
- custom_spec['nicSettingMap'][0]['adapter']['dnsServerList'] = custom_spec['ipsettings']['dnsServerList'] if custom_spec['ipsettings'].key?('dnsServerList')
277
- end
278
- end
279
- ### End of backwards compatability
280
-
281
- ## requirements check here ##
282
- raise ArgumentError, "globalIPSettings are required when using Customization Spec" unless custom_spec.key?('globalIPSettings')
283
- raise ArgumentError, "identity is required when using Customization Spec" unless custom_spec.key?('identity')
284
-
285
- # encryptionKey
286
- custom_encryptionKey = custom_spec['encryptionKey'] if custom_spec.key?('encryptionKey')
287
- custom_encryptionKey ||= nil
288
-
289
- # globalIPSettings
290
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.GlobalIPSettings.html
291
- custom_globalIPSettings = RbVmomi::VIM::CustomizationGlobalIPSettings.new()
292
- custom_globalIPSettings.dnsServerList = custom_spec['globalIPSettings']['dnsServerList'] if custom_spec['globalIPSettings'].key?("dnsServerList")
293
- custom_globalIPSettings.dnsSuffixList = custom_spec['globalIPSettings']['dnsSuffixList'] if custom_spec['globalIPSettings'].key?("dnsSuffixList")
294
-
295
- # identity
296
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.IdentitySettings.html
297
- # Accepts the 3 supported CustomizationIdentitySettings Types:
298
- # 1. CustomizationLinuxPrep (LinuxPrep) - note the uppercase P
299
- # 2. CustomizationSysprep (Sysprep)
300
- # 3. CustomizationSysprepText (SysprepText)
301
- # At least one of these is required
302
- #
303
- identity = custom_spec['identity']
304
- if identity.key?("LinuxPrep")
305
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.LinuxPrep.html
306
- # Fields:
307
- # * domain: string **REQUIRED**
308
- # * hostName: string (CustomizationName) **REQUIRED** Will use options['name'] if not provided.
309
- # * hwClockUTC: boolean
310
- # * timeZone: string (https://pubs.vmware.com/vsphere-55/topic/com.vmware.wssdk.apiref.doc/timezone.html)
311
- raise ArgumentError, "domain is required when using LinuxPrep identity" unless identity['LinuxPrep'].key?('domain')
312
- custom_identity = RbVmomi::VIM::CustomizationLinuxPrep(:domain => identity['LinuxPrep']['domain'])
313
- cust_hostname = RbVmomi::VIM::CustomizationFixedName(:name => identity['LinuxPrep']['hostName']) if identity['LinuxPrep'].key?('hostName')
314
- cust_hostname ||= RbVmomi::VIM::CustomizationFixedName(:name => options['name'])
315
- custom_identity.hostName = cust_hostname
316
- custom_identity.hwClockUTC = identity['LinuxPrep']['hwClockUTC'] if identity['LinuxPrep'].key?('hwClockUTC')
317
- custom_identity.timeZone = identity['LinuxPrep']['timeZone'] if identity['LinuxPrep'].key?('timeZone')
318
- elsif identity.key?("Sysprep")
319
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Sysprep.html
320
- # Fields:
321
- # * guiRunOnce: CustomizationGuiRunOnce
322
- # * guiUnattended: CustomizationGuiUnattended **REQUIRED**
323
- # * identification: CustomizationIdentification **REQUIRED**
324
- # * licenseFilePrintData: CustomizationLicenseFilePrintData
325
- # * userData: CustomizationUserData **REQUIRED**
326
- #
327
- raise ArgumentError, "guiUnattended is required when using Sysprep identity" unless identity['Sysprep'].key?('guiUnattended')
328
- raise ArgumentError, "identification is required when using Sysprep identity" unless identity['Sysprep'].key?('identification')
329
- raise ArgumentError, "userData is required when using Sysprep identity" unless identity['Sysprep'].key?('userData')
330
- if identity['Sysprep']['guiRunOnce']
331
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.GuiRunOnce.html
332
- # Fields:
333
- # * commandList: array of string **REQUIRED***
334
- #
335
- raise ArgumentError, "commandList is required when using Sysprep identity and guiRunOnce" unless identity['Sysprep']['guiRunOnce'].key?('commandList')
336
- cust_guirunonce = RbVmomi::VIM.CustomizationGuiRunOnce( :commandList => identity['Sysprep']['guiRunOnce']['commandList'] )
337
- end
338
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.GuiUnattended.html
339
- # Fields:
340
- # * autoLogin: boolean **REQUIRED**
341
- # * autoLogonCount: int **REQUIRED**
342
- # * timeZone: int (see here for values https://msdn.microsoft.com/en-us/library/ms912391(v=winembedded.11).aspx) **REQUIRED**
343
- # * password: CustomizationPassword
344
- raise ArgumentError, "guiUnattended->autoLogon is required when using Sysprep identity" unless identity['Sysprep']['guiUnattended'].key?('autoLogon')
345
- raise ArgumentError, "guiUnattended->autoLogonCount is required when using Sysprep identity" unless identity['Sysprep']['guiUnattended'].key?('autoLogonCount')
346
- raise ArgumentError, "guiUnattended->timeZone is required when using Sysprep identity" unless identity['Sysprep']['guiUnattended'].key?('timeZone')
347
- custom_guiUnattended = RbVmomi::VIM.CustomizationGuiUnattended(
348
- :autoLogon => identity['Sysprep']['guiUnattended']['autoLogon'],
349
- :autoLogonCount => identity['Sysprep']['guiUnattended']['autoLogonCount'],
350
- :timeZone => identity['Sysprep']['guiUnattended']['timeZone']
351
- )
352
- if identity['Sysprep']['guiUnattended']['password']
353
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Password.html
354
- # Fields:
355
- # * plainText: boolean **REQUIRED**
356
- # * value: string **REQUIRED**
357
- raise ArgumentError, "guiUnattended->password->plainText is required when using Sysprep identity and guiUnattended -> password" unless identity['Sysprep']['guiUnattended']['password'].key?('plainText')
358
- raise ArgumentError, "guiUnattended->password->value is required when using Sysprep identity and guiUnattended -> password" unless identity['Sysprep']['guiUnattended']['password'].key?('value')
359
- custom_guiUnattended.password = RbVmomi::VIM.CustomizationPassword(
360
- :plainText => identity['Sysprep']['guiUnattended']['password']['plainText'],
361
- :value => identity['Sysprep']['guiUnattended']['password']['value']
362
- )
363
- end
364
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Identification.html
365
- # Fields:
366
- # * domainAdmin: string
367
- # * domainAdminPassword: CustomizationPassword
368
- # * joinDomain: string *If supplied domainAdmin and domainAdminPassword must be set
369
- # * joinWorkgroup: string *If supplied, joinDomain, domainAdmin and domainAdminPassword will be ignored
370
- custom_identification = RbVmomi::VIM.CustomizationIdentification()
371
- if identity['Sysprep']['identification'].key?('joinWorkgroup')
372
- custom_identification.joinWorkgroup = identity['Sysprep']['identification']['joinWorkgroup']
373
- elsif identity['Sysprep']['identification'].key?('joinDomain')
374
- raise ArgumentError, "identification->domainAdmin is required when using Sysprep identity and identification -> joinDomain" unless identity['Sysprep']['identification'].key?('domainAdmin')
375
- raise ArgumentError, "identification->domainAdminPassword is required when using Sysprep identity and identification -> joinDomain" unless identity['Sysprep']['identification'].key?('domainAdmin')
376
- raise ArgumentError, "identification->domainAdminPassword->plainText is required when using Sysprep identity and identification -> joinDomain" unless identity['Sysprep']['identification']['domainAdminPassword'].key?('plainText')
377
- raise ArgumentError, "identification->domainAdminPassword->value is required when using Sysprep identity and identification -> joinDomain" unless identity['Sysprep']['identification']['domainAdminPassword'].key?('value')
378
- custom_identification.joinDomain = identity['Sysprep']['identification']['joinDomain']
379
- custom_identification.domainAdmin = identity['Sysprep']['identification']['domainAdmin']
380
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Password.html
381
- # Fields:
382
- # * plainText: boolean **REQUIRED**
383
- # * value: string **REQUIRED**
384
- custom_identification.domainAdminPassword = RbVmomi::VIM.CustomizationPassword(
385
- :plainText => identity['Sysprep']['identification']['domainAdminPassword']['plainText'],
386
- :value => identity['Sysprep']['identification']['domainAdminPassword']['value']
387
- )
388
- else
389
- raise ArgumentError, "No valid Indentification found, valid values are 'joinWorkgroup' and 'joinDomain'"
390
- end
391
- if identity['Sysprep'].key?('licenseFilePrintData')
392
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.LicenseFilePrintData.html
393
- # Fields:
394
- # * autoMode: string (CustomizationLicenseDataMode) ** REQUIRED **, valid strings are: 'perSeat' or 'perServer'
395
- # * autoUsers: int (valid only if AutoMode = PerServer)
396
- raise ArgumentError, "licenseFilePrintData->autoMode is required when using Sysprep identity and licenseFilePrintData" unless identity['Sysprep']['licenseFilePrintData'].key?('autoMode')
397
- raise ArgumentError, "Unsupported autoMode, supported modes are : 'perSeat' or 'perServer'" unless ['perSeat', 'perServer'].include? identity['Sysprep']['licenseFilePrintData']['autoMode']
398
- custom_licenseFilePrintData = RbVmomi::VIM.CustomizationLicenseFilePrintData(
399
- :autoMode => RbVmomi::VIM.CustomizationLicenseDataMode(identity['Sysprep']['licenseFilePrintData']['autoMode'])
400
- )
401
- if identity['Sysprep']['licenseFilePrintData'].key?('autoUsers')
402
- custom_licenseFilePrintData.autoUsers = identity['Sysprep']['licenseFilePrintData']['autoUsers'] if identity['Sysprep']['licenseFilePrintData']['autoMode'] == "PerServer"
403
- end
404
- end
405
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.UserData.html
406
- # Fields:
407
- # * computerName: string (CustomizationFixedName) **REQUIRED**
408
- # * fullName: string **REQUIRED**
409
- # * orgName: string **REQUIRED**
410
- # * productID: string **REQUIRED**
411
- raise ArgumentError, "userData->computerName is required when using Sysprep identity" unless identity['Sysprep']['userData'].key?('computerName')
412
- raise ArgumentError, "userData->fullName is required when using Sysprep identity" unless identity['Sysprep']['userData'].key?('fullName')
413
- raise ArgumentError, "userData->orgName is required when using Sysprep identity" unless identity['Sysprep']['userData'].key?('orgName')
414
- raise ArgumentError, "userData->productId is required when using Sysprep identity" unless identity['Sysprep']['userData'].key?('productId')
415
- custom_userData = RbVmomi::VIM.CustomizationUserData(
416
- :fullName => identity['Sysprep']['userData']['fullName'],
417
- :orgName => identity['Sysprep']['userData']['orgName'],
418
- :productId => identity['Sysprep']['userData']['productId'],
419
- :computerName => RbVmomi::VIM.CustomizationFixedName(:name => identity['Sysprep']['userData']['computerName'])
420
- )
421
-
422
- custom_identity = RbVmomi::VIM::CustomizationSysprep(
423
- :guiUnattended => custom_guiUnattended,
424
- :identification => custom_identification,
425
- :userData => custom_userData
426
- )
427
- custom_identity.guiRunOnce = cust_guirunonce if defined?(cust_guirunonce)
428
- custom_identity.licenseFilePrintData = custom_licenseFilePrintData if defined?(custom_licenseFilePrintData)
429
- elsif identity.key?("SysprepText")
430
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.SysprepText.html
431
- # Fields:
432
- # * value: string **REQUIRED**
433
- raise ArgumentError, "SysprepText -> value is required when using SysprepText identity" unless identity['SysprepText'].key?('value')
434
- custom_identity = RbVmomi::VIM::CustomizationSysprepText(:value => identity['SysprepText']['value'])
435
- else
436
- raise ArgumentError, "At least one of the following valid identities must be supplied: LinuxPrep, Sysprep, SysprepText"
437
- end
438
-
439
- if custom_spec.key?("nicSettingMap")
440
- # custom_spec['nicSettingMap'] is an array of adapater mappings:
441
- # custom_spec['nicSettingMap'][0]['macAddress']
442
- # custom_spec['nicSettingMap'][0]['adapter']['ip']
443
- #https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.AdapterMapping.html
444
- # Fields:
445
- # * adapter: CustomizationIPSettings **REQUIRED**
446
- # * macAddress: string
447
- raise ArgumentError, "At least one nicSettingMap is required when using nicSettingMap" unless custom_spec['nicSettingMap'].length > 0
448
- raise ArgumentError, "Adapter is required when using nicSettingMap" unless custom_spec['nicSettingMap'][0].key?('adapter')
449
-
450
- custom_nicSettingMap = []
451
- # need to go through array here for each apapter
452
- custom_spec['nicSettingMap'].each do | nic |
453
- # https://pubs.vmware.com/vsphere-55/index.jsp?topic=%2Fcom.vmware.wssdk.apiref.doc%2Fvim.vm.customization.IPSettings.html
454
- # Fields:
455
- # * dnsDomain: string
456
- # * gateway: array of string
457
- # * ip: CustomizationIpGenerator (string) **REQUIRED IF Assigning Static IP***
458
- # * ipV6Spec: CustomizationIPSettingsIpV6AddressSpec
459
- # * netBIOS: CustomizationNetBIOSMode (string)
460
- # * primaryWINS: string
461
- # * secondaryWINS: string
462
- # * subnetMask: string - Required if assigning static IP
463
- if nic['adapter'].key?('ip')
464
- raise ArgumentError, "SubnetMask is required when assigning static IP when using nicSettingMap -> Adapter" unless nic['adapter'].key?('subnetMask')
465
- custom_ip = RbVmomi::VIM.CustomizationFixedIp(:ipAddress => nic['adapter']['ip'])
466
- else
467
- custom_ip = RbVmomi::VIM::CustomizationDhcpIpGenerator.new()
468
- end
469
- custom_adapter = RbVmomi::VIM.CustomizationIPSettings(:ip => custom_ip)
470
- custom_adapter.dnsDomain = nic['adapter']['dnsDomain'] if nic['adapter'].key?('dnsDomain')
471
- custom_adapter.dnsServerList = nic['adapter']['dnsServerList'] if nic['adapter'].key?('dnsServerList')
472
- custom_adapter.gateway = nic['adapter']['gateway'] if nic['adapter'].key?('gateway')
473
- if nic['adapter'].key?('ipV6Spec')
474
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.IPSettings.IpV6AddressSpec.html
475
- # Fields:
476
- # * gateway: array of string
477
- # * ip: CustomizationIpV6Generator[] **Required if setting static IP **
478
- if nic['adapter']['ipV6Spec'].key?('ipAddress')
479
- raise ArgumentError, "SubnetMask is required when assigning static IPv6 when using nicSettingMap -> Adapter -> ipV6Spec" unless nic['adapter']['ipV6Spec'].key?('subnetMask')
480
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.FixedIpV6.html
481
- # * ipAddress: string **REQUIRED**
482
- # * subnetMask: int **REQUIRED**
483
- custom_ipv6 = RbVmomi::VIM.CustomizationFixedIpV6(
484
- :ipAddress => nic['adapter']['ipV6Spec']['ipAddress'],
485
- :subnetMask => nic['adapter']['ipV6Spec']['subnetMask']
486
- )
487
- else
488
- custom_ipv6 = RbVmomi::VIM::CustomizationDhcpIpV6Generator.new()
489
- end
490
- custom_ipv6Spec = RbVmomo::VIM.CustomizationIPSettingsIpV6AddressSpec(:ip => custom_ipv6)
491
- custom_ipv6Spec.gateway = nic['adapter']['ipV6Spec']['gateway'] if nic['adapter']['ipV6Spec'].key?('gateway')
492
- custom_adapter.ipV6Spec = custom_ipv6Spec
493
- end
494
- if nic['adapter'].key?('netBIOS')
495
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.IPSettings.NetBIOSMode.html
496
- # Fields:
497
- # netBIOS: string matching: 'disableNetBIOS','enableNetBIOS' or 'enableNetBIOSViaDhcp' ** REQUIRED **
498
- #
499
- raise ArgumentError, "Unsupported NetBIOSMode, supported modes are : 'disableNetBIOS','enableNetBIOS' or 'enableNetBIOSViaDhcp'" unless ['disableNetBIOS','enableNetBIOS','enableNetBIOSViaDhcp'].include? nic['adapter']['netBIOS']
500
- custom_adapter.netBIOS = RbVmomi::VIM.CustomizationNetBIOSMode(nic['adapter']['netBIOS'])
501
- end
502
- custom_adapter.primaryWINS = nic['adapter']['primaryWINS'] if nic['adapter'].key?('primaryWINS')
503
- custom_adapter.secondaryWINS = nic['adapter']['secondaryWINS'] if nic['adapter'].key?('secondaryWINS')
504
- custom_adapter.subnetMask = nic['adapter']['subnetMask'] if nic['adapter'].key?('subnetMask')
505
-
506
- custom_adapter_mapping = RbVmomi::VIM::CustomizationAdapterMapping(:adapter => custom_adapter)
507
- custom_adapter_mapping.macAddress = nic['macAddress'] if nic.key?('macAddress')
508
-
509
- # build the adapters array, creates it if not already created, otherwise appends to it
510
- custom_nicSettingMap << custom_adapter_mapping
511
- end
512
- end
513
- custom_nicSettingMap = nil if custom_nicSettingMap.length < 1
514
-
515
- if custom_spec.key?("options")
516
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Options.html
517
- # this currently doesn't have any Linux options, just windows
518
- # Fields:
519
- # * changeSID: boolean **REQUIRED**
520
- # * deleteAccounts: boolean **REQUIRED** **note deleteAccounts is deprecated as of VI API 2.5 so can be ignored
521
- # * reboot: CustomizationSysprepRebootOption: (string) one of following 'noreboot', reboot' or 'shutdown' (defaults to reboot)
522
- raise ArgumentError, "changeSID id required when using Windows Options" unless custom_spec['options'].key?('changeSID')
523
- raise ArgumentError, "deleteAccounts id required when using Windows Options" unless custom_spec['options'].key?('deleteAccounts')
524
- custom_options = RbVmomi::VIM::CustomizationWinOptions(
525
- :changeSID => custom_spec['options']['changeSID'],
526
- :deleteAccounts => custom_spec['options']['deleteAccounts']
527
- )
528
- if custom_spec['options'].key?('reboot')
529
- raise ArgumentError, "Unsupported reboot option, supported options are : 'noreboot', 'reboot' or 'shutdown'" unless ['noreboot','reboot','shutdown'].include? custom_spec['options']['reboot']
530
- custom_options.reboot = RBVmomi::VIM.CustomizationSysprepRebootOption(custom_spec['options']['reboot'])
531
- end
532
- end
533
- custom_options ||=nil
534
-
535
- # https://pubs.vmware.com/vsphere-55/index.jsp#com.vmware.wssdk.apiref.doc/vim.vm.customization.Specification.html
536
- customization_spec = RbVmomi::VIM::CustomizationSpec(
537
- :globalIPSettings => custom_globalIPSettings,
538
- :identity => custom_identity
539
- )
540
- customization_spec.encryptionKey = custom_encryptionKey if defined?(custom_encryptionKey)
541
- customization_spec.nicSettingMap = custom_nicSettingMap if defined?(custom_nicSettingMap)
542
- customization_spec.options = custom_options if defined?(custom_options)
543
-
544
- end
545
- customization_spec ||= nil
546
-
547
- relocation_spec=nil
548
- if ( options['linked_clone'] )
549
- # cribbed heavily from the rbvmomi clone_vm.rb
550
- # this chunk of code reconfigures the disk of the clone source to be read only,
551
- # and then creates a delta disk on top of that, this is required by the API in order to create
552
- # linked clondes
553
- disks = vm_mob_ref.config.hardware.device.select do |vm_device|
554
- vm_device.class == RbVmomi::VIM::VirtualDisk
555
- end
556
- disks.select{|vm_device| vm_device.backing.parent == nil}.each do |disk|
557
- disk_spec = {
558
- :deviceChange => [
559
- {
560
- :operation => :remove,
561
- :device => disk
562
- },
563
- {
564
- :operation => :add,
565
- :fileOperation => :create,
566
- :device => disk.dup.tap{|disk_backing|
567
- disk_backing.backing = disk_backing.backing.dup;
568
- disk_backing.backing.fileName = "[#{disk.backing.datastore.name}]";
569
- disk_backing.backing.parent = disk.backing
570
- }
571
- }
572
- ]
573
- }
574
- vm_mob_ref.ReconfigVM_Task(:spec => disk_spec).wait_for_completion
575
- end
576
- # Next, create a Relocation Spec instance
577
- relocation_spec = RbVmomi::VIM.VirtualMachineRelocateSpec(:datastore => datastore_obj,
578
- :pool => resource_pool,
579
- :diskMoveType => :moveChildMostDiskBacking)
580
- else
581
- relocation_spec = RbVmomi::VIM.VirtualMachineRelocateSpec(:datastore => datastore_obj,
582
- :pool => resource_pool,
583
- :transform => options['transform'] || 'sparse')
584
- end
585
- # And the clone specification
586
- clone_spec = RbVmomi::VIM.VirtualMachineCloneSpec(:location => relocation_spec,
587
- :config => virtual_machine_config_spec,
588
- :customization => customization_spec,
589
- :powerOn => options.key?('power_on') ? options['power_on'] : true,
590
- :template => false)
591
-
592
- # Perform the actual Clone Task
593
- task = vm_mob_ref.CloneVM_Task(:folder => dest_folder,
594
- :name => options['name'],
595
- :spec => clone_spec)
596
- # Waiting for the VM to complete allows us to get the VirtulMachine
597
- # object of the new machine when it's done. It is HIGHLY recommended
598
- # to set 'wait' => true if your app wants to wait. Otherwise, you're
599
- # going to have to reload the server model over and over which
600
- # generates a lot of time consuming API calls to vmware.
601
- if options.fetch('wait', true) then
602
- # REVISIT: It would be awesome to call a block passed to this
603
- # request to notify the application how far along in the process we
604
- # are. I'm thinking of updating a progress bar, etc...
605
- new_vm = task.wait_for_completion
606
- else
607
- tries = 0
608
- new_vm = begin
609
- # Try and find the new VM (folder.find is quite efficient)
610
- dest_folder.find(options['name'], RbVmomi::VIM::VirtualMachine) or raise Fog::Vsphere::Errors::NotFound
611
- rescue Fog::Vsphere::Errors::NotFound
612
- tries += 1
613
- if tries <= 10 then
614
- sleep 15
615
- retry
616
- end
617
- nil
618
- end
619
- end
620
-
621
- # Return hash
622
- {
623
- 'vm_ref' => new_vm ? new_vm._ref : nil,
624
- 'new_vm' => new_vm ? convert_vm_mob_ref_to_attr_hash(new_vm) : nil,
625
- 'task_ref' => task._ref
626
- }
627
- end
628
- end
629
-
630
- class Mock
631
- include Shared
632
- def vm_clone(options = {})
633
- # Option handling TODO Needs better method of checking
634
- options = vm_clone_check_options(options)
635
- notfound = lambda { raise Fog::Compute::Vsphere::NotFound, "Could not find VM template" }
636
- template = list_virtual_machines.find(notfound) do |vm|
637
- vm['name'] == options['template_path'].split("/")[-1]
638
- end
639
-
640
- # generate a random id
641
- id = [8,4,4,4,12].map{|i| Fog::Mock.random_hex(i)}.join("-")
642
- new_vm = template.clone.merge({
643
- "name" => options['name'],
644
- "id" => id,
645
- "instance_uuid" => id,
646
- "path" => "/Datacenters/#{options['datacenter']}/#{options['dest_folder'] ? options['dest_folder']+"/" : ""}#{options['name']}"
647
- })
648
- self.data[:servers][id] = new_vm
649
-
650
- {
651
- 'vm_ref' => "vm-#{Fog::Mock.random_numbers(3)}",
652
- 'new_vm' => new_vm,
653
- 'task_ref' => "task-#{Fog::Mock.random_numbers(4)}",
654
- }
655
- end
656
- end
657
- end
658
- end
659
- end