fog 1.29.0 → 1.30.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +88 -0
- data/CONTRIBUTING.md +1 -1
- data/fog.gemspec +3 -7
- data/lib/fog.rb +0 -1
- data/lib/fog/bin.rb +0 -1
- data/lib/fog/cloudstack/models/compute/public_ip_address.rb +78 -35
- data/lib/fog/cloudstack/models/compute/public_ip_addresses.rb +7 -5
- data/lib/fog/cloudstack/requests/compute/associate_ip_address.rb +2 -2
- data/lib/fog/cloudstack/requests/compute/disable_static_nat.rb +26 -0
- data/lib/fog/cloudstack/requests/compute/disassociate_ip_address.rb +1 -1
- data/lib/fog/cloudstack/requests/compute/enable_static_nat.rb +43 -0
- data/lib/fog/cloudstack/requests/compute/list_public_ip_addresses.rb +14 -4
- data/lib/fog/dynect/models/dns/records.rb +0 -1
- data/lib/fog/glesys/models/compute/server.rb +2 -4
- data/lib/fog/hp/storage.rb +25 -5
- data/lib/fog/linode/requests/compute/avail_datacenters.rb +2 -1
- data/lib/fog/opennebula/compute.rb +3 -0
- data/lib/fog/opennebula/models/compute/flavor.rb +11 -7
- data/lib/fog/opennebula/models/compute/networks.rb +11 -1
- data/lib/fog/opennebula/models/compute/servers.rb +4 -0
- data/lib/fog/opennebula/requests/compute/image_pool.rb +27 -0
- data/lib/fog/opennebula/requests/compute/list_networks.rb +1 -1
- data/lib/fog/opennebula/requests/compute/template_pool.rb +23 -4
- data/lib/fog/opennebula/requests/compute/vm_disk_snapshot.rb +22 -0
- data/lib/fog/opennebula/requests/compute/vm_shutdown.rb +18 -0
- data/lib/fog/openstack/compute.rb +34 -24
- data/lib/fog/openstack/core.rb +26 -13
- data/lib/fog/openstack/models/orchestration/resource.rb +1 -1
- data/lib/fog/openstack/models/orchestration/stack.rb +1 -1
- data/lib/fog/openstack/network.rb +34 -10
- data/lib/fog/openstack/requests/storage/get_object_http_url.rb +1 -1
- data/lib/fog/openstack/requests/storage/get_object_https_url.rb +9 -8
- data/lib/fog/openstack/requests/volume/list_snapshots.rb +4 -3
- data/lib/fog/rackspace/docs/compute_v2.md +4 -0
- data/lib/fog/rackspace/requests/cdn_v2/update_service.rb +3 -0
- data/lib/fog/vcloud_director/compute.rb +7 -4
- data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +15 -0
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +7 -1
- data/lib/fog/vsphere/models/compute/server.rb +3 -0
- data/lib/fog/vsphere/requests/compute/create_vm.rb +3 -0
- data/lib/fog/vsphere/requests/compute/get_datacenter.rb +1 -1
- data/lib/fog/vsphere/requests/compute/get_virtual_machine.rb +7 -1
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +3 -0
- data/lib/fog/xenserver/compute.rb +9 -8
- data/lib/fog/xenserver/core.rb +16 -16
- data/lib/fog/xenserver/requests/compute/create_server.rb +1 -1
- data/lib/fog/xenserver/requests/compute/create_vbd.rb +1 -1
- data/lib/fog/xenserver/requests/compute/create_vif.rb +1 -1
- data/lib/tasks/changelog_task.rb +1 -0
- data/spec/fog/bin_spec.rb +0 -3
- data/tests/cloudstack/compute/models/public_ip_address_tests.rb +27 -0
- data/tests/cloudstack/compute/models/public_ip_addresses_tests.rb +5 -0
- data/tests/compute/helper.rb +8 -0
- data/tests/helper.rb +1 -9
- data/tests/helpers/mock_helper.rb +1 -9
- data/tests/opennebula/models/compute/flavor_tests.rb +7 -0
- data/tests/opennebula/models/compute/flavors_tests.rb +0 -1
- data/tests/opennebula/models/compute/networks_tests.rb +1 -0
- data/tests/opennebula/requests/compute/vm_disk_snapshot_test.rb +49 -0
- data/tests/storage/helper.rb +0 -3
- metadata +25 -552
- data/lib/fog/bin/google.rb +0 -88
- data/lib/fog/bin/libvirt.rb +0 -58
- data/lib/fog/google.rb +0 -5
- data/lib/fog/google/README.md +0 -31
- data/lib/fog/google/Rakefile +0 -17
- data/lib/fog/google/compute.rb +0 -1070
- data/lib/fog/google/core.rb +0 -210
- data/lib/fog/google/dns.rb +0 -98
- data/lib/fog/google/examples/backend_services.rb +0 -22
- data/lib/fog/google/examples/bootstrap.rb +0 -9
- data/lib/fog/google/examples/create.rb +0 -49
- data/lib/fog/google/examples/dns/project.rb +0 -8
- data/lib/fog/google/examples/dns/zones.rb +0 -43
- data/lib/fog/google/examples/eric-fail.rb +0 -36
- data/lib/fog/google/examples/get_list_images.rb +0 -26
- data/lib/fog/google/examples/get_list_snapshots.rb +0 -18
- data/lib/fog/google/examples/image_all.rb +0 -6
- data/lib/fog/google/examples/image_create.rb +0 -17
- data/lib/fog/google/examples/l7_load_balance.rb +0 -73
- data/lib/fog/google/examples/launch_micro_instance.rb +0 -29
- data/lib/fog/google/examples/load-balance.rb +0 -98
- data/lib/fog/google/examples/metadata.rb +0 -30
- data/lib/fog/google/examples/monitoring/metric_descriptors.rb +0 -11
- data/lib/fog/google/examples/monitoring/timeseries_collection.rb +0 -15
- data/lib/fog/google/examples/monitoring/timeseries_descriptors.rb +0 -15
- data/lib/fog/google/examples/network.rb +0 -38
- data/lib/fog/google/examples/precreated_client.rb +0 -14
- data/lib/fog/google/examples/sql/flags.rb +0 -7
- data/lib/fog/google/examples/sql/instances.rb +0 -38
- data/lib/fog/google/examples/sql/operations.rb +0 -20
- data/lib/fog/google/examples/sql/ssl_certs.rb +0 -28
- data/lib/fog/google/examples/sql/tiers.rb +0 -7
- data/lib/fog/google/models/compute/address.rb +0 -94
- data/lib/fog/google/models/compute/addresses.rb +0 -40
- data/lib/fog/google/models/compute/backend_service.rb +0 -92
- data/lib/fog/google/models/compute/backend_services.rb +0 -22
- data/lib/fog/google/models/compute/disk.rb +0 -120
- data/lib/fog/google/models/compute/disk_type.rb +0 -28
- data/lib/fog/google/models/compute/disk_types.rb +0 -40
- data/lib/fog/google/models/compute/disks.rb +0 -41
- data/lib/fog/google/models/compute/firewall.rb +0 -46
- data/lib/fog/google/models/compute/firewalls.rb +0 -25
- data/lib/fog/google/models/compute/flavor.rb +0 -33
- data/lib/fog/google/models/compute/flavors.rb +0 -31
- data/lib/fog/google/models/compute/forwarding_rule.rb +0 -86
- data/lib/fog/google/models/compute/forwarding_rules.rb +0 -41
- data/lib/fog/google/models/compute/global_forwarding_rule.rb +0 -86
- data/lib/fog/google/models/compute/global_forwarding_rules.rb +0 -23
- data/lib/fog/google/models/compute/http_health_check.rb +0 -84
- data/lib/fog/google/models/compute/http_health_checks.rb +0 -26
- data/lib/fog/google/models/compute/image.rb +0 -90
- data/lib/fog/google/models/compute/images.rb +0 -73
- data/lib/fog/google/models/compute/network.rb +0 -43
- data/lib/fog/google/models/compute/networks.rb +0 -25
- data/lib/fog/google/models/compute/operation.rb +0 -75
- data/lib/fog/google/models/compute/operations.rb +0 -37
- data/lib/fog/google/models/compute/project.rb +0 -30
- data/lib/fog/google/models/compute/projects.rb +0 -20
- data/lib/fog/google/models/compute/region.rb +0 -32
- data/lib/fog/google/models/compute/regions.rb +0 -25
- data/lib/fog/google/models/compute/resource_view.rb +0 -116
- data/lib/fog/google/models/compute/resource_views.rb +0 -57
- data/lib/fog/google/models/compute/route.rb +0 -50
- data/lib/fog/google/models/compute/routes.rb +0 -25
- data/lib/fog/google/models/compute/server.rb +0 -258
- data/lib/fog/google/models/compute/servers.rb +0 -80
- data/lib/fog/google/models/compute/snapshot.rb +0 -48
- data/lib/fog/google/models/compute/snapshots.rb +0 -26
- data/lib/fog/google/models/compute/target_http_proxies.rb +0 -22
- data/lib/fog/google/models/compute/target_http_proxy.rb +0 -75
- data/lib/fog/google/models/compute/target_instance.rb +0 -74
- data/lib/fog/google/models/compute/target_instances.rb +0 -28
- data/lib/fog/google/models/compute/target_pool.rb +0 -113
- data/lib/fog/google/models/compute/target_pools.rb +0 -41
- data/lib/fog/google/models/compute/url_map.rb +0 -95
- data/lib/fog/google/models/compute/url_maps.rb +0 -22
- data/lib/fog/google/models/compute/zone.rb +0 -23
- data/lib/fog/google/models/compute/zones.rb +0 -24
- data/lib/fog/google/models/dns/change.rb +0 -40
- data/lib/fog/google/models/dns/changes.rb +0 -52
- data/lib/fog/google/models/dns/project.rb +0 -75
- data/lib/fog/google/models/dns/projects.rb +0 -25
- data/lib/fog/google/models/dns/record.rb +0 -112
- data/lib/fog/google/models/dns/records.rb +0 -52
- data/lib/fog/google/models/dns/zone.rb +0 -74
- data/lib/fog/google/models/dns/zones.rb +0 -34
- data/lib/fog/google/models/monitoring/metric_descriptor.rb +0 -20
- data/lib/fog/google/models/monitoring/metric_descriptors.rb +0 -28
- data/lib/fog/google/models/monitoring/timeseries.rb +0 -17
- data/lib/fog/google/models/monitoring/timeseries_collection.rb +0 -31
- data/lib/fog/google/models/monitoring/timeseries_descriptor.rb +0 -20
- data/lib/fog/google/models/monitoring/timeseries_descriptors.rb +0 -31
- data/lib/fog/google/models/sql/backup_run.rb +0 -34
- data/lib/fog/google/models/sql/backup_runs.rb +0 -38
- data/lib/fog/google/models/sql/flag.rb +0 -22
- data/lib/fog/google/models/sql/flags.rb +0 -21
- data/lib/fog/google/models/sql/instance.rb +0 -353
- data/lib/fog/google/models/sql/instances.rb +0 -39
- data/lib/fog/google/models/sql/operation.rb +0 -61
- data/lib/fog/google/models/sql/operations.rb +0 -49
- data/lib/fog/google/models/sql/ssl_cert.rb +0 -73
- data/lib/fog/google/models/sql/ssl_certs.rb +0 -49
- data/lib/fog/google/models/sql/tier.rb +0 -20
- data/lib/fog/google/models/sql/tiers.rb +0 -21
- data/lib/fog/google/models/storage/directories.rb +0 -39
- data/lib/fog/google/models/storage/directory.rb +0 -74
- data/lib/fog/google/models/storage/file.rb +0 -144
- data/lib/fog/google/models/storage/files.rb +0 -104
- data/lib/fog/google/monitoring.rb +0 -89
- data/lib/fog/google/parsers/storage/access_control_list.rb +0 -44
- data/lib/fog/google/parsers/storage/copy_object.rb +0 -18
- data/lib/fog/google/parsers/storage/get_bucket.rb +0 -58
- data/lib/fog/google/parsers/storage/get_bucket_logging.rb +0 -36
- data/lib/fog/google/parsers/storage/get_bucket_object_versions.rb +0 -84
- data/lib/fog/google/parsers/storage/get_bucket_versioning.rb +0 -20
- data/lib/fog/google/parsers/storage/get_request_payment.rb +0 -16
- data/lib/fog/google/parsers/storage/get_service.rb +0 -28
- data/lib/fog/google/requests/compute/add_backend_service_backends.rb +0 -29
- data/lib/fog/google/requests/compute/add_region_view_resources.rb +0 -27
- data/lib/fog/google/requests/compute/add_server_access_config.rb +0 -32
- data/lib/fog/google/requests/compute/add_target_pool_health_checks.rb +0 -27
- data/lib/fog/google/requests/compute/add_target_pool_instances.rb +0 -27
- data/lib/fog/google/requests/compute/add_url_map_host_rules.rb +0 -25
- data/lib/fog/google/requests/compute/add_url_map_path_matchers.rb +0 -29
- data/lib/fog/google/requests/compute/add_zone_view_resources.rb +0 -27
- data/lib/fog/google/requests/compute/attach_disk.rb +0 -34
- data/lib/fog/google/requests/compute/delete_address.rb +0 -24
- data/lib/fog/google/requests/compute/delete_backend_service.rb +0 -43
- data/lib/fog/google/requests/compute/delete_disk.rb +0 -48
- data/lib/fog/google/requests/compute/delete_firewall.rb +0 -23
- data/lib/fog/google/requests/compute/delete_forwarding_rule.rb +0 -49
- data/lib/fog/google/requests/compute/delete_global_forwarding_rule.rb +0 -48
- data/lib/fog/google/requests/compute/delete_global_operation.rb +0 -25
- data/lib/fog/google/requests/compute/delete_http_health_check.rb +0 -41
- data/lib/fog/google/requests/compute/delete_image.rb +0 -42
- data/lib/fog/google/requests/compute/delete_network.rb +0 -23
- data/lib/fog/google/requests/compute/delete_region_operation.rb +0 -29
- data/lib/fog/google/requests/compute/delete_region_view.rb +0 -24
- data/lib/fog/google/requests/compute/delete_route.rb +0 -23
- data/lib/fog/google/requests/compute/delete_server.rb +0 -69
- data/lib/fog/google/requests/compute/delete_server_access_config.rb +0 -26
- data/lib/fog/google/requests/compute/delete_snapshot.rb +0 -23
- data/lib/fog/google/requests/compute/delete_target_http_proxy.rb +0 -43
- data/lib/fog/google/requests/compute/delete_target_instance.rb +0 -48
- data/lib/fog/google/requests/compute/delete_target_pool.rb +0 -49
- data/lib/fog/google/requests/compute/delete_url_map.rb +0 -43
- data/lib/fog/google/requests/compute/delete_zone_operation.rb +0 -29
- data/lib/fog/google/requests/compute/delete_zone_view.rb +0 -24
- data/lib/fog/google/requests/compute/detach_disk.rb +0 -25
- data/lib/fog/google/requests/compute/get_address.rb +0 -24
- data/lib/fog/google/requests/compute/get_backend_service.rb +0 -26
- data/lib/fog/google/requests/compute/get_backend_service_health.rb +0 -27
- data/lib/fog/google/requests/compute/get_backend_services.rb +0 -23
- data/lib/fog/google/requests/compute/get_disk.rb +0 -52
- data/lib/fog/google/requests/compute/get_disk_type.rb +0 -42
- data/lib/fog/google/requests/compute/get_firewall.rb +0 -23
- data/lib/fog/google/requests/compute/get_forwarding_rule.rb +0 -46
- data/lib/fog/google/requests/compute/get_global_forwarding_rule.rb +0 -32
- data/lib/fog/google/requests/compute/get_global_operation.rb +0 -50
- data/lib/fog/google/requests/compute/get_http_health_check.rb +0 -39
- data/lib/fog/google/requests/compute/get_image.rb +0 -36
- data/lib/fog/google/requests/compute/get_machine_type.rb +0 -43
- data/lib/fog/google/requests/compute/get_network.rb +0 -23
- data/lib/fog/google/requests/compute/get_project.rb +0 -22
- data/lib/fog/google/requests/compute/get_region.rb +0 -37
- data/lib/fog/google/requests/compute/get_region_operation.rb +0 -55
- data/lib/fog/google/requests/compute/get_region_view.rb +0 -24
- data/lib/fog/google/requests/compute/get_route.rb +0 -23
- data/lib/fog/google/requests/compute/get_server.rb +0 -75
- data/lib/fog/google/requests/compute/get_server_serial_port_output.rb +0 -24
- data/lib/fog/google/requests/compute/get_snapshot.rb +0 -27
- data/lib/fog/google/requests/compute/get_target_http_proxy.rb +0 -27
- data/lib/fog/google/requests/compute/get_target_instance.rb +0 -32
- data/lib/fog/google/requests/compute/get_target_pool.rb +0 -40
- data/lib/fog/google/requests/compute/get_target_pool_health.rb +0 -29
- data/lib/fog/google/requests/compute/get_url_map.rb +0 -27
- data/lib/fog/google/requests/compute/get_zone.rb +0 -36
- data/lib/fog/google/requests/compute/get_zone_operation.rb +0 -55
- data/lib/fog/google/requests/compute/get_zone_view.rb +0 -24
- data/lib/fog/google/requests/compute/insert_address.rb +0 -25
- data/lib/fog/google/requests/compute/insert_backend_service.rb +0 -63
- data/lib/fog/google/requests/compute/insert_disk.rb +0 -113
- data/lib/fog/google/requests/compute/insert_firewall.rb +0 -43
- data/lib/fog/google/requests/compute/insert_forwarding_rule.rb +0 -60
- data/lib/fog/google/requests/compute/insert_global_forwarding_rule.rb +0 -56
- data/lib/fog/google/requests/compute/insert_http_health_check.rb +0 -59
- data/lib/fog/google/requests/compute/insert_image.rb +0 -64
- data/lib/fog/google/requests/compute/insert_network.rb +0 -29
- data/lib/fog/google/requests/compute/insert_region_view.rb +0 -25
- data/lib/fog/google/requests/compute/insert_route.rb +0 -35
- data/lib/fog/google/requests/compute/insert_server.rb +0 -191
- data/lib/fog/google/requests/compute/insert_snapshot.rb +0 -40
- data/lib/fog/google/requests/compute/insert_target_http_proxy.rb +0 -52
- data/lib/fog/google/requests/compute/insert_target_instance.rb +0 -55
- data/lib/fog/google/requests/compute/insert_target_pool.rb +0 -58
- data/lib/fog/google/requests/compute/insert_url_map.rb +0 -55
- data/lib/fog/google/requests/compute/insert_zone_view.rb +0 -27
- data/lib/fog/google/requests/compute/list_addresses.rb +0 -23
- data/lib/fog/google/requests/compute/list_aggregated_addresses.rb +0 -23
- data/lib/fog/google/requests/compute/list_aggregated_disk_types.rb +0 -40
- data/lib/fog/google/requests/compute/list_aggregated_disks.rb +0 -40
- data/lib/fog/google/requests/compute/list_aggregated_machine_types.rb +0 -22
- data/lib/fog/google/requests/compute/list_aggregated_servers.rb +0 -40
- data/lib/fog/google/requests/compute/list_backend_services.rb +0 -29
- data/lib/fog/google/requests/compute/list_disk_types.rb +0 -46
- data/lib/fog/google/requests/compute/list_disks.rb +0 -29
- data/lib/fog/google/requests/compute/list_firewalls.rb +0 -22
- data/lib/fog/google/requests/compute/list_forwarding_rules.rb +0 -29
- data/lib/fog/google/requests/compute/list_global_forwarding_rules.rb +0 -30
- data/lib/fog/google/requests/compute/list_global_operations.rb +0 -24
- data/lib/fog/google/requests/compute/list_http_health_checks.rb +0 -29
- data/lib/fog/google/requests/compute/list_images.rb +0 -29
- data/lib/fog/google/requests/compute/list_machine_types.rb +0 -30
- data/lib/fog/google/requests/compute/list_networks.rb +0 -22
- data/lib/fog/google/requests/compute/list_region_operations.rb +0 -25
- data/lib/fog/google/requests/compute/list_region_view_resources.rb +0 -25
- data/lib/fog/google/requests/compute/list_region_views.rb +0 -23
- data/lib/fog/google/requests/compute/list_regions.rb +0 -85
- data/lib/fog/google/requests/compute/list_routes.rb +0 -22
- data/lib/fog/google/requests/compute/list_servers.rb +0 -31
- data/lib/fog/google/requests/compute/list_snapshots.rb +0 -23
- data/lib/fog/google/requests/compute/list_target_http_proxies.rb +0 -30
- data/lib/fog/google/requests/compute/list_target_instances.rb +0 -30
- data/lib/fog/google/requests/compute/list_target_pools.rb +0 -29
- data/lib/fog/google/requests/compute/list_url_maps.rb +0 -29
- data/lib/fog/google/requests/compute/list_zone_operations.rb +0 -25
- data/lib/fog/google/requests/compute/list_zone_view_resources.rb +0 -25
- data/lib/fog/google/requests/compute/list_zone_views.rb +0 -23
- data/lib/fog/google/requests/compute/list_zones.rb +0 -28
- data/lib/fog/google/requests/compute/remove_target_pool_health_checks.rb +0 -27
- data/lib/fog/google/requests/compute/remove_target_pool_instance.rb +0 -27
- data/lib/fog/google/requests/compute/remove_target_pool_instances.rb +0 -27
- data/lib/fog/google/requests/compute/reset_server.rb +0 -24
- data/lib/fog/google/requests/compute/set_common_instance_metadata.rb +0 -26
- data/lib/fog/google/requests/compute/set_forwarding_rule_target.rb +0 -27
- data/lib/fog/google/requests/compute/set_global_forwarding_rule_target.rb +0 -27
- data/lib/fog/google/requests/compute/set_metadata.rb +0 -39
- data/lib/fog/google/requests/compute/set_server_disk_auto_delete.rb +0 -26
- data/lib/fog/google/requests/compute/set_server_scheduling.rb +0 -29
- data/lib/fog/google/requests/compute/set_tags.rb +0 -24
- data/lib/fog/google/requests/compute/set_target_http_proxy_url_map.rb +0 -27
- data/lib/fog/google/requests/compute/start_server.rb +0 -24
- data/lib/fog/google/requests/compute/stop_server.rb +0 -24
- data/lib/fog/google/requests/compute/update_url_map.rb +0 -39
- data/lib/fog/google/requests/compute/validate_url_map.rb +0 -24
- data/lib/fog/google/requests/dns/create_change.rb +0 -64
- data/lib/fog/google/requests/dns/create_managed_zone.rb +0 -82
- data/lib/fog/google/requests/dns/delete_managed_zone.rb +0 -35
- data/lib/fog/google/requests/dns/get_change.rb +0 -42
- data/lib/fog/google/requests/dns/get_managed_zone.rb +0 -37
- data/lib/fog/google/requests/dns/get_project.rb +0 -42
- data/lib/fog/google/requests/dns/list_changes.rb +0 -41
- data/lib/fog/google/requests/dns/list_managed_zones.rb +0 -31
- data/lib/fog/google/requests/dns/list_resource_record_sets.rb +0 -50
- data/lib/fog/google/requests/monitoring/list_metric_descriptors.rb +0 -191
- data/lib/fog/google/requests/monitoring/list_timeseries.rb +0 -68
- data/lib/fog/google/requests/monitoring/list_timeseries_descriptors.rb +0 -87
- data/lib/fog/google/requests/sql/clone_instance.rb +0 -84
- data/lib/fog/google/requests/sql/delete_instance.rb +0 -67
- data/lib/fog/google/requests/sql/delete_ssl_cert.rb +0 -68
- data/lib/fog/google/requests/sql/export_instance.rb +0 -56
- data/lib/fog/google/requests/sql/get_backup_run.rb +0 -30
- data/lib/fog/google/requests/sql/get_instance.rb +0 -48
- data/lib/fog/google/requests/sql/get_operation.rb +0 -66
- data/lib/fog/google/requests/sql/get_ssl_cert.rb +0 -66
- data/lib/fog/google/requests/sql/import_instance.rb +0 -55
- data/lib/fog/google/requests/sql/insert_instance.rb +0 -165
- data/lib/fog/google/requests/sql/insert_ssl_cert.rb +0 -80
- data/lib/fog/google/requests/sql/list_backup_runs.rb +0 -30
- data/lib/fog/google/requests/sql/list_flags.rb +0 -143
- data/lib/fog/google/requests/sql/list_instances.rb +0 -32
- data/lib/fog/google/requests/sql/list_operations.rb +0 -52
- data/lib/fog/google/requests/sql/list_ssl_certs.rb +0 -51
- data/lib/fog/google/requests/sql/list_tiers.rb +0 -82
- data/lib/fog/google/requests/sql/reset_instance_ssl_config.rb +0 -49
- data/lib/fog/google/requests/sql/restart_instance.rb +0 -47
- data/lib/fog/google/requests/sql/restore_instance_backup.rb +0 -30
- data/lib/fog/google/requests/sql/set_instance_root_password.rb +0 -54
- data/lib/fog/google/requests/sql/update_instance.rb +0 -132
- data/lib/fog/google/requests/storage/copy_object.rb +0 -68
- data/lib/fog/google/requests/storage/delete_bucket.rb +0 -41
- data/lib/fog/google/requests/storage/delete_object.rb +0 -46
- data/lib/fog/google/requests/storage/get_bucket.rb +0 -106
- data/lib/fog/google/requests/storage/get_bucket_acl.rb +0 -59
- data/lib/fog/google/requests/storage/get_object.rb +0 -108
- data/lib/fog/google/requests/storage/get_object_acl.rb +0 -70
- data/lib/fog/google/requests/storage/get_object_http_url.rb +0 -44
- data/lib/fog/google/requests/storage/get_object_https_url.rb +0 -44
- data/lib/fog/google/requests/storage/get_object_torrent.rb +0 -45
- data/lib/fog/google/requests/storage/get_object_url.rb +0 -33
- data/lib/fog/google/requests/storage/get_service.rb +0 -48
- data/lib/fog/google/requests/storage/head_object.rb +0 -60
- data/lib/fog/google/requests/storage/put_bucket.rb +0 -71
- data/lib/fog/google/requests/storage/put_bucket_acl.rb +0 -58
- data/lib/fog/google/requests/storage/put_object.rb +0 -89
- data/lib/fog/google/requests/storage/put_object_acl.rb +0 -51
- data/lib/fog/google/requests/storage/put_object_url.rb +0 -50
- data/lib/fog/google/sql.rb +0 -132
- data/lib/fog/google/storage.rb +0 -300
- data/lib/fog/libvirt.rb +0 -1
- data/lib/fog/libvirt/compute.rb +0 -137
- data/lib/fog/libvirt/core.rb +0 -11
- data/lib/fog/libvirt/models/compute/README.md +0 -76
- data/lib/fog/libvirt/models/compute/interface.rb +0 -25
- data/lib/fog/libvirt/models/compute/interfaces.rb +0 -20
- data/lib/fog/libvirt/models/compute/network.rb +0 -29
- data/lib/fog/libvirt/models/compute/networks.rb +0 -20
- data/lib/fog/libvirt/models/compute/nic.rb +0 -50
- data/lib/fog/libvirt/models/compute/nics.rb +0 -12
- data/lib/fog/libvirt/models/compute/node.rb +0 -29
- data/lib/fog/libvirt/models/compute/nodes.rb +0 -20
- data/lib/fog/libvirt/models/compute/pool.rb +0 -84
- data/lib/fog/libvirt/models/compute/pools.rb +0 -20
- data/lib/fog/libvirt/models/compute/server.rb +0 -401
- data/lib/fog/libvirt/models/compute/servers.rb +0 -21
- data/lib/fog/libvirt/models/compute/templates/network.xml.erb +0 -6
- data/lib/fog/libvirt/models/compute/templates/pool.xml.erb +0 -6
- data/lib/fog/libvirt/models/compute/templates/server.xml.erb +0 -54
- data/lib/fog/libvirt/models/compute/templates/volume.xml.erb +0 -26
- data/lib/fog/libvirt/models/compute/util/uri.rb +0 -138
- data/lib/fog/libvirt/models/compute/util/util.rb +0 -32
- data/lib/fog/libvirt/models/compute/volume.rb +0 -122
- data/lib/fog/libvirt/models/compute/volumes.rb +0 -20
- data/lib/fog/libvirt/requests/compute/clone_volume.rb +0 -18
- data/lib/fog/libvirt/requests/compute/create_domain.rb +0 -17
- data/lib/fog/libvirt/requests/compute/create_volume.rb +0 -16
- data/lib/fog/libvirt/requests/compute/define_domain.rb +0 -17
- data/lib/fog/libvirt/requests/compute/define_pool.rb +0 -16
- data/lib/fog/libvirt/requests/compute/destroy_interface.rb +0 -18
- data/lib/fog/libvirt/requests/compute/destroy_network.rb +0 -17
- data/lib/fog/libvirt/requests/compute/get_node_info.rb +0 -37
- data/lib/fog/libvirt/requests/compute/list_domains.rb +0 -105
- data/lib/fog/libvirt/requests/compute/list_interfaces.rb +0 -57
- data/lib/fog/libvirt/requests/compute/list_networks.rb +0 -55
- data/lib/fog/libvirt/requests/compute/list_pool_volumes.rb +0 -19
- data/lib/fog/libvirt/requests/compute/list_pools.rb +0 -71
- data/lib/fog/libvirt/requests/compute/list_volumes.rb +0 -88
- data/lib/fog/libvirt/requests/compute/mock_files/domain.xml +0 -40
- data/lib/fog/libvirt/requests/compute/pool_action.rb +0 -19
- data/lib/fog/libvirt/requests/compute/update_display.rb +0 -31
- data/lib/fog/libvirt/requests/compute/vm_action.rb +0 -19
- data/lib/fog/libvirt/requests/compute/volume_action.rb +0 -18
- data/spec/fog/bin/libvirt_spec.rb +0 -10
- data/tests/brightbox/compute/image_selector_tests.rb +0 -103
- data/tests/google/credentials_tests.rb +0 -73
- data/tests/google/helpers/google_tests_helper.rb +0 -89
- data/tests/google/models/compute/backend_service_tests.rb +0 -6
- data/tests/google/models/compute/backend_services_tests.rb +0 -8
- data/tests/google/models/compute/disk_tests.rb +0 -9
- data/tests/google/models/compute/disk_types_tests.rb +0 -22
- data/tests/google/models/compute/disks_tests.rb +0 -9
- data/tests/google/models/compute/forwarding_rule_tests.rb +0 -8
- data/tests/google/models/compute/forwarding_rules_tests.rb +0 -8
- data/tests/google/models/compute/global_forwarding_rule_tests.rb +0 -7
- data/tests/google/models/compute/global_forwarding_rules_tests.rb +0 -7
- data/tests/google/models/compute/http_health_check_tests.rb +0 -5
- data/tests/google/models/compute/http_health_checks_tests.rb +0 -5
- data/tests/google/models/compute/image_tests.rb +0 -6
- data/tests/google/models/compute/images_tests.rb +0 -6
- data/tests/google/models/compute/region_tests.rb +0 -10
- data/tests/google/models/compute/regions_tests.rb +0 -19
- data/tests/google/models/compute/server_tests.rb +0 -37
- data/tests/google/models/compute/servers_tests.rb +0 -14
- data/tests/google/models/compute/target_http_proxies_tests.rb +0 -7
- data/tests/google/models/compute/target_http_proxy_test.rb +0 -6
- data/tests/google/models/compute/target_instance_tests.rb +0 -7
- data/tests/google/models/compute/target_instances_tests.rb +0 -7
- data/tests/google/models/compute/target_pool_tests.rb +0 -12
- data/tests/google/models/compute/target_pools_tests.rb +0 -11
- data/tests/google/models/compute/url_map_tests.rb +0 -6
- data/tests/google/models/compute/url_maps_tests.rb +0 -7
- data/tests/google/models/dns/change_tests.rb +0 -28
- data/tests/google/models/dns/changes_tests.rb +0 -36
- data/tests/google/models/dns/projects_tests.rb +0 -12
- data/tests/google/models/dns/record_tests.rb +0 -42
- data/tests/google/models/dns/records_tests.rb +0 -36
- data/tests/google/models/dns/zone_tests.rb +0 -28
- data/tests/google/models/dns/zones_tests.rb +0 -14
- data/tests/google/models/monitoring/metric_descriptors_tests.rb +0 -12
- data/tests/google/models/monitoring/timeseries_collection_tests.rb +0 -12
- data/tests/google/models/monitoring/timeseries_descriptors_tests.rb +0 -13
- data/tests/google/models/sql/flags_tests.rb +0 -12
- data/tests/google/models/sql/instance_tests.rb +0 -56
- data/tests/google/models/sql/instances_tests.rb +0 -32
- data/tests/google/models/sql/operation_tests.rb +0 -25
- data/tests/google/models/sql/operations_tests.rb +0 -38
- data/tests/google/models/sql/ssl_cert_tests.rb +0 -24
- data/tests/google/models/sql/ssl_certs_tests.rb +0 -39
- data/tests/google/models/sql/tiers_tests.rb +0 -12
- data/tests/google/requests/compute/backend_service_tests.rb +0 -83
- data/tests/google/requests/compute/disk_tests.rb +0 -74
- data/tests/google/requests/compute/disk_type_tests.rb +0 -45
- data/tests/google/requests/compute/firewall_tests.rb +0 -88
- data/tests/google/requests/compute/forwarding_rules_tests.rb +0 -83
- data/tests/google/requests/compute/global_forwarding_rules_tests.rb +0 -83
- data/tests/google/requests/compute/http_health_checks_tests.rb +0 -83
- data/tests/google/requests/compute/image_tests.rb +0 -83
- data/tests/google/requests/compute/network_tests.rb +0 -75
- data/tests/google/requests/compute/operation_tests.rb +0 -20
- data/tests/google/requests/compute/region_tests.rb +0 -39
- data/tests/google/requests/compute/server_tests.rb +0 -84
- data/tests/google/requests/compute/target_http_proxies_test.rb +0 -79
- data/tests/google/requests/compute/target_instances_tests.rb +0 -83
- data/tests/google/requests/compute/target_pools_tests.rb +0 -82
- data/tests/google/requests/compute/url_maps_tests.rb +0 -82
- data/tests/google/requests/compute/zone_tests.rb +0 -37
- data/tests/google/requests/dns/change_tests.rb +0 -86
- data/tests/google/requests/dns/managed_zone_tests.rb +0 -66
- data/tests/google/requests/dns/project_tests.rb +0 -29
- data/tests/google/requests/dns/record_tests.rb +0 -49
- data/tests/google/requests/monitoring/metric_descriptor_tests.rb +0 -25
- data/tests/google/requests/monitoring/timeseries_collection_tests.rb +0 -25
- data/tests/google/requests/monitoring/timeseries_descriptor_tests.rb +0 -26
- data/tests/google/requests/sql/flag_tests.rb +0 -27
- data/tests/google/requests/sql/instance_tests.rb +0 -129
- data/tests/google/requests/sql/operation_tests.rb +0 -42
- data/tests/google/requests/sql/ssl_cert_tests.rb +0 -61
- data/tests/google/requests/sql/tier_tests.rb +0 -25
- data/tests/google/requests/storage/bucket_tests.rb +0 -77
- data/tests/google/requests/storage/object_tests.rb +0 -84
- data/tests/libvirt/compute_tests.rb +0 -17
- data/tests/libvirt/models/compute/interface_tests.rb +0 -27
- data/tests/libvirt/models/compute/interfaces_tests.rb +0 -14
- data/tests/libvirt/models/compute/network_tests.rb +0 -27
- data/tests/libvirt/models/compute/networks_tests.rb +0 -13
- data/tests/libvirt/models/compute/nic_tests.rb +0 -31
- data/tests/libvirt/models/compute/nics_tests.rb +0 -10
- data/tests/libvirt/models/compute/pool_tests.rb +0 -27
- data/tests/libvirt/models/compute/pools_tests.rb +0 -13
- data/tests/libvirt/models/compute/server_tests.rb +0 -58
- data/tests/libvirt/models/compute/servers_tests.rb +0 -14
- data/tests/libvirt/models/compute/volume_tests.rb +0 -38
- data/tests/libvirt/models/compute/volumes_tests.rb +0 -14
- data/tests/libvirt/requests/compute/create_domain_tests.rb +0 -21
- data/tests/libvirt/requests/compute/define_domain_tests.rb +0 -11
- data/tests/libvirt/requests/compute/update_display.rb +0 -13
data/lib/fog/openstack/core.rb
CHANGED
@@ -182,7 +182,6 @@ module Fog
|
|
182
182
|
identity_service_type = options[:openstack_identity_service_type]
|
183
183
|
endpoint_type = (options[:openstack_endpoint_type] || 'public').to_s
|
184
184
|
openstack_region = options[:openstack_region]
|
185
|
-
domain_name = options[:openstack_domain]
|
186
185
|
|
187
186
|
body, token_headers = retrieve_tokens_v3(options, connection_options)
|
188
187
|
|
@@ -212,8 +211,10 @@ module Fog
|
|
212
211
|
service = get_service(body, service_type, service_name)
|
213
212
|
end
|
214
213
|
|
214
|
+
endpoint_type = 'public'
|
215
|
+
|
215
216
|
service['endpoints'] = service['endpoints'].select do |endpoint|
|
216
|
-
endpoint['region'] == openstack_region
|
217
|
+
endpoint['region'] == openstack_region && endpoint['interface'] == endpoint_type
|
217
218
|
end if openstack_region
|
218
219
|
|
219
220
|
if service['endpoints'].empty?
|
@@ -245,7 +246,6 @@ module Fog
|
|
245
246
|
identity_service = get_service(body, identity_service_type) if identity_service_type
|
246
247
|
tenant = body['token']['project']['name']
|
247
248
|
user = body['token']['user']['name']
|
248
|
-
endpoint_type = 'public'
|
249
249
|
|
250
250
|
management_url = service['endpoints'].find{|s| s["interface"][endpoint_type]}["url"]
|
251
251
|
identity_url = identity_service['endpoints'].find{|s| s["interface"]["public"]}["url"] if identity_service
|
@@ -319,10 +319,15 @@ module Fog
|
|
319
319
|
def self.retrieve_tokens_v3(options, connection_options = {})
|
320
320
|
api_key = options[:openstack_api_key].to_s
|
321
321
|
username = options[:openstack_username].to_s
|
322
|
-
|
322
|
+
if options[:openstack_tenant_id]
|
323
|
+
tenant_id = options[:openstack_tenant_id].to_s
|
324
|
+
else
|
325
|
+
tenant_name = options[:openstack_tenant].to_s
|
326
|
+
end
|
323
327
|
auth_token = options[:openstack_auth_token] || options[:unscoped_token]
|
324
328
|
uri = options[:openstack_auth_uri]
|
325
|
-
|
329
|
+
userdomain = options[:openstack_user_domain] || options[:openstack_domain]
|
330
|
+
project_domain = options[:openstack_project_domain] || options[:openstack_domain] || 'Default'
|
326
331
|
|
327
332
|
connection = Fog::Core::Connection.new(uri.to_s, false, connection_options)
|
328
333
|
request_body = {:auth => Hash.new}
|
@@ -337,21 +342,29 @@ module Fog
|
|
337
342
|
:password => {
|
338
343
|
:user => {
|
339
344
|
:domain => {
|
340
|
-
:name =>
|
345
|
+
:name => userdomain
|
341
346
|
},
|
342
347
|
:name => username,
|
343
348
|
:password => api_key
|
344
349
|
}
|
345
350
|
}
|
346
351
|
}
|
347
|
-
|
348
|
-
:
|
349
|
-
:
|
350
|
-
:
|
351
|
-
}
|
352
|
-
:id => tenant_name
|
352
|
+
unless tenant_id.nil?
|
353
|
+
request_body[:auth][:scope] = {
|
354
|
+
:project => {
|
355
|
+
:id => tenant_id
|
356
|
+
}
|
353
357
|
}
|
354
|
-
|
358
|
+
else
|
359
|
+
request_body[:auth][:scope] = {
|
360
|
+
:project => {
|
361
|
+
:domain => {
|
362
|
+
:name => project_domain
|
363
|
+
},
|
364
|
+
:name => tenant_name
|
365
|
+
}
|
366
|
+
}
|
367
|
+
end
|
355
368
|
end
|
356
369
|
|
357
370
|
response = connection.request({
|
@@ -9,7 +9,7 @@ module Fog
|
|
9
9
|
|
10
10
|
identity :id
|
11
11
|
|
12
|
-
%w{resource_name description links logical_resource_id resource_status
|
12
|
+
%w{resource_name description links logical_resource_id physical_resource_id resource_status
|
13
13
|
updated_time required_by resource_status_reason resource_type}.each do |a|
|
14
14
|
attribute a.to_sym
|
15
15
|
end
|
@@ -6,7 +6,7 @@ module Fog
|
|
6
6
|
identity :id
|
7
7
|
|
8
8
|
%w{capabilities description disable_rollback links notification_topics outputs parameters
|
9
|
-
stack_name stack_status stack_status_reason template_description timeout_mins
|
9
|
+
stack_name stack_status stack_status_reason template_description timeout_mins parent
|
10
10
|
creation_time updated_time}.each do |a|
|
11
11
|
attribute a.to_sym
|
12
12
|
end
|
@@ -8,8 +8,10 @@ module Fog
|
|
8
8
|
requires :openstack_auth_url
|
9
9
|
recognizes :openstack_auth_token, :openstack_management_url, :persistent,
|
10
10
|
:openstack_service_type, :openstack_service_name, :openstack_tenant,
|
11
|
+
:openstack_tenant_id,
|
11
12
|
:openstack_api_key, :openstack_username, :openstack_endpoint_type,
|
12
|
-
:current_user, :current_tenant, :openstack_region
|
13
|
+
:current_user, :current_tenant, :openstack_region,
|
14
|
+
:openstack_project_domain, :openstack_user_domain
|
13
15
|
|
14
16
|
## MODELS
|
15
17
|
#
|
@@ -204,6 +206,7 @@ module Fog
|
|
204
206
|
def initialize(options={})
|
205
207
|
@openstack_username = options[:openstack_username]
|
206
208
|
@openstack_tenant = options[:openstack_tenant]
|
209
|
+
@openstack_tenant_id = options[:openstack_tenant_id]
|
207
210
|
end
|
208
211
|
|
209
212
|
def data
|
@@ -225,6 +228,8 @@ module Fog
|
|
225
228
|
class Real
|
226
229
|
attr_reader :current_user
|
227
230
|
attr_reader :current_tenant
|
231
|
+
attr_reader :openstack_user_domain
|
232
|
+
attr_reader :openstack_project_domain
|
228
233
|
|
229
234
|
def initialize(options={})
|
230
235
|
@openstack_auth_token = options[:openstack_auth_token]
|
@@ -233,6 +238,8 @@ module Fog
|
|
233
238
|
missing_credentials = Array.new
|
234
239
|
@openstack_api_key = options[:openstack_api_key]
|
235
240
|
@openstack_username = options[:openstack_username]
|
241
|
+
@openstack_user_domain = options[:openstack_user_domain] || options[:openstack_domain]
|
242
|
+
@openstack_project_domain = options[:openstack_project_domain] || options[:openstack_domain] || 'Default'
|
236
243
|
|
237
244
|
missing_credentials << :openstack_api_key unless @openstack_api_key
|
238
245
|
missing_credentials << :openstack_username unless @openstack_username
|
@@ -240,6 +247,9 @@ module Fog
|
|
240
247
|
end
|
241
248
|
|
242
249
|
@openstack_tenant = options[:openstack_tenant]
|
250
|
+
@openstack_tenant_id = options[:openstack_tenant_id]
|
251
|
+
@openstack_user_domain = options[:openstack_user_domain] || options[:openstack_domain]
|
252
|
+
@openstack_project_domain = options[:openstack_project_domain] || options[:openstack_domain] || 'Default'
|
243
253
|
@openstack_auth_uri = URI.parse(options[:openstack_auth_url])
|
244
254
|
@openstack_management_url = options[:openstack_management_url]
|
245
255
|
@openstack_must_reauthenticate = false
|
@@ -261,6 +271,9 @@ module Fog
|
|
261
271
|
|
262
272
|
def credentials
|
263
273
|
{ :provider => 'openstack',
|
274
|
+
:openstack_tenant_id => @openstack_tenant_id,
|
275
|
+
:openstack_user_domain => @openstack_user_domain,
|
276
|
+
:openstack_project_domain => @openstack_project_domain,
|
264
277
|
:openstack_auth_url => @openstack_auth_uri.to_s,
|
265
278
|
:openstack_auth_token => @auth_token,
|
266
279
|
:openstack_management_url => @openstack_management_url,
|
@@ -310,18 +323,29 @@ module Fog
|
|
310
323
|
def authenticate
|
311
324
|
if !@openstack_management_url || @openstack_must_reauthenticate
|
312
325
|
options = {
|
313
|
-
:openstack_tenant
|
314
|
-
:
|
315
|
-
:
|
316
|
-
:
|
317
|
-
:
|
318
|
-
:
|
319
|
-
:
|
326
|
+
:openstack_tenant => @openstack_tenant,
|
327
|
+
:openstack_tenant_id => @openstack_tenant_id,
|
328
|
+
:openstack_api_key => @openstack_api_key,
|
329
|
+
:openstack_username => @openstack_username,
|
330
|
+
:openstack_user_domain => @openstack_user_domain,
|
331
|
+
:openstack_project_domain => @openstack_project_domain,
|
332
|
+
:openstack_auth_uri => @openstack_auth_uri,
|
333
|
+
:openstack_auth_token => @openstack_must_reauthenticate ? nil : @openstack_auth_token,
|
334
|
+
:openstack_service_type => @openstack_service_type,
|
335
|
+
:openstack_service_name => @openstack_service_name,
|
320
336
|
:openstack_endpoint_type => @openstack_endpoint_type,
|
321
|
-
:openstack_region
|
337
|
+
:openstack_region => @openstack_region
|
322
338
|
}
|
323
339
|
|
324
|
-
|
340
|
+
case @openstack_auth_uri.path
|
341
|
+
when %r{/v2.0}
|
342
|
+
credentials = Fog::OpenStack.authenticate_v2(options, @connection_options)
|
343
|
+
when %r{/v3}
|
344
|
+
credentials = Fog::OpenStack.authenticate_v3(options, @connection_options)
|
345
|
+
else
|
346
|
+
credentials = Fog::OpenStack.authenticate_v2(options, @connection_options)
|
347
|
+
end
|
348
|
+
|
325
349
|
|
326
350
|
@current_user = credentials[:user]
|
327
351
|
@current_tenant = credentials[:tenant]
|
@@ -13,7 +13,7 @@ module Fog
|
|
13
13
|
# * response<~Excon::Response>:
|
14
14
|
# * body<~String> - url for object
|
15
15
|
def get_object_http_url(container, object, expires, options = {})
|
16
|
-
create_temp_url(container, object, expires, "GET", options.merge(:scheme => "http"))
|
16
|
+
create_temp_url(container, object, expires, "GET", {:port => 80}.merge(options).merge(:scheme => "http"))
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
@@ -13,7 +13,7 @@ module Fog
|
|
13
13
|
# * response<~Excon::Response>:
|
14
14
|
# * body<~String> - url for object
|
15
15
|
def get_object_https_url(container, object, expires, options = {})
|
16
|
-
create_temp_url(container, object, expires, "GET", options.merge(:scheme => "https"))
|
16
|
+
create_temp_url(container, object, expires, "GET", {:port => 443}.merge(options).merge(:scheme => "https"))
|
17
17
|
end
|
18
18
|
|
19
19
|
# creates a temporary url
|
@@ -23,8 +23,10 @@ module Fog
|
|
23
23
|
# * object<~String> - Name of object to get expiring url for
|
24
24
|
# * expires<~Time> - An expiry time for this url
|
25
25
|
# * method<~String> - The method to use for accessing the object (GET, PUT, HEAD)
|
26
|
-
# * scheme<~String> - The scheme to use (http, https)
|
27
26
|
# * options<~Hash> - An optional options hash
|
27
|
+
# * 'scheme'<~String> - The scheme to use (http, https)
|
28
|
+
# * 'host'<~String> - The host to use
|
29
|
+
# * 'port'<~Integer> - The port to use
|
28
30
|
#
|
29
31
|
# ==== Returns
|
30
32
|
# * response<~Excon::Response>:
|
@@ -37,6 +39,8 @@ module Fog
|
|
37
39
|
raise ArgumentError, "Storage must be instantiated with the :openstack_temp_url_key option" if @openstack_temp_url_key.nil?
|
38
40
|
|
39
41
|
scheme = options[:scheme] || @scheme
|
42
|
+
host = options[:host] || @host
|
43
|
+
port = options[:port] || @port
|
40
44
|
|
41
45
|
# POST not allowed
|
42
46
|
allowed_methods = %w{GET PUT HEAD}
|
@@ -54,13 +58,10 @@ module Fog
|
|
54
58
|
|
55
59
|
temp_url_options = {
|
56
60
|
:scheme => scheme,
|
57
|
-
:host =>
|
58
|
-
:port =>
|
61
|
+
:host => host,
|
62
|
+
:port => port,
|
59
63
|
:path => object_path_escaped,
|
60
|
-
:query =>
|
61
|
-
:temp_url_sig => sig,
|
62
|
-
:temp_url_expires => expires
|
63
|
-
)
|
64
|
+
:query => "temp_url_sig=#{sig}&temp_url_expires=#{expires}"
|
64
65
|
}
|
65
66
|
URI::Generic.build(temp_url_options).to_s
|
66
67
|
end
|
@@ -2,18 +2,19 @@ module Fog
|
|
2
2
|
module Volume
|
3
3
|
class OpenStack
|
4
4
|
class Real
|
5
|
-
def list_snapshots(detailed=true)
|
5
|
+
def list_snapshots(detailed=true, options={})
|
6
6
|
path = detailed ? 'snapshots/detail' : 'snapshots'
|
7
7
|
request(
|
8
8
|
:expects => 200,
|
9
9
|
:method => 'GET',
|
10
|
-
:path => path
|
10
|
+
:path => path,
|
11
|
+
:query => options
|
11
12
|
)
|
12
13
|
end
|
13
14
|
end
|
14
15
|
|
15
16
|
class Mock
|
16
|
-
def list_snapshots(detailed=true)
|
17
|
+
def list_snapshots(detailed=true, options={})
|
17
18
|
response = Excon::Response.new
|
18
19
|
response.status = 200
|
19
20
|
response.body = {
|
@@ -485,6 +485,10 @@ The `create` method also supports the following key values:
|
|
485
485
|
<td>Whether a read-only configuration drive is attached. Refer to Next Gen Server API documentation - <a
|
486
486
|
href="http://docs.rackspace.com/servers/api/v2/cs-devguide/content/config_drive_ext.html">Config Drive Extension</a>.</td>
|
487
487
|
</tr>
|
488
|
+
<tr>
|
489
|
+
<td>:networks</td>
|
490
|
+
<td>Array of uuids corresponding to cloud networks that should be attached to the server, and defaults to two elements (all-zeros for public internet and all-ones for ServiceNet). Please refer to the Rackspace <a href="http://docs.rackspace.com/servers/api/v2/cs-devguide/content/CreateServers.html">Create Server </a> API documentation for further information.</td>
|
491
|
+
</tr>
|
488
492
|
</table>
|
489
493
|
|
490
494
|
## Bootstrap
|
@@ -3,8 +3,11 @@ class Fog::Rackspace::CDNV2::Real
|
|
3
3
|
request(
|
4
4
|
:expects => [201, 202],
|
5
5
|
:method => 'PATCH',
|
6
|
+
:headers => {"Content-Type" => "application/json-patch+json"},
|
6
7
|
:body => Fog::JSON.encode(service.operations),
|
7
8
|
:path => "services/#{service.id}"
|
8
9
|
)
|
10
|
+
|
11
|
+
service.operations = []
|
9
12
|
end
|
10
13
|
end
|
@@ -44,7 +44,7 @@ module Fog
|
|
44
44
|
class TaskError < Fog::VcloudDirector::Errors::TaskError; end
|
45
45
|
|
46
46
|
requires :vcloud_director_username, :vcloud_director_password, :vcloud_director_host
|
47
|
-
recognizes :vcloud_director_api_version, :vcloud_director_show_progress
|
47
|
+
recognizes :vcloud_director_api_version, :vcloud_director_show_progress, :path, :vcloud_token
|
48
48
|
|
49
49
|
secrets :vcloud_director_password
|
50
50
|
|
@@ -346,6 +346,7 @@ module Fog
|
|
346
346
|
@api_version = options[:vcloud_director_api_version] || Fog::Compute::VcloudDirector::Defaults::API_VERSION
|
347
347
|
@show_progress = options[:vcloud_director_show_progress]
|
348
348
|
@show_progress = $stdin.tty? if @show_progress.nil?
|
349
|
+
@vcloud_token = options[:vcloud_token]
|
349
350
|
end
|
350
351
|
|
351
352
|
def vcloud_token
|
@@ -460,7 +461,8 @@ module Fog
|
|
460
461
|
private
|
461
462
|
|
462
463
|
def login
|
463
|
-
|
464
|
+
@vcloud_token ||= ENV['FOG_VCLOUD_TOKEN']
|
465
|
+
if @vcloud_token
|
464
466
|
response = get_current_session
|
465
467
|
session_org = response.body[:org]
|
466
468
|
session_user = response.body[:user]
|
@@ -768,8 +770,9 @@ module Fog
|
|
768
770
|
@port = options[:port] || Fog::Compute::VcloudDirector::Defaults::PORT
|
769
771
|
@scheme = options[:scheme] || Fog::Compute::VcloudDirector::Defaults::SCHEME
|
770
772
|
#@connection = Fog::XML::Connection.new("#{@scheme}://#{@host}:#{@port}", @persistent, @connection_options)
|
771
|
-
@end_point
|
772
|
-
@api_version
|
773
|
+
@end_point = "#{@scheme}://#{@host}#{@path}/"
|
774
|
+
@api_version = options[:vcloud_director_api_version] || Fog::Compute::VcloudDirector::Defaults::API_VERSION
|
775
|
+
@vcloud_token = options[:vcloud_token]
|
773
776
|
end
|
774
777
|
|
775
778
|
def vcloud_token
|
@@ -61,6 +61,21 @@ module Fog
|
|
61
61
|
}
|
62
62
|
# The template
|
63
63
|
xml.Source(:href => options[:template_uri])
|
64
|
+
# Use of sourceItems for configuring VM's during instantiation.
|
65
|
+
# NOTE: Name and storage profile configuration supported so far.
|
66
|
+
# http://pubs.vmware.com/vca/index.jsp?topic=%2Fcom.vmware.vcloud.api.doc_56%2FGUID-BF9B790D-512E-4EA1-99E8-6826D4B8E6DC.html
|
67
|
+
(options[:vms_config] || []).each do |vm_config|
|
68
|
+
next unless vm_config[:href]
|
69
|
+
xml.SourcedItem {
|
70
|
+
xml.Source(:href => vm_config[:href])
|
71
|
+
xml.VmGeneralParams{
|
72
|
+
xml.Name(vm_config[:name]) if vm_config[:name]
|
73
|
+
}
|
74
|
+
if storage_href = vm_config[:storage_profile_href]
|
75
|
+
xml.StorageProfile(:href => storage_href)
|
76
|
+
end
|
77
|
+
}
|
78
|
+
end
|
64
79
|
xml.AllEULAsAccepted("true")
|
65
80
|
}
|
66
81
|
end
|
data/lib/fog/version.rb
CHANGED
data/lib/fog/vsphere/compute.rb
CHANGED
@@ -7,6 +7,7 @@ module Fog
|
|
7
7
|
requires :vsphere_username, :vsphere_password, :vsphere_server
|
8
8
|
recognizes :vsphere_port, :vsphere_path, :vsphere_ns
|
9
9
|
recognizes :vsphere_rev, :vsphere_ssl, :vsphere_expected_pubkey_hash
|
10
|
+
recognizes :vsphere_debug
|
10
11
|
|
11
12
|
model_path 'fog/vsphere/models/compute'
|
12
13
|
model :server
|
@@ -113,6 +114,9 @@ module Fog
|
|
113
114
|
:overall_status => 'overallStatus',
|
114
115
|
:guest_id => 'config.guestId',
|
115
116
|
:hardware_version => 'config.version',
|
117
|
+
:cpuHotAddEnabled => 'config.cpuHotAddEnabled',
|
118
|
+
:memoryHotAddEnabled => 'config.memoryHotAddEnabled',
|
119
|
+
:firmware => 'config.firmware',
|
116
120
|
}
|
117
121
|
|
118
122
|
def convert_vm_view_to_attr_hash(vms)
|
@@ -381,6 +385,7 @@ module Fog
|
|
381
385
|
@vsphere_ns = options[:vsphere_ns] || 'urn:vim25'
|
382
386
|
@vsphere_rev = options[:vsphere_rev] || '4.0'
|
383
387
|
@vsphere_ssl = options[:vsphere_ssl] || true
|
388
|
+
@vsphere_debug = options[:vsphere_debug] || false
|
384
389
|
@vsphere_expected_pubkey_hash = options[:vsphere_expected_pubkey_hash]
|
385
390
|
@vsphere_must_reauthenticate = false
|
386
391
|
@vsphere_is_vcenter = nil
|
@@ -422,7 +427,8 @@ module Fog
|
|
422
427
|
:ns => @vsphere_ns,
|
423
428
|
:rev => @vsphere_rev,
|
424
429
|
:ssl => @vsphere_ssl,
|
425
|
-
:insecure => bad_cert
|
430
|
+
:insecure => bad_cert,
|
431
|
+
:debug => @vsphere_debug
|
426
432
|
break
|
427
433
|
rescue OpenSSL::SSL::SSLError
|
428
434
|
raise if bad_cert
|
@@ -46,6 +46,9 @@ module Fog
|
|
46
46
|
attribute :guest_id
|
47
47
|
attribute :hardware_version
|
48
48
|
attribute :scsi_controller # this is the first scsi controller. Right now no more of them can be used.
|
49
|
+
attribute :cpuHotAddEnabled
|
50
|
+
attribute :memoryHotAddEnabled
|
51
|
+
attribute :firmware
|
49
52
|
|
50
53
|
def initialize(attributes={} )
|
51
54
|
super defaults.merge(attributes)
|
@@ -16,6 +16,9 @@ module Fog
|
|
16
16
|
:deviceChange => device_change(attributes),
|
17
17
|
:extraConfig => extra_config(attributes),
|
18
18
|
}
|
19
|
+
vm_cfg[:cpuHotAddEnabled] = attributes[:cpuHotAddEnabled] if attributes.key?(:cpuHotAddEnabled)
|
20
|
+
vm_cfg[:memoryHotAddEnabled] = attributes[:memoryHotAddEnabled] if attributes.key?(:memoryHotAddEnabled)
|
21
|
+
vm_cfg[:firmware] = attributes[:firmware] if attributes.key?(:firmware)
|
19
22
|
resource_pool = if attributes[:resource_pool]
|
20
23
|
get_raw_resource_pool(attributes[:resource_pool], attributes[:cluster], attributes[:datacenter])
|
21
24
|
else
|
@@ -30,7 +30,13 @@ module Fog
|
|
30
30
|
|
31
31
|
def get_vm_by_name(name, dc)
|
32
32
|
vms = raw_list_all_virtual_machines(dc)
|
33
|
-
|
33
|
+
|
34
|
+
if name.include?('/')
|
35
|
+
folder, basename = name.split('/')
|
36
|
+
vms.keep_if { |v| v["name"] == basename && v.parent["name"] == folder }.first
|
37
|
+
else
|
38
|
+
vms.keep_if { |v| v["name"] == name }.first
|
39
|
+
end
|
34
40
|
end
|
35
41
|
end
|
36
42
|
|