fog 1.31.0 → 1.37.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.travis.yml +12 -24
- data/CHANGELOG.md +354 -0
- data/CONTRIBUTING.md +1 -1
- data/Gemfile +1 -0
- data/README.md +4 -20
- data/Rakefile +7 -7
- data/fog.gemspec +14 -9
- data/lib/fog/bin.rb +1 -0
- data/lib/fog/cloudstack/models/compute/network.rb +1 -0
- data/lib/fog/digitalocean/compute_v2.rb +109 -0
- data/lib/fog/digitalocean/examples/getting_started.md +24 -48
- data/lib/fog/digitalocean/models/compute/server.rb +0 -1
- data/lib/fog/digitalocean/models/compute_v2/flavor.rb +17 -0
- data/lib/fog/digitalocean/models/compute_v2/flavors.rb +21 -0
- data/lib/fog/digitalocean/models/compute_v2/image.rb +25 -0
- data/lib/fog/digitalocean/models/compute_v2/images.rb +36 -0
- data/lib/fog/digitalocean/models/compute_v2/region.rb +13 -0
- data/lib/fog/digitalocean/models/compute_v2/regions.rb +21 -0
- data/lib/fog/digitalocean/models/compute_v2/server.rb +170 -0
- data/lib/fog/digitalocean/models/compute_v2/servers.rb +39 -0
- data/lib/fog/digitalocean/models/compute_v2/ssh_key.rb +31 -0
- data/lib/fog/digitalocean/models/compute_v2/ssh_keys.rb +35 -0
- data/lib/fog/digitalocean/requests/compute_v2/change_kernel.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/convert_to_snapshot.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/create_server.rb +93 -0
- data/lib/fog/digitalocean/requests/compute_v2/create_ssh_key.rb +49 -0
- data/lib/fog/digitalocean/requests/compute_v2/delete_server.rb +28 -0
- data/lib/fog/digitalocean/requests/compute_v2/delete_ssh_key.rb +32 -0
- data/lib/fog/digitalocean/requests/compute_v2/disable_backups.rb +45 -0
- data/lib/fog/digitalocean/requests/compute_v2/enable_ipv6.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/enable_private_networking.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/get_droplet_action.rb +36 -0
- data/lib/fog/digitalocean/requests/compute_v2/get_image_details.rb +42 -0
- data/lib/fog/digitalocean/requests/compute_v2/get_server_details.rb +84 -0
- data/lib/fog/digitalocean/requests/compute_v2/get_ssh_key.rb +34 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_droplet_actions.rb +38 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_flavors.rb +131 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_images.rb +50 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_regions.rb +94 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_servers.rb +28 -0
- data/lib/fog/digitalocean/requests/compute_v2/list_ssh_keys.rb +31 -0
- data/lib/fog/digitalocean/requests/compute_v2/password_reset.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/power_cycle.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/power_off.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/power_on.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/reboot_server.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/rebuild.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/rename.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/resize.rb +48 -0
- data/lib/fog/digitalocean/requests/compute_v2/restore.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/shutdown.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/snapshot.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/transfer_image.rb +44 -0
- data/lib/fog/digitalocean/requests/compute_v2/update_ssh_key.rb +46 -0
- data/lib/fog/digitalocean/requests/compute_v2/upgrade.rb +44 -0
- data/lib/fog/digitalocean/service.rb +51 -0
- data/lib/fog/glesys/models/compute/server.rb +0 -1
- data/lib/fog/joyent/compute.rb +6 -1
- data/lib/fog/linode/compute.rb +3 -0
- data/lib/fog/linode/models/compute/data_center.rb +1 -0
- data/lib/fog/linode/models/compute/flavor.rb +3 -0
- data/lib/fog/linode/models/compute/flavors.rb +8 -1
- data/lib/fog/linode/models/compute/image.rb +2 -0
- data/lib/fog/linode/models/compute/images.rb +2 -1
- data/lib/fog/linode/models/compute/kernel.rb +3 -0
- data/lib/fog/linode/models/compute/kernels.rb +14 -8
- data/lib/fog/linode/models/compute/node_balancer_flavor.rb +13 -0
- data/lib/fog/linode/models/compute/node_balancer_flavors.rb +27 -0
- data/lib/fog/linode/requests/compute/avail_datacenters.rb +8 -7
- data/lib/fog/linode/requests/compute/avail_kernels.rb +17 -18
- data/lib/fog/linode/requests/compute/avail_linodeplans.rb +4 -2
- data/lib/fog/linode/requests/compute/avail_nodebalancers.rb +42 -0
- data/lib/fog/linode/requests/compute/avail_stackscripts.rb +6 -11
- data/lib/fog/opennebula/models/compute/flavor.rb +13 -13
- data/lib/fog/opennebula/requests/compute/template_pool.rb +14 -11
- data/lib/fog/openstack/baremetal.rb +20 -82
- data/lib/fog/openstack/common.rb +46 -0
- data/lib/fog/openstack/compute.rb +50 -122
- data/lib/fog/openstack/core.rb +304 -124
- data/lib/fog/openstack/docs/compute.md +1 -1
- data/lib/fog/openstack/identity.rb +6 -48
- data/lib/fog/openstack/identity_v2.rb +22 -86
- data/lib/fog/openstack/identity_v3.rb +21 -92
- data/lib/fog/openstack/image.rb +11 -207
- data/lib/fog/openstack/image_v1.rb +148 -0
- data/lib/fog/openstack/image_v2.rb +142 -0
- data/lib/fog/openstack/metering.rb +16 -76
- data/lib/fog/openstack/models/baremetal/chassis.rb +3 -14
- data/lib/fog/openstack/models/baremetal/chassis_collection.rb +12 -6
- data/lib/fog/openstack/models/baremetal/driver.rb +2 -8
- data/lib/fog/openstack/models/baremetal/drivers.rb +4 -4
- data/lib/fog/openstack/models/baremetal/node.rb +3 -14
- data/lib/fog/openstack/models/baremetal/nodes.rb +13 -7
- data/lib/fog/openstack/models/baremetal/port.rb +3 -14
- data/lib/fog/openstack/models/baremetal/ports.rb +12 -6
- data/lib/fog/openstack/models/collection.rb +45 -0
- data/lib/fog/openstack/models/compute/address.rb +2 -2
- data/lib/fog/openstack/models/compute/addresses.rb +4 -4
- data/lib/fog/openstack/models/compute/aggregate.rb +58 -0
- data/lib/fog/openstack/models/compute/aggregates.rb +26 -0
- data/lib/fog/openstack/models/compute/availability_zone.rb +14 -0
- data/lib/fog/openstack/models/compute/availability_zones.rb +22 -0
- data/lib/fog/openstack/models/compute/flavor.rb +2 -8
- data/lib/fog/openstack/models/compute/flavors.rb +9 -4
- data/lib/fog/openstack/models/compute/host.rb +1 -1
- data/lib/fog/openstack/models/compute/hosts.rb +5 -5
- data/lib/fog/openstack/models/compute/image.rb +2 -8
- data/lib/fog/openstack/models/compute/images.rb +4 -4
- data/lib/fog/openstack/models/compute/key_pair.rb +2 -2
- data/lib/fog/openstack/models/compute/key_pairs.rb +5 -4
- data/lib/fog/openstack/models/compute/metadata.rb +3 -2
- data/lib/fog/openstack/models/compute/metadatum.rb +2 -2
- data/lib/fog/openstack/models/compute/network.rb +2 -2
- data/lib/fog/openstack/models/compute/networks.rb +3 -2
- data/lib/fog/openstack/models/compute/security_group.rb +2 -2
- data/lib/fog/openstack/models/compute/security_group_rule.rb +2 -2
- data/lib/fog/openstack/models/compute/security_group_rules.rb +2 -2
- data/lib/fog/openstack/models/compute/security_groups.rb +4 -4
- data/lib/fog/openstack/models/compute/server.rb +26 -2
- data/lib/fog/openstack/models/compute/servers.rb +10 -4
- data/lib/fog/openstack/models/compute/service.rb +2 -8
- data/lib/fog/openstack/models/compute/services.rb +9 -6
- data/lib/fog/openstack/models/compute/snapshot.rb +2 -8
- data/lib/fog/openstack/models/compute/snapshots.rb +17 -4
- data/lib/fog/openstack/models/compute/tenant.rb +2 -2
- data/lib/fog/openstack/models/compute/tenants.rb +3 -4
- data/lib/fog/openstack/models/compute/volume.rb +2 -8
- data/lib/fog/openstack/models/compute/volumes.rb +17 -4
- data/lib/fog/openstack/models/identity_v2/ec2_credential.rb +3 -9
- data/lib/fog/openstack/models/identity_v2/ec2_credentials.rb +7 -6
- data/lib/fog/openstack/models/identity_v2/role.rb +3 -3
- data/lib/fog/openstack/models/identity_v2/roles.rb +5 -5
- data/lib/fog/openstack/models/identity_v2/tenant.rb +5 -9
- data/lib/fog/openstack/models/identity_v2/tenants.rb +5 -5
- data/lib/fog/openstack/models/identity_v2/user.rb +8 -10
- data/lib/fog/openstack/models/identity_v2/users.rb +7 -5
- data/lib/fog/openstack/models/identity_v3/domain.rb +11 -9
- data/lib/fog/openstack/models/identity_v3/domains.rb +24 -10
- data/lib/fog/openstack/models/identity_v3/endpoint.rb +5 -9
- data/lib/fog/openstack/models/identity_v3/endpoints.rb +5 -6
- data/lib/fog/openstack/models/identity_v3/group.rb +5 -9
- data/lib/fog/openstack/models/identity_v3/groups.rb +5 -5
- data/lib/fog/openstack/models/identity_v3/os_credential.rb +3 -3
- data/lib/fog/openstack/models/identity_v3/os_credentials.rb +5 -5
- data/lib/fog/openstack/models/identity_v3/policies.rb +5 -5
- data/lib/fog/openstack/models/identity_v3/policy.rb +5 -9
- data/lib/fog/openstack/models/identity_v3/project.rb +16 -8
- data/lib/fog/openstack/models/identity_v3/projects.rb +39 -13
- data/lib/fog/openstack/models/identity_v3/role.rb +3 -8
- data/lib/fog/openstack/models/identity_v3/role_assignment.rb +3 -3
- data/lib/fog/openstack/models/identity_v3/role_assignments.rb +10 -7
- data/lib/fog/openstack/models/identity_v3/roles.rb +11 -7
- data/lib/fog/openstack/models/identity_v3/service.rb +3 -3
- data/lib/fog/openstack/models/identity_v3/services.rb +5 -5
- data/lib/fog/openstack/models/identity_v3/token.rb +3 -3
- data/lib/fog/openstack/models/identity_v3/tokens.rb +4 -3
- data/lib/fog/openstack/models/identity_v3/user.rb +3 -9
- data/lib/fog/openstack/models/identity_v3/users.rb +4 -4
- data/lib/fog/openstack/models/image_v1/image.rb +78 -0
- data/lib/fog/openstack/models/image_v1/images.rb +70 -0
- data/lib/fog/openstack/models/image_v2/image.rb +149 -0
- data/lib/fog/openstack/models/image_v2/images.rb +67 -0
- data/lib/fog/openstack/models/metering/resource.rb +2 -7
- data/lib/fog/openstack/models/metering/resources.rb +3 -3
- data/lib/fog/openstack/models/model.rb +44 -0
- data/lib/fog/openstack/models/network/floating_ip.rb +2 -7
- data/lib/fog/openstack/models/network/floating_ips.rb +3 -3
- data/lib/fog/openstack/models/network/lb_health_monitor.rb +2 -12
- data/lib/fog/openstack/models/network/lb_health_monitors.rb +3 -3
- data/lib/fog/openstack/models/network/lb_member.rb +2 -12
- data/lib/fog/openstack/models/network/lb_members.rb +3 -3
- data/lib/fog/openstack/models/network/lb_pool.rb +2 -12
- data/lib/fog/openstack/models/network/lb_pools.rb +3 -3
- data/lib/fog/openstack/models/network/lb_vip.rb +2 -12
- data/lib/fog/openstack/models/network/lb_vips.rb +3 -3
- data/lib/fog/openstack/models/network/network.rb +2 -12
- data/lib/fog/openstack/models/network/networks.rb +3 -3
- data/lib/fog/openstack/models/network/port.rb +3 -13
- data/lib/fog/openstack/models/network/ports.rb +3 -3
- data/lib/fog/openstack/models/network/router.rb +2 -13
- data/lib/fog/openstack/models/network/routers.rb +3 -3
- data/lib/fog/openstack/models/network/security_group.rb +2 -2
- data/lib/fog/openstack/models/network/security_group_rule.rb +2 -2
- data/lib/fog/openstack/models/network/security_group_rules.rb +3 -3
- data/lib/fog/openstack/models/network/security_groups.rb +3 -3
- data/lib/fog/openstack/models/network/subnet.rb +3 -14
- data/lib/fog/openstack/models/network/subnets.rb +3 -3
- data/lib/fog/openstack/models/orchestration/event.rb +2 -2
- data/lib/fog/openstack/models/orchestration/events.rb +11 -8
- data/lib/fog/openstack/models/orchestration/resource.rb +2 -2
- data/lib/fog/openstack/models/orchestration/resource_schemas.rb +2 -2
- data/lib/fog/openstack/models/orchestration/resources.rb +5 -4
- data/lib/fog/openstack/models/orchestration/stack.rb +10 -9
- data/lib/fog/openstack/models/orchestration/stacks.rb +13 -4
- data/lib/fog/openstack/models/orchestration/template.rb +2 -2
- data/lib/fog/openstack/models/orchestration/templates.rb +2 -1
- data/lib/fog/openstack/models/planning/plan.rb +2 -13
- data/lib/fog/openstack/models/planning/plans.rb +4 -4
- data/lib/fog/openstack/models/planning/role.rb +2 -8
- data/lib/fog/openstack/models/planning/roles.rb +4 -4
- data/lib/fog/openstack/models/storage/directories.rb +5 -5
- data/lib/fog/openstack/models/storage/directory.rb +2 -2
- data/lib/fog/openstack/models/storage/file.rb +24 -2
- data/lib/fog/openstack/models/storage/files.rb +7 -6
- data/lib/fog/openstack/models/volume/availability_zone.rb +10 -0
- data/lib/fog/openstack/models/volume/availability_zones.rb +14 -0
- data/lib/fog/openstack/models/volume/transfer.rb +28 -0
- data/lib/fog/openstack/models/volume/transfers.rb +35 -0
- data/lib/fog/openstack/models/volume/volume.rb +14 -24
- data/lib/fog/openstack/models/volume/volume_type.rb +25 -9
- data/lib/fog/openstack/models/volume/volume_types.rb +3 -7
- data/lib/fog/openstack/models/volume/volumes.rb +15 -8
- data/lib/fog/openstack/models/volume_v1/availability_zone.rb +15 -0
- data/lib/fog/openstack/models/volume_v1/availability_zones.rb +16 -0
- data/lib/fog/openstack/models/volume_v1/transfer.rb +18 -0
- data/lib/fog/openstack/models/volume_v1/transfers.rb +16 -0
- data/lib/fog/openstack/models/volume_v1/volume.rb +26 -0
- data/lib/fog/openstack/models/volume_v1/volume_type.rb +16 -0
- data/lib/fog/openstack/models/volume_v1/volume_types.rb +16 -0
- data/lib/fog/openstack/models/volume_v1/volumes.rb +16 -0
- data/lib/fog/openstack/models/volume_v2/availability_zone.rb +15 -0
- data/lib/fog/openstack/models/volume_v2/availability_zones.rb +16 -0
- data/lib/fog/openstack/models/volume_v2/transfer.rb +19 -0
- data/lib/fog/openstack/models/volume_v2/transfers.rb +16 -0
- data/lib/fog/openstack/models/volume_v2/volume.rb +27 -0
- data/lib/fog/openstack/models/volume_v2/volume_type.rb +16 -0
- data/lib/fog/openstack/models/volume_v2/volume_types.rb +16 -0
- data/lib/fog/openstack/models/volume_v2/volumes.rb +16 -0
- data/lib/fog/openstack/network.rb +24 -102
- data/lib/fog/openstack/orchestration.rb +15 -91
- data/lib/fog/openstack/planning.rb +20 -81
- data/lib/fog/openstack/requests/baremetal/delete_node.rb +1 -1
- data/lib/fog/openstack/requests/baremetal/list_chassis.rb +2 -8
- data/lib/fog/openstack/requests/baremetal/list_chassis_detailed.rb +3 -9
- data/lib/fog/openstack/requests/baremetal/list_drivers.rb +4 -3
- data/lib/fog/openstack/requests/baremetal/list_nodes.rb +3 -9
- data/lib/fog/openstack/requests/baremetal/list_nodes_detailed.rb +3 -9
- data/lib/fog/openstack/requests/baremetal/list_ports.rb +3 -9
- data/lib/fog/openstack/requests/baremetal/list_ports_detailed.rb +3 -9
- data/lib/fog/openstack/requests/compute/add_aggregate_host.rb +30 -0
- data/lib/fog/openstack/requests/compute/create_aggregate.rb +42 -0
- data/lib/fog/openstack/requests/compute/delete_aggregate.rb +28 -0
- data/lib/fog/openstack/requests/compute/evacuate_server.rb +26 -0
- data/lib/fog/openstack/requests/compute/get_aggregate.rb +26 -0
- data/lib/fog/openstack/requests/compute/list_aggregates.rb +36 -0
- data/lib/fog/openstack/requests/compute/list_all_addresses.rb +4 -3
- data/lib/fog/openstack/requests/compute/list_flavors.rb +6 -5
- data/lib/fog/openstack/requests/compute/list_hosts.rb +4 -3
- data/lib/fog/openstack/requests/compute/list_key_pairs.rb +4 -3
- data/lib/fog/openstack/requests/compute/list_security_groups.rb +24 -3
- data/lib/fog/openstack/requests/compute/list_servers.rb +8 -5
- data/lib/fog/openstack/requests/compute/list_servers_detail.rb +9 -6
- data/lib/fog/openstack/requests/compute/list_snapshots.rb +18 -4
- data/lib/fog/openstack/requests/compute/list_snapshots_detail.rb +27 -0
- data/lib/fog/openstack/requests/compute/list_volumes.rb +18 -4
- data/lib/fog/openstack/requests/compute/list_volumes_detail.rb +25 -0
- data/lib/fog/openstack/requests/compute/list_zones.rb +6 -5
- data/lib/fog/openstack/requests/compute/list_zones_detailed.rb +55 -0
- data/lib/fog/openstack/requests/compute/remove_aggregate_host.rb +30 -0
- data/lib/fog/openstack/requests/compute/server_actions.rb +14 -3
- data/lib/fog/openstack/requests/compute/shelve_offload_server.rb +24 -0
- data/lib/fog/openstack/requests/compute/shelve_server.rb +24 -0
- data/lib/fog/openstack/requests/compute/unshelve_server.rb +24 -0
- data/lib/fog/openstack/requests/compute/update_aggregate.rb +37 -0
- data/lib/fog/openstack/requests/compute/update_aggregate_metadata.rb +30 -0
- data/lib/fog/openstack/requests/identity_v2/list_ec2_credentials.rb +23 -7
- data/lib/fog/openstack/requests/identity_v2/list_roles.rb +5 -4
- data/lib/fog/openstack/requests/identity_v2/list_tenants.rb +14 -8
- data/lib/fog/openstack/requests/identity_v2/list_users.rb +16 -4
- data/lib/fog/openstack/requests/identity_v3/auth_domains.rb +2 -7
- data/lib/fog/openstack/requests/identity_v3/auth_projects.rb +6 -11
- data/lib/fog/openstack/requests/identity_v3/get_project.rb +2 -2
- data/lib/fog/openstack/requests/identity_v3/list_domains.rb +7 -14
- data/lib/fog/openstack/requests/identity_v3/list_endpoints.rb +7 -14
- data/lib/fog/openstack/requests/identity_v3/list_group_users.rb +5 -13
- data/lib/fog/openstack/requests/identity_v3/list_groups.rb +14 -24
- data/lib/fog/openstack/requests/identity_v3/list_os_credentials.rb +7 -12
- data/lib/fog/openstack/requests/identity_v3/list_policies.rb +7 -11
- data/lib/fog/openstack/requests/identity_v3/list_projects.rb +14 -25
- data/lib/fog/openstack/requests/identity_v3/list_role_assignments.rb +21 -17
- data/lib/fog/openstack/requests/identity_v3/list_roles.rb +7 -25
- data/lib/fog/openstack/requests/identity_v3/list_services.rb +7 -13
- data/lib/fog/openstack/requests/identity_v3/list_users.rb +7 -15
- data/lib/fog/openstack/requests/{image → image_v1}/add_member_to_image.rb +2 -0
- data/lib/fog/openstack/requests/image_v1/create_image.rb +78 -0
- data/lib/fog/openstack/requests/image_v1/delete_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v1/get_image.rb +47 -0
- data/lib/fog/openstack/requests/image_v1/get_image_by_id.rb +34 -0
- data/lib/fog/openstack/requests/image_v1/get_image_members.rb +31 -0
- data/lib/fog/openstack/requests/image_v1/get_shared_images.rb +31 -0
- data/lib/fog/openstack/requests/image_v1/list_public_images.rb +35 -0
- data/lib/fog/openstack/requests/image_v1/list_public_images_detailed.rb +37 -0
- data/lib/fog/openstack/requests/image_v1/remove_member_from_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v1/set_tenant.rb +21 -0
- data/lib/fog/openstack/requests/image_v1/update_image.rb +66 -0
- data/lib/fog/openstack/requests/image_v1/update_image_members.rb +39 -0
- data/lib/fog/openstack/requests/image_v2/add_member_to_image.rb +26 -0
- data/lib/fog/openstack/requests/image_v2/add_tag_to_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/create_image.rb +54 -0
- data/lib/fog/openstack/requests/image_v2/deactivate_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/delete_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/download_image.rb +29 -0
- data/lib/fog/openstack/requests/image_v2/get_image.rb +47 -0
- data/lib/fog/openstack/requests/image_v2/get_image_by_id.rb +34 -0
- data/lib/fog/openstack/requests/image_v2/get_image_members.rb +31 -0
- data/lib/fog/openstack/requests/image_v2/get_member_details.rb +33 -0
- data/lib/fog/openstack/requests/image_v2/get_shared_images.rb +31 -0
- data/lib/fog/openstack/requests/image_v2/list_images.rb +35 -0
- data/lib/fog/openstack/requests/image_v2/reactivate_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/remove_member_from_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/remove_tag_from_image.rb +25 -0
- data/lib/fog/openstack/requests/image_v2/set_tenant.rb +21 -0
- data/lib/fog/openstack/requests/image_v2/update_image.rb +49 -0
- data/lib/fog/openstack/requests/image_v2/update_image_member.rb +34 -0
- data/lib/fog/openstack/requests/image_v2/upload_image.rb +30 -0
- data/lib/fog/openstack/requests/network/add_router_interface.rb +12 -4
- data/lib/fog/openstack/requests/network/create_port.rb +14 -11
- data/lib/fog/openstack/requests/network/create_subnet.rb +7 -7
- data/lib/fog/openstack/requests/network/get_port.rb +5 -0
- data/lib/fog/openstack/requests/network/set_tenant.rb +1 -0
- data/lib/fog/openstack/requests/network/update_port.rb +7 -6
- data/lib/fog/openstack/requests/network/update_subnet.rb +8 -7
- data/lib/fog/openstack/requests/orchestration/list_events.rb +46 -0
- data/lib/fog/openstack/requests/orchestration/list_resource_events.rb +7 -2
- data/lib/fog/openstack/requests/orchestration/list_resource_types.rb +3 -2
- data/lib/fog/openstack/requests/orchestration/list_resources.rb +27 -4
- data/lib/fog/openstack/requests/orchestration/list_stack_data.rb +2 -2
- data/lib/fog/openstack/requests/orchestration/list_stack_data_detailed.rb +49 -0
- data/lib/fog/openstack/requests/orchestration/list_stack_events.rb +6 -2
- data/lib/fog/openstack/requests/orchestration/patch_stack.rb +37 -0
- data/lib/fog/openstack/requests/planning/list_plans.rb +4 -3
- data/lib/fog/openstack/requests/planning/list_roles.rb +3 -9
- data/lib/fog/openstack/requests/volume/accept_transfer.rb +22 -0
- data/lib/fog/openstack/requests/volume/create_transfer.rb +25 -0
- data/lib/fog/openstack/requests/volume/create_volume.rb +9 -39
- data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +13 -31
- data/lib/fog/openstack/requests/volume/create_volume_type.rb +41 -0
- data/lib/fog/openstack/requests/volume/delete_snapshot.rb +2 -2
- data/lib/fog/openstack/requests/volume/delete_transfer.rb +15 -0
- data/lib/fog/openstack/requests/volume/delete_volume.rb +2 -2
- data/lib/fog/openstack/requests/volume/delete_volume_type.rb +23 -0
- data/lib/fog/openstack/requests/volume/extend_volume.rb +25 -0
- data/lib/fog/openstack/requests/volume/get_quota.rb +2 -2
- data/lib/fog/openstack/requests/volume/get_quota_defaults.rb +7 -7
- data/lib/fog/openstack/requests/volume/get_quota_usage.rb +44 -0
- data/lib/fog/openstack/requests/volume/get_snapshot_details.rb +1 -20
- data/lib/fog/openstack/requests/volume/get_transfer_details.rb +17 -0
- data/lib/fog/openstack/requests/volume/get_volume_details.rb +1 -22
- data/lib/fog/openstack/requests/volume/get_volume_type_details.rb +3 -3
- data/lib/fog/openstack/requests/volume/list_snapshots.rb +18 -5
- data/lib/fog/openstack/requests/volume/list_snapshots_detailed.rb +27 -0
- data/lib/fog/openstack/requests/volume/list_transfers.rb +18 -0
- data/lib/fog/openstack/requests/volume/list_transfers_detailed.rb +18 -0
- data/lib/fog/openstack/requests/volume/list_volume_types.rb +8 -8
- data/lib/fog/openstack/requests/volume/list_volumes.rb +20 -40
- data/lib/fog/openstack/requests/volume/list_volumes_detailed.rb +16 -0
- data/lib/fog/openstack/requests/volume/list_zones.rb +32 -0
- data/lib/fog/openstack/requests/volume/set_tenant.rb +2 -2
- data/lib/fog/openstack/requests/volume/update_quota.rb +2 -2
- data/lib/fog/openstack/requests/volume/update_volume_type.rb +41 -0
- data/lib/fog/openstack/requests/volume_v1/accept_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/create_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/create_volume.rb +49 -0
- data/lib/fog/openstack/requests/volume_v1/create_volume_snapshot.rb +44 -0
- data/lib/fog/openstack/requests/volume_v1/create_volume_type.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/delete_snapshot.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/delete_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/delete_volume.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/delete_volume_type.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/extend_volume.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/get_quota.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/get_quota_defaults.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/get_quota_usage.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/get_snapshot_details.rb +32 -0
- data/lib/fog/openstack/requests/volume_v1/get_transfer_details.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/get_volume_details.rb +35 -0
- data/lib/fog/openstack/requests/volume_v1/get_volume_type_details.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_snapshots.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_snapshots_detailed.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_transfers.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_transfers_detailed.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_volume_types.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/list_volumes.rb +46 -0
- data/lib/fog/openstack/requests/volume_v1/list_volumes_detailed.rb +46 -0
- data/lib/fog/openstack/requests/volume_v1/list_zones.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/real.rb +11 -0
- data/lib/fog/openstack/requests/volume_v1/real_mock.rb +14 -0
- data/lib/fog/openstack/requests/volume_v1/set_tenant.rb +2 -0
- data/lib/fog/openstack/requests/volume_v1/update_quota.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/accept_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/create_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/create_volume.rb +49 -0
- data/lib/fog/openstack/requests/volume_v2/create_volume_snapshot.rb +43 -0
- data/lib/fog/openstack/requests/volume_v2/create_volume_type.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/delete_snapshot.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/delete_transfer.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/delete_volume.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/delete_volume_type.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/extend_volume.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/get_quota.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/get_quota_defaults.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/get_quota_usage.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/get_snapshot_details.rb +32 -0
- data/lib/fog/openstack/requests/volume_v2/get_transfer_details.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/get_volume_details.rb +35 -0
- data/lib/fog/openstack/requests/volume_v2/get_volume_type_details.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_snapshots.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_snapshots_detailed.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_transfers.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_transfers_detailed.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_volume_types.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/list_volumes.rb +46 -0
- data/lib/fog/openstack/requests/volume_v2/list_volumes_detailed.rb +46 -0
- data/lib/fog/openstack/requests/volume_v2/list_zones.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/real.rb +11 -0
- data/lib/fog/openstack/requests/volume_v2/real_mock.rb +14 -0
- data/lib/fog/openstack/requests/volume_v2/set_tenant.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/update_quota.rb +2 -0
- data/lib/fog/openstack/requests/volume_v2/update_volume_type.rb +2 -0
- data/lib/fog/openstack/storage.rb +19 -55
- data/lib/fog/openstack/volume.rb +21 -216
- data/lib/fog/openstack/volume_v1.rb +163 -0
- data/lib/fog/openstack/volume_v2.rb +164 -0
- data/lib/fog/openstack.rb +5 -0
- data/lib/fog/ovirt/models/compute/server.rb +1 -0
- data/lib/fog/ovirt/models/compute/template.rb +1 -0
- data/lib/fog/rackspace/compute_v2.rb +1 -0
- data/lib/fog/rackspace/docs/compute_v2.md +1 -1
- data/lib/fog/rackspace/docs/queues.md +2 -2
- data/lib/fog/rackspace/examples/compute_v2/create_network.rb +1 -1
- data/lib/fog/rackspace/models/block_storage/snapshot.rb +5 -1
- data/lib/fog/rackspace/models/compute_v2/server.rb +25 -1
- data/lib/fog/rackspace/models/compute_v2/servers.rb +2 -2
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +7 -2
- data/lib/fog/rackspace/requests/compute_v2/get_vnc_console.rb +45 -0
- data/lib/fog/rackspace/requests/load_balancers/create_node.rb +1 -1
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +13 -2
- data/lib/fog/rackspace/requests/storage/put_container.rb +10 -6
- data/lib/fog/vcloud_director/compute.rb +18 -2
- data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +32 -30
- data/lib/fog/vcloud_director/models/compute/disks.rb +6 -0
- data/lib/fog/vcloud_director/models/compute/networks.rb +7 -2
- data/lib/fog/vcloud_director/models/compute/task.rb +2 -2
- data/lib/fog/vcloud_director/models/compute/vdc.rb +5 -0
- data/lib/fog/vcloud_director/models/compute/vm.rb +15 -1
- data/lib/fog/vcloud_director/models/compute/vm_customizations.rb +15 -0
- data/lib/fog/vcloud_director/parsers/compute/vm.rb +4 -0
- data/lib/fog/vcloud_director/parsers/compute/vms.rb +4 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +24 -3
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +23 -0
- data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +13 -10
- data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +11 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +1 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +20 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms.rb +13 -0
- data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +35 -0
- data/lib/fog/vcloud_director/requests/compute/post_reconfigure_vm.rb +118 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +34 -0
- data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +2 -1
- data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +31 -0
- data/lib/fog/version.rb +1 -1
- data/lib/fog.rb +1 -0
- data/lib/tasks/changelog_task.rb +6 -0
- data/spec/fog/openstack/identity_v3/authv3_a.yml +50 -37
- data/spec/fog/openstack/identity_v3/authv3_b.yml +50 -37
- data/spec/fog/openstack/identity_v3/authv3_c.yml +393 -35
- data/spec/fog/openstack/identity_v3/authv3_token.yml +421 -82
- data/spec/fog/openstack/identity_v3/authv3_unscoped.yml +471 -213
- data/spec/fog/openstack/identity_v3/authv3_unscoped_reauth.yml +835 -0
- data/spec/fog/openstack/identity_v3/common_setup.yml +98 -0
- data/spec/fog/openstack/identity_v3/idv3_credential.yml +71 -35
- data/spec/fog/openstack/identity_v3/idv3_credential_crud.yml +620 -210
- data/spec/fog/openstack/identity_v3/idv3_domain.yml +78 -117
- data/spec/fog/openstack/identity_v3/idv3_domain_crud.yml +277 -427
- data/spec/fog/openstack/identity_v3/idv3_domain_group_roles_mutation.yml +511 -404
- data/spec/fog/openstack/identity_v3/idv3_domain_roles_mutation.yml +555 -219
- data/spec/fog/openstack/identity_v3/idv3_endpoint.yml +499 -179
- data/spec/fog/openstack/identity_v3/idv3_endpoints_crud.yml +734 -447
- data/spec/fog/openstack/identity_v3/idv3_group_crud_mutation.yml +682 -332
- data/spec/fog/openstack/identity_v3/idv3_policy.yml +99 -51
- data/spec/fog/openstack/identity_v3/idv3_policy_crud.yml +249 -129
- data/spec/fog/openstack/identity_v3/idv3_project.yml +322 -136
- data/spec/fog/openstack/identity_v3/idv3_project_crud.yml +250 -423
- data/spec/fog/openstack/identity_v3/idv3_project_group_user_roles_mutation.yml +757 -616
- data/spec/fog/openstack/identity_v3/idv3_project_hier_crud_list.yml +1405 -0
- data/spec/fog/openstack/identity_v3/idv3_role.yml +159 -79
- data/spec/fog/openstack/identity_v3/idv3_role_crud.yml +329 -343
- data/spec/fog/openstack/identity_v3/idv3_service.yml +208 -100
- data/spec/fog/openstack/identity_v3/idv3_services_crud.yml +359 -321
- data/spec/fog/openstack/identity_v3/idv3_token.yml +246 -116
- data/spec/fog/openstack/identity_v3/idv3_user_crud.yml +465 -210
- data/spec/fog/openstack/identity_v3/idv3_users.yml +244 -228
- data/spec/fog/openstack/identity_v3_spec.rb +673 -568
- data/spec/fog/openstack/image_v1/common_setup.yml +144 -0
- data/spec/fog/openstack/image_v1/list_images.yml +54 -0
- data/spec/fog/openstack/image_v1_spec.rb +24 -0
- data/spec/fog/openstack/image_v2/common_setup.yml +144 -0
- data/spec/fog/openstack/image_v2/image_schema.json +190 -0
- data/spec/fog/openstack/image_v2/image_v2_activation.yml +3988 -0
- data/spec/fog/openstack/image_v2/image_v2_create_id.yml +291 -0
- data/spec/fog/openstack/image_v2/image_v2_crud.yml +437 -0
- data/spec/fog/openstack/image_v2/image_v2_member_crudl.yml +451 -0
- data/spec/fog/openstack/image_v2/image_v2_tags.yml +532 -0
- data/spec/fog/openstack/image_v2/image_v2_upload_download.yml +3966 -0
- data/spec/fog/openstack/image_v2/minimal.ova +0 -0
- data/spec/fog/openstack/image_v2_spec.rb +285 -0
- data/spec/fog/openstack/image_v2_upload_spec.rb +74 -0
- data/spec/fog/openstack/network/common_setup.yml +140 -0
- data/spec/fog/openstack/network/subnets_crud.yml +180 -0
- data/spec/fog/openstack/network_spec.rb +43 -0
- data/spec/fog/openstack/shared_context.rb +115 -0
- data/spec/fog/openstack/volume/common_setup.yml +100 -0
- data/spec/fog/openstack/volume/volume_crud.yml +611 -0
- data/spec/fog/openstack/volume/volume_extend.yml +669 -0
- data/spec/fog/openstack/volume/volume_transfer_and_accept.yml +1072 -0
- data/spec/fog/openstack/volume/volume_transfer_and_delete.yml +666 -0
- data/spec/fog/openstack/volume/volume_type_read.yml +114 -0
- data/spec/fog/openstack/volume_spec.rb +362 -0
- data/spec/fog/openstack/volume_v1/common_setup.yml +100 -0
- data/spec/fog/openstack/volume_v1/volume_crud.yml +535 -0
- data/spec/fog/openstack/volume_v1/volume_extend.yml +596 -0
- data/spec/fog/openstack/volume_v1/volume_transfer_and_accept.yml +1010 -0
- data/spec/fog/openstack/volume_v1/volume_transfer_and_delete.yml +645 -0
- data/spec/fog/openstack/volume_v1/volume_type_read.yml +114 -0
- data/spec/fog/openstack/volume_v2/common_setup.yml +100 -0
- data/spec/fog/openstack/volume_v2/volume_crud.yml +611 -0
- data/spec/fog/openstack/volume_v2/volume_extend.yml +669 -0
- data/spec/fog/openstack/volume_v2/volume_transfer_and_accept.yml +1072 -0
- data/spec/fog/openstack/volume_v2/volume_transfer_and_delete.yml +666 -0
- data/spec/fog/openstack/volume_v2/volume_type_read.yml +114 -0
- data/tests/compute/helper.rb +0 -9
- data/tests/digitalocean/requests/compute_v2/list_flavors_tests.rb +25 -0
- data/tests/digitalocean/requests/compute_v2/list_images_tests.rb +25 -0
- data/tests/digitalocean/requests/compute_v2/list_regions_tests.rb +21 -0
- data/tests/digitalocean/requests/compute_v2/server_tests.rb +77 -0
- data/tests/helper.rb +1 -0
- data/tests/helpers/mock_helper.rb +1 -4
- data/tests/linode/requests/compute/datacenter_tests.rb +2 -1
- data/tests/linode/requests/compute/kernel_tests.rb +2 -10
- data/tests/linode/requests/compute/linodeplans_tests.rb +10 -7
- data/tests/linode/requests/compute/nodebalancers_tests.rb +20 -0
- data/tests/opennebula/models/compute/flavor_tests.rb +1 -1
- data/tests/openstack/authenticate_tests.rb +4 -0
- data/tests/openstack/models/storage/file_tests.rb +55 -0
- data/tests/openstack/requests/compute/aggregate_tests.rb +59 -0
- data/tests/openstack/requests/compute/availability_zone_tests.rb +18 -0
- data/tests/openstack/requests/compute/server_tests.rb +12 -0
- data/tests/openstack/requests/network/port_tests.rb +14 -11
- data/tests/openstack/requests/network/subnet_tests.rb +2 -2
- data/tests/openstack/requests/orchestration/stack_tests.rb +30 -1
- data/tests/openstack/requests/volume/availability_zone_tests.rb +13 -0
- data/tests/openstack/requests/volume/volume_type_tests.rb +32 -0
- data/tests/openstack/volume_tests.rb +4 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +7 -7
- data/tests/rackspace/requests/compute_v2/server_tests.rb +4 -0
- data/tests/rackspace/requests/load_balancers/node_tests.rb +7 -0
- data/tests/rackspace/requests/storage/object_tests.rb +46 -4
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +4 -4
- metadata +403 -457
- data/gemfiles/Gemfile-ruby-1.8.7 +0 -17
- data/lib/fog/bin/dynect.rb +0 -28
- data/lib/fog/bin/vsphere.rb +0 -28
- data/lib/fog/bin/xenserver.rb +0 -29
- data/lib/fog/dynect/core.rb +0 -26
- data/lib/fog/dynect/dns.rb +0 -157
- data/lib/fog/dynect/models/dns/record.rb +0 -67
- data/lib/fog/dynect/models/dns/records.rb +0 -48
- data/lib/fog/dynect/models/dns/zone.rb +0 -56
- data/lib/fog/dynect/models/dns/zones.rb +0 -25
- data/lib/fog/dynect/requests/dns/delete_record.rb +0 -55
- data/lib/fog/dynect/requests/dns/delete_zone.rb +0 -41
- data/lib/fog/dynect/requests/dns/get_all_records.rb +0 -56
- data/lib/fog/dynect/requests/dns/get_node_list.rb +0 -55
- data/lib/fog/dynect/requests/dns/get_record.rb +0 -83
- data/lib/fog/dynect/requests/dns/get_zone.rb +0 -57
- data/lib/fog/dynect/requests/dns/post_record.rb +0 -71
- data/lib/fog/dynect/requests/dns/post_session.rb +0 -43
- data/lib/fog/dynect/requests/dns/post_zone.rb +0 -70
- data/lib/fog/dynect/requests/dns/put_record.rb +0 -76
- data/lib/fog/dynect/requests/dns/put_zone.rb +0 -76
- data/lib/fog/dynect.rb +0 -1
- data/lib/fog/openstack/models/image/image.rb +0 -87
- data/lib/fog/openstack/models/image/images.rb +0 -61
- data/lib/fog/openstack/requests/image/create_image.rb +0 -76
- data/lib/fog/openstack/requests/image/delete_image.rb +0 -23
- data/lib/fog/openstack/requests/image/get_image.rb +0 -45
- data/lib/fog/openstack/requests/image/get_image_by_id.rb +0 -32
- data/lib/fog/openstack/requests/image/get_image_members.rb +0 -29
- data/lib/fog/openstack/requests/image/get_shared_images.rb +0 -29
- data/lib/fog/openstack/requests/image/list_public_images.rb +0 -32
- data/lib/fog/openstack/requests/image/list_public_images_detailed.rb +0 -32
- data/lib/fog/openstack/requests/image/remove_member_from_image.rb +0 -23
- data/lib/fog/openstack/requests/image/set_tenant.rb +0 -19
- data/lib/fog/openstack/requests/image/update_image.rb +0 -64
- data/lib/fog/openstack/requests/image/update_image_members.rb +0 -37
- data/lib/fog/vsphere/compute.rb +0 -465
- data/lib/fog/vsphere/core.rb +0 -39
- data/lib/fog/vsphere/models/compute/cluster.rb +0 -28
- data/lib/fog/vsphere/models/compute/clusters.rb +0 -23
- data/lib/fog/vsphere/models/compute/customfield.rb +0 -16
- data/lib/fog/vsphere/models/compute/customfields.rb +0 -24
- data/lib/fog/vsphere/models/compute/customvalue.rb +0 -14
- data/lib/fog/vsphere/models/compute/customvalues.rb +0 -34
- data/lib/fog/vsphere/models/compute/datacenter.rb +0 -44
- data/lib/fog/vsphere/models/compute/datacenters.rb +0 -20
- data/lib/fog/vsphere/models/compute/datastore.rb +0 -21
- data/lib/fog/vsphere/models/compute/datastores.rb +0 -22
- data/lib/fog/vsphere/models/compute/folder.rb +0 -24
- data/lib/fog/vsphere/models/compute/folders.rb +0 -24
- data/lib/fog/vsphere/models/compute/interface.rb +0 -91
- data/lib/fog/vsphere/models/compute/interfaces.rb +0 -67
- data/lib/fog/vsphere/models/compute/interfacetype.rb +0 -22
- data/lib/fog/vsphere/models/compute/interfacetypes.rb +0 -35
- data/lib/fog/vsphere/models/compute/network.rb +0 -17
- data/lib/fog/vsphere/models/compute/networks.rb +0 -23
- data/lib/fog/vsphere/models/compute/resource_pool.rb +0 -19
- data/lib/fog/vsphere/models/compute/resource_pools.rb +0 -23
- data/lib/fog/vsphere/models/compute/scsicontroller.rb +0 -16
- data/lib/fog/vsphere/models/compute/server.rb +0 -296
- data/lib/fog/vsphere/models/compute/servers.rb +0 -37
- data/lib/fog/vsphere/models/compute/servertype.rb +0 -36
- data/lib/fog/vsphere/models/compute/servertypes.rb +0 -24
- data/lib/fog/vsphere/models/compute/template.rb +0 -11
- data/lib/fog/vsphere/models/compute/templates.rb +0 -20
- data/lib/fog/vsphere/models/compute/volume.rb +0 -99
- data/lib/fog/vsphere/models/compute/volumes.rb +0 -54
- data/lib/fog/vsphere/requests/compute/cloudinit_to_customspec.rb +0 -65
- data/lib/fog/vsphere/requests/compute/create_folder.rb +0 -22
- data/lib/fog/vsphere/requests/compute/create_vm.rb +0 -164
- data/lib/fog/vsphere/requests/compute/current_time.rb +0 -18
- data/lib/fog/vsphere/requests/compute/get_cluster.rb +0 -25
- data/lib/fog/vsphere/requests/compute/get_compute_resource.rb +0 -41
- data/lib/fog/vsphere/requests/compute/get_datacenter.rb +0 -31
- data/lib/fog/vsphere/requests/compute/get_datastore.rb +0 -30
- data/lib/fog/vsphere/requests/compute/get_folder.rb +0 -74
- data/lib/fog/vsphere/requests/compute/get_interface_type.rb +0 -15
- data/lib/fog/vsphere/requests/compute/get_network.rb +0 -59
- data/lib/fog/vsphere/requests/compute/get_resource_pool.rb +0 -26
- data/lib/fog/vsphere/requests/compute/get_server_type.rb +0 -32
- data/lib/fog/vsphere/requests/compute/get_template.rb +0 -16
- data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +0 -56
- data/lib/fog/vsphere/requests/compute/get_vm_first_scsi_controller.rb +0 -26
- data/lib/fog/vsphere/requests/compute/list_clusters.rb +0 -72
- data/lib/fog/vsphere/requests/compute/list_compute_resources.rb +0 -92
- data/lib/fog/vsphere/requests/compute/list_customfields.rb +0 -21
- data/lib/fog/vsphere/requests/compute/list_datacenters.rb +0 -53
- data/lib/fog/vsphere/requests/compute/list_datastores.rb +0 -40
- data/lib/fog/vsphere/requests/compute/list_folders.rb +0 -44
- data/lib/fog/vsphere/requests/compute/list_interface_types.rb +0 -25
- data/lib/fog/vsphere/requests/compute/list_networks.rb +0 -37
- data/lib/fog/vsphere/requests/compute/list_resource_pools.rb +0 -38
- data/lib/fog/vsphere/requests/compute/list_server_types.rb +0 -54
- data/lib/fog/vsphere/requests/compute/list_templates.rb +0 -48
- data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +0 -80
- data/lib/fog/vsphere/requests/compute/list_vm_customvalues.rb +0 -20
- data/lib/fog/vsphere/requests/compute/list_vm_interfaces.rb +0 -63
- data/lib/fog/vsphere/requests/compute/list_vm_volumes.rb +0 -52
- data/lib/fog/vsphere/requests/compute/modify_vm_interface.rb +0 -59
- data/lib/fog/vsphere/requests/compute/modify_vm_volume.rb +0 -25
- data/lib/fog/vsphere/requests/compute/set_vm_customvalue.rb +0 -17
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +0 -659
- data/lib/fog/vsphere/requests/compute/vm_config_vnc.rb +0 -45
- data/lib/fog/vsphere/requests/compute/vm_destroy.rb +0 -23
- data/lib/fog/vsphere/requests/compute/vm_migrate.rb +0 -33
- data/lib/fog/vsphere/requests/compute/vm_power_off.rb +0 -39
- data/lib/fog/vsphere/requests/compute/vm_power_on.rb +0 -26
- data/lib/fog/vsphere/requests/compute/vm_reboot.rb +0 -31
- data/lib/fog/vsphere/requests/compute/vm_reconfig_cpus.rb +0 -23
- data/lib/fog/vsphere/requests/compute/vm_reconfig_hardware.rb +0 -24
- data/lib/fog/vsphere/requests/compute/vm_reconfig_memory.rb +0 -23
- data/lib/fog/vsphere.rb +0 -1
- data/lib/fog/xenserver/CHANGELOG.md +0 -77
- data/lib/fog/xenserver/compute.rb +0 -186
- data/lib/fog/xenserver/core.rb +0 -94
- data/lib/fog/xenserver/examples/README.md +0 -11
- data/lib/fog/xenserver/examples/chage_default_storage_repository.md +0 -99
- data/lib/fog/xenserver/examples/creating_servers.md +0 -168
- data/lib/fog/xenserver/examples/getting_started.md +0 -163
- data/lib/fog/xenserver/examples/networks-and-vlans.rb +0 -44
- data/lib/fog/xenserver/examples/storage_repositories.md +0 -94
- data/lib/fog/xenserver/models/compute/blob.rb +0 -22
- data/lib/fog/xenserver/models/compute/blobs.rb +0 -25
- data/lib/fog/xenserver/models/compute/bond.rb +0 -23
- data/lib/fog/xenserver/models/compute/bonds.rb +0 -25
- data/lib/fog/xenserver/models/compute/console.rb +0 -29
- data/lib/fog/xenserver/models/compute/consoles.rb +0 -25
- data/lib/fog/xenserver/models/compute/crash_dump.rb +0 -19
- data/lib/fog/xenserver/models/compute/crash_dumps.rb +0 -25
- data/lib/fog/xenserver/models/compute/dr_task.rb +0 -17
- data/lib/fog/xenserver/models/compute/dr_tasks.rb +0 -25
- data/lib/fog/xenserver/models/compute/gpu_group.rb +0 -22
- data/lib/fog/xenserver/models/compute/gpu_groups.rb +0 -25
- data/lib/fog/xenserver/models/compute/guest_metrics.rb +0 -26
- data/lib/fog/xenserver/models/compute/host.rb +0 -156
- data/lib/fog/xenserver/models/compute/host_cpu.rb +0 -34
- data/lib/fog/xenserver/models/compute/host_crash_dump.rb +0 -20
- data/lib/fog/xenserver/models/compute/host_crash_dumps.rb +0 -25
- data/lib/fog/xenserver/models/compute/host_metrics.rb +0 -26
- data/lib/fog/xenserver/models/compute/host_patch.rb +0 -25
- data/lib/fog/xenserver/models/compute/host_patchs.rb +0 -25
- data/lib/fog/xenserver/models/compute/hosts.rb +0 -25
- data/lib/fog/xenserver/models/compute/network.rb +0 -93
- data/lib/fog/xenserver/models/compute/networks.rb +0 -29
- data/lib/fog/xenserver/models/compute/pbd.rb +0 -37
- data/lib/fog/xenserver/models/compute/pbds.rb +0 -29
- data/lib/fog/xenserver/models/compute/pci.rb +0 -22
- data/lib/fog/xenserver/models/compute/pcis.rb +0 -25
- data/lib/fog/xenserver/models/compute/pgpu.rb +0 -20
- data/lib/fog/xenserver/models/compute/pgpus.rb +0 -25
- data/lib/fog/xenserver/models/compute/pif.rb +0 -54
- data/lib/fog/xenserver/models/compute/pif_metrics.rb +0 -28
- data/lib/fog/xenserver/models/compute/pifs.rb +0 -29
- data/lib/fog/xenserver/models/compute/pifs_metrics.rb +0 -25
- data/lib/fog/xenserver/models/compute/pool.rb +0 -75
- data/lib/fog/xenserver/models/compute/pool_patch.rb +0 -24
- data/lib/fog/xenserver/models/compute/pool_patchs.rb +0 -25
- data/lib/fog/xenserver/models/compute/pools.rb +0 -29
- data/lib/fog/xenserver/models/compute/role.rb +0 -19
- data/lib/fog/xenserver/models/compute/roles.rb +0 -25
- data/lib/fog/xenserver/models/compute/server.rb +0 -251
- data/lib/fog/xenserver/models/compute/server_appliance.rb +0 -21
- data/lib/fog/xenserver/models/compute/server_appliances.rb +0 -25
- data/lib/fog/xenserver/models/compute/servers.rb +0 -64
- data/lib/fog/xenserver/models/compute/storage_manager.rb +0 -28
- data/lib/fog/xenserver/models/compute/storage_managers.rb +0 -25
- data/lib/fog/xenserver/models/compute/storage_repositories.rb +0 -27
- data/lib/fog/xenserver/models/compute/storage_repository.rb +0 -90
- data/lib/fog/xenserver/models/compute/tunnel.rb +0 -20
- data/lib/fog/xenserver/models/compute/tunnels.rb +0 -25
- data/lib/fog/xenserver/models/compute/vbd.rb +0 -88
- data/lib/fog/xenserver/models/compute/vbd_metrics.rb +0 -25
- data/lib/fog/xenserver/models/compute/vbds.rb +0 -29
- data/lib/fog/xenserver/models/compute/vdi.rb +0 -102
- data/lib/fog/xenserver/models/compute/vdis.rb +0 -25
- data/lib/fog/xenserver/models/compute/vif.rb +0 -56
- data/lib/fog/xenserver/models/compute/vifs.rb +0 -25
- data/lib/fog/xenserver/models/compute/vlan.rb +0 -78
- data/lib/fog/xenserver/models/compute/vlans.rb +0 -35
- data/lib/fog/xenserver/models/compute/vmpp.rb +0 -35
- data/lib/fog/xenserver/models/compute/vmpps.rb +0 -25
- data/lib/fog/xenserver/models/compute/vtpm.rb +0 -18
- data/lib/fog/xenserver/models/compute/vtpms.rb +0 -25
- data/lib/fog/xenserver/parser.rb +0 -34
- data/lib/fog/xenserver/parsers/get_hosts.rb +0 -16
- data/lib/fog/xenserver/parsers/get_networks.rb +0 -16
- data/lib/fog/xenserver/parsers/get_pools.rb +0 -16
- data/lib/fog/xenserver/parsers/get_records.rb +0 -16
- data/lib/fog/xenserver/parsers/get_storage_repositories.rb +0 -16
- data/lib/fog/xenserver/parsers/get_vbds.rb +0 -16
- data/lib/fog/xenserver/parsers/get_vifs.rb +0 -16
- data/lib/fog/xenserver/parsers/get_vms.rb +0 -16
- data/lib/fog/xenserver/requests/compute/clone_server.rb +0 -30
- data/lib/fog/xenserver/requests/compute/create_network.rb +0 -46
- data/lib/fog/xenserver/requests/compute/create_server.rb +0 -144
- data/lib/fog/xenserver/requests/compute/create_sr.rb +0 -88
- data/lib/fog/xenserver/requests/compute/create_vbd.rb +0 -43
- data/lib/fog/xenserver/requests/compute/create_vdi.rb +0 -57
- data/lib/fog/xenserver/requests/compute/create_vif.rb +0 -62
- data/lib/fog/xenserver/requests/compute/create_vlan.rb +0 -43
- data/lib/fog/xenserver/requests/compute/destroy_network.rb +0 -31
- data/lib/fog/xenserver/requests/compute/destroy_record.rb +0 -11
- data/lib/fog/xenserver/requests/compute/destroy_server.rb +0 -20
- data/lib/fog/xenserver/requests/compute/destroy_sr.rb +0 -28
- data/lib/fog/xenserver/requests/compute/destroy_vdi.rb +0 -20
- data/lib/fog/xenserver/requests/compute/destroy_vif.rb +0 -20
- data/lib/fog/xenserver/requests/compute/destroy_vlan.rb +0 -30
- data/lib/fog/xenserver/requests/compute/disable_host.rb +0 -23
- data/lib/fog/xenserver/requests/compute/eject_vbd.rb +0 -17
- data/lib/fog/xenserver/requests/compute/enable_host.rb +0 -22
- data/lib/fog/xenserver/requests/compute/get_record.rb +0 -31
- data/lib/fog/xenserver/requests/compute/get_records.rb +0 -24
- data/lib/fog/xenserver/requests/compute/insert_vbd.rb +0 -17
- data/lib/fog/xenserver/requests/compute/provision_server.rb +0 -17
- data/lib/fog/xenserver/requests/compute/reboot_host.rb +0 -17
- data/lib/fog/xenserver/requests/compute/reboot_server.rb +0 -17
- data/lib/fog/xenserver/requests/compute/scan_sr.rb +0 -17
- data/lib/fog/xenserver/requests/compute/set_affinity.rb +0 -19
- data/lib/fog/xenserver/requests/compute/set_attribute.rb +0 -19
- data/lib/fog/xenserver/requests/compute/shutdown_host.rb +0 -17
- data/lib/fog/xenserver/requests/compute/shutdown_server.rb +0 -17
- data/lib/fog/xenserver/requests/compute/snapshot_revert.rb +0 -24
- data/lib/fog/xenserver/requests/compute/snapshot_server.rb +0 -17
- data/lib/fog/xenserver/requests/compute/start_server.rb +0 -17
- data/lib/fog/xenserver/requests/compute/start_vm.rb +0 -19
- data/lib/fog/xenserver/requests/compute/unplug_pbd.rb +0 -20
- data/lib/fog/xenserver/requests/compute/unplug_vbd.rb +0 -25
- data/lib/fog/xenserver/utilities.rb +0 -8
- data/lib/fog/xenserver.rb +0 -1
- data/spec/fog/openstack/identity_v3/authv3_project.yml +0 -61
- data/spec/fog/openstack/identity_v3/idv2_unscoped_token_v3.yml +0 -467
- data/spec/fog/openstack/identity_v3/idv3.yml +0 -61
- data/tests/brightbox/compute/helper.rb +0 -1
- data/tests/brightbox/compute/schema.rb +0 -799
- data/tests/brightbox/compute_tests.rb +0 -101
- data/tests/brightbox/helper.rb +0 -1
- data/tests/brightbox/models/compute/account_tests.rb +0 -17
- data/tests/brightbox/models/compute/cloud_ip_tests.rb +0 -32
- data/tests/brightbox/models/compute/database_server_tests.rb +0 -78
- data/tests/brightbox/models/compute/database_snapshot_tests.rb +0 -26
- data/tests/brightbox/models/compute/database_type_tests.rb +0 -27
- data/tests/brightbox/models/compute/server_tests.rb +0 -19
- data/tests/brightbox/oauth2_tests.rb +0 -110
- data/tests/brightbox/requests/compute/account_tests.rb +0 -65
- data/tests/brightbox/requests/compute/api_client_tests.rb +0 -64
- data/tests/brightbox/requests/compute/application_test.rb +0 -63
- data/tests/brightbox/requests/compute/cloud_ip_tests.rb +0 -85
- data/tests/brightbox/requests/compute/collaboration_tests.rb +0 -39
- data/tests/brightbox/requests/compute/database_server_tests.rb +0 -54
- data/tests/brightbox/requests/compute/database_snapsnot_tests.rb +0 -47
- data/tests/brightbox/requests/compute/database_type_tests.rb +0 -17
- data/tests/brightbox/requests/compute/firewall_policy_tests.rb +0 -40
- data/tests/brightbox/requests/compute/firewall_rule_tests.rb +0 -43
- data/tests/brightbox/requests/compute/helper.rb +0 -41
- data/tests/brightbox/requests/compute/image_tests.rb +0 -60
- data/tests/brightbox/requests/compute/interface_tests.rb +0 -33
- data/tests/brightbox/requests/compute/load_balancer_tests.rb +0 -121
- data/tests/brightbox/requests/compute/server_group_tests.rb +0 -96
- data/tests/brightbox/requests/compute/server_tests.rb +0 -99
- data/tests/brightbox/requests/compute/server_type_tests.rb +0 -34
- data/tests/brightbox/requests/compute/user_collaboration_tests.rb +0 -67
- data/tests/brightbox/requests/compute/user_tests.rb +0 -38
- data/tests/brightbox/requests/compute/zone_tests.rb +0 -34
- data/tests/dynect/requests/dns/dns_tests.rb +0 -258
- data/tests/vsphere/compute_tests.rb +0 -53
- data/tests/vsphere/models/compute/server_tests.rb +0 -44
- data/tests/vsphere/models/compute/servers_tests.rb +0 -15
- data/tests/vsphere/requests/compute/current_time_tests.rb +0 -12
- data/tests/vsphere/requests/compute/get_network_tests.rb +0 -48
- data/tests/vsphere/requests/compute/list_clusters_tests.rb +0 -11
- data/tests/vsphere/requests/compute/list_virtual_machines_tests.rb +0 -38
- data/tests/vsphere/requests/compute/set_vm_customvalue_tests.rb +0 -20
- data/tests/vsphere/requests/compute/vm_clone_tests.rb +0 -50
- data/tests/vsphere/requests/compute/vm_config_vnc_tests.rb +0 -19
- data/tests/vsphere/requests/compute/vm_destroy_tests.rb +0 -17
- data/tests/vsphere/requests/compute/vm_migrate_tests.rb +0 -16
- data/tests/vsphere/requests/compute/vm_power_off_tests.rb +0 -26
- data/tests/vsphere/requests/compute/vm_power_on_tests.rb +0 -17
- data/tests/vsphere/requests/compute/vm_reboot_tests.rb +0 -26
- data/tests/vsphere/requests/compute/vm_reconfig_cpus_tests.rb +0 -19
- data/tests/vsphere/requests/compute/vm_reconfig_hardware_tests.rb +0 -19
- data/tests/vsphere/requests/compute/vm_reconfig_memory_tests.rb +0 -19
- data/tests/xenserver/README +0 -21
- data/tests/xenserver/compute_tests.rb +0 -51
- data/tests/xenserver/helper.rb +0 -36
- data/tests/xenserver/models/compute/console_test.rb +0 -35
- data/tests/xenserver/models/compute/consoles_test.rb +0 -19
- data/tests/xenserver/models/compute/host_cpu_tests.rb +0 -58
- data/tests/xenserver/models/compute/host_metrics_tests.rb +0 -48
- data/tests/xenserver/models/compute/host_tests.rb +0 -98
- data/tests/xenserver/models/compute/hosts_tests.rb +0 -22
- data/tests/xenserver/models/compute/network_tests.rb +0 -79
- data/tests/xenserver/models/compute/networks_tests.rb +0 -22
- data/tests/xenserver/models/compute/pbd_tests.rb +0 -76
- data/tests/xenserver/models/compute/pbds_tests.rb +0 -22
- data/tests/xenserver/models/compute/pif_tests.rb +0 -58
- data/tests/xenserver/models/compute/pifs_tests.rb +0 -22
- data/tests/xenserver/models/compute/pool_tests.rb +0 -56
- data/tests/xenserver/models/compute/pools_tests.rb +0 -30
- data/tests/xenserver/models/compute/server_tests.rb +0 -184
- data/tests/xenserver/models/compute/servers_tests.rb +0 -89
- data/tests/xenserver/models/compute/storage_repositories_tests.rb +0 -30
- data/tests/xenserver/models/compute/storage_repository_tests.rb +0 -114
- data/tests/xenserver/models/compute/vbd_tests.rb +0 -115
- data/tests/xenserver/models/compute/vbds_tests.rb +0 -22
- data/tests/xenserver/models/compute/vif_tests.rb +0 -53
- data/tests/xenserver/models/compute/vifs_tests.rb +0 -22
- data/tests/xenserver/models/compute/vlan_tests.rb +0 -76
- data/tests/xenserver/models/compute/vlans_tests.rb +0 -36
- data/tests/xenserver/requests/compute/clone_server_tests.rb +0 -32
- data/tests/xenserver/requests/compute/create_network_tests.rb +0 -20
- data/tests/xenserver/requests/compute/create_server_tests.rb +0 -129
- data/tests/xenserver/requests/compute/create_sr_tests.rb +0 -54
- data/tests/xenserver/requests/compute/create_vdi_tests.rb +0 -80
- data/tests/xenserver/requests/compute/create_vif_tests.rb +0 -88
- data/tests/xenserver/requests/compute/create_vlan_tests.rb +0 -36
- data/tests/xenserver/requests/compute/destroy_network_tests.rb +0 -13
- data/tests/xenserver/requests/compute/destroy_sr_tests.rb +0 -46
- data/tests/xenserver/requests/compute/destroy_vdi_tests.rb +0 -25
- data/tests/xenserver/requests/compute/destroy_vlan_tests.rb +0 -36
- data/tests/xenserver/requests/compute/disable_host_tests.rb +0 -16
- data/tests/xenserver/requests/compute/enable_host_tests.rb +0 -16
- data/tests/xenserver/requests/compute/get_record_tests.rb +0 -15
- data/tests/xenserver/requests/compute/set_attribute_tests.rb +0 -66
- data/tests/xenserver/requests/compute/unplug_pbd_tests.rb +0 -48
- 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
|