fog 1.10.1 → 1.11.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.travis.yml +1 -0
- data/Gemfile +2 -0
- data/README.md +4 -3
- data/changelog.txt +207 -0
- data/fog.gemspec +4 -3
- data/lib/fog/aws.rb +0 -2
- data/lib/fog/aws/dynamodb.rb +1 -1
- data/lib/fog/aws/elasticache.rb +0 -2
- data/lib/fog/aws/iam.rb +1 -0
- data/lib/fog/aws/models/compute/volume.rb +1 -0
- data/lib/fog/aws/models/iam/user.rb +1 -0
- data/lib/fog/aws/models/storage/directories.rb +1 -1
- data/lib/fog/aws/models/storage/directory.rb +20 -17
- data/lib/fog/aws/models/storage/file.rb +4 -5
- data/lib/fog/aws/parsers/iam/get_user.rb +2 -0
- data/lib/fog/aws/parsers/iam/list_users.rb +2 -0
- data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +2 -2
- data/lib/fog/aws/requests/cdn/put_distribution_config.rb +3 -3
- data/lib/fog/aws/requests/cloud_formation/update_stack.rb +3 -3
- data/lib/fog/aws/requests/cloud_formation/validate_template.rb +5 -5
- data/lib/fog/aws/requests/iam/create_user.rb +5 -4
- data/lib/fog/aws/requests/iam/get_user.rb +5 -4
- data/lib/fog/aws/requests/iam/list_users.rb +5 -4
- data/lib/fog/aws/requests/rds/create_db_instance.rb +25 -25
- data/lib/fog/aws/requests/storage/abort_multipart_upload.rb +3 -3
- data/lib/fog/aws/requests/storage/complete_multipart_upload.rb +2 -2
- data/lib/fog/aws/requests/storage/copy_object.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_bucket.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_bucket_cors.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_bucket_lifecycle.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_bucket_policy.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_bucket_website.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +1 -1
- data/lib/fog/aws/requests/storage/delete_object.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_acl.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_cors.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_lifecycle.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_location.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_logging.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_object_versions.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_policy.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_versioning.rb +1 -1
- data/lib/fog/aws/requests/storage/get_bucket_website.rb +1 -1
- data/lib/fog/aws/requests/storage/get_object.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_acl.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_http_url.rb +1 -19
- data/lib/fog/aws/requests/storage/get_object_torrent.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_url.rb +5 -14
- data/lib/fog/aws/requests/storage/get_request_payment.rb +1 -1
- data/lib/fog/aws/requests/storage/head_object.rb +2 -2
- data/lib/fog/aws/requests/storage/initiate_multipart_upload.rb +2 -2
- data/lib/fog/aws/requests/storage/list_multipart_uploads.rb +7 -8
- data/lib/fog/aws/requests/storage/list_parts.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_acl.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_cors.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_lifecycle.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_logging.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_policy.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_versioning.rb +1 -1
- data/lib/fog/aws/requests/storage/put_bucket_website.rb +1 -1
- data/lib/fog/aws/requests/storage/put_object.rb +2 -2
- data/lib/fog/aws/requests/storage/put_object_acl.rb +8 -8
- data/lib/fog/aws/requests/storage/put_object_url.rb +5 -7
- data/lib/fog/aws/requests/storage/put_request_payment.rb +1 -1
- data/lib/fog/aws/requests/storage/upload_part.rb +2 -2
- data/lib/fog/aws/storage.rb +201 -97
- data/lib/fog/bin/google.rb +47 -1
- data/lib/fog/bluebox/models/compute/server.rb +3 -1
- data/lib/fog/brightbox/compute.rb +11 -26
- data/lib/fog/brightbox/compute/image_selector.rb +45 -0
- data/lib/fog/cloudstack/compute.rb +70 -2
- data/lib/fog/cloudstack/models/compute/disk_offering.rb +46 -0
- data/lib/fog/cloudstack/models/compute/disk_offerings.rb +27 -0
- data/lib/fog/cloudstack/models/compute/image.rb +1 -1
- data/lib/fog/cloudstack/models/compute/servers.rb +3 -2
- data/lib/fog/cloudstack/requests/compute/create_disk_offering.rb +51 -0
- data/lib/fog/cloudstack/requests/compute/delete_disk_offering.rb +31 -0
- data/lib/fog/cloudstack/requests/compute/delete_snapshot.rb +44 -2
- data/lib/fog/cloudstack/requests/compute/list_disk_offerings.rb +9 -0
- data/lib/fog/cloudstack/requests/compute/list_os_types.rb +9 -0
- data/lib/fog/cloudstack/requests/compute/list_snapshots.rb +21 -0
- data/lib/fog/core/errors.rb +3 -0
- data/lib/fog/core/json.rb +48 -7
- data/lib/fog/core/model.rb +11 -10
- data/lib/fog/core/service.rb +1 -1
- data/lib/fog/digitalocean/CHANGELOG.md +1 -1
- data/lib/fog/dreamhost/dns.rb +1 -3
- data/lib/fog/google.rb +1 -0
- data/lib/fog/google/compute.rb +131 -0
- data/lib/fog/google/models/compute/flavor.rb +24 -0
- data/lib/fog/google/models/compute/flavors.rb +28 -0
- data/lib/fog/google/models/compute/image.rb +19 -0
- data/lib/fog/google/models/compute/images.rb +28 -0
- data/lib/fog/google/models/compute/server.rb +80 -0
- data/lib/fog/google/models/compute/servers.rb +61 -0
- data/lib/fog/google/requests/compute/delete_disk.rb +31 -0
- data/lib/fog/google/requests/compute/delete_firewall.rb +30 -0
- data/lib/fog/google/requests/compute/delete_image.rb +30 -0
- data/lib/fog/google/requests/compute/delete_network.rb +30 -0
- data/lib/fog/google/requests/compute/delete_operation.rb +30 -0
- data/lib/fog/google/requests/compute/delete_server.rb +40 -0
- data/lib/fog/google/requests/compute/get_disk.rb +31 -0
- data/lib/fog/google/requests/compute/get_firewall.rb +30 -0
- data/lib/fog/google/requests/compute/get_image.rb +30 -0
- data/lib/fog/google/requests/compute/get_machine_type.rb +30 -0
- data/lib/fog/google/requests/compute/get_network.rb +30 -0
- data/lib/fog/google/requests/compute/get_server.rb +31 -0
- data/lib/fog/google/requests/compute/get_zone.rb +30 -0
- data/lib/fog/google/requests/compute/insert_disk.rb +35 -0
- data/lib/fog/google/requests/compute/insert_firewall.rb +37 -0
- data/lib/fog/google/requests/compute/insert_image.rb +38 -0
- data/lib/fog/google/requests/compute/insert_network.rb +34 -0
- data/lib/fog/google/requests/compute/insert_server.rb +49 -0
- data/lib/fog/google/requests/compute/list_disks.rb +30 -0
- data/lib/fog/google/requests/compute/list_firewalls.rb +29 -0
- data/lib/fog/google/requests/compute/list_global_operations.rb +28 -0
- data/lib/fog/google/requests/compute/list_images.rb +29 -0
- data/lib/fog/google/requests/compute/list_machine_types.rb +29 -0
- data/lib/fog/google/requests/compute/list_networks.rb +29 -0
- data/lib/fog/google/requests/compute/list_servers.rb +30 -0
- data/lib/fog/google/requests/compute/list_zone_operations.rb +28 -0
- data/lib/fog/google/requests/compute/list_zones.rb +29 -0
- data/lib/fog/google/requests/compute/set_metadata.rb +36 -0
- data/lib/fog/hp.rb +1 -1
- data/lib/fog/hp/storage.rb +1 -1
- data/lib/fog/internet_archive/models/storage/ia_attributes.rb +1 -1
- data/lib/fog/internet_archive/requests/storage/head_object.rb +1 -2
- data/lib/fog/internet_archive/requests/storage/list_multipart_uploads.rb +5 -6
- data/lib/fog/openstack.rb +29 -1
- data/lib/fog/openstack/CHANGELOG.md +1 -1
- data/lib/fog/openstack/compute.rb +3 -2
- data/lib/fog/openstack/identity.rb +1 -5
- data/lib/fog/openstack/image.rb +8 -9
- data/lib/fog/openstack/models/compute/server.rb +24 -0
- data/lib/fog/openstack/network.rb +7 -28
- data/lib/fog/openstack/requests/compute/allocate_address.rb +1 -1
- data/lib/fog/openstack/requests/compute/attach_volume.rb +11 -6
- data/lib/fog/openstack/requests/compute/boot_from_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_flavor.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_key_pair.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_security_group.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_security_group_rule.rb +1 -1
- data/lib/fog/openstack/requests/compute/create_volume.rb +15 -14
- data/lib/fog/openstack/requests/compute/create_volume_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/compute/delete_volume.rb +9 -2
- data/lib/fog/openstack/requests/compute/detach_volume.rb +7 -2
- data/lib/fog/openstack/requests/compute/get_server_volumes.rb +10 -0
- data/lib/fog/openstack/requests/compute/get_volume_details.rb +7 -16
- data/lib/fog/openstack/requests/compute/list_tenants.rb +1 -1
- data/lib/fog/openstack/requests/compute/list_volumes.rb +4 -26
- data/lib/fog/openstack/requests/compute/revert_resize_server.rb +2 -2
- data/lib/fog/openstack/requests/compute/update_quota.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_ec2_credential.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_role.rb +1 -1
- data/lib/fog/openstack/requests/identity/create_user.rb +1 -1
- data/lib/fog/openstack/requests/identity/update_user.rb +1 -1
- data/lib/fog/openstack/requests/image/update_image_members.rb +1 -1
- data/lib/fog/openstack/requests/volume/create_volume.rb +1 -1
- data/lib/fog/openstack/requests/volume/create_volume_snapshot.rb +1 -1
- data/lib/fog/openstack/requests/volume/get_quota.rb +31 -0
- data/lib/fog/openstack/requests/volume/get_quota_defaults.rb +31 -0
- data/lib/fog/openstack/requests/volume/update_quota.rb +32 -0
- data/lib/fog/openstack/volume.rb +11 -7
- data/lib/fog/rackspace.rb +11 -5
- data/lib/fog/rackspace/block_storage.rb +2 -1
- data/lib/fog/rackspace/cdn.rb +15 -15
- data/lib/fog/rackspace/compute.rb +2 -2
- data/lib/fog/rackspace/compute_v2.rb +8 -5
- data/lib/fog/rackspace/databases.rb +2 -1
- data/lib/fog/rackspace/dns.rb +2 -1
- data/lib/fog/rackspace/errors.rb +27 -0
- data/lib/fog/rackspace/load_balancers.rb +2 -1
- data/lib/fog/rackspace/mock_data.rb +5 -6
- data/lib/fog/rackspace/models/block_storage/snapshot.rb +8 -8
- data/lib/fog/rackspace/models/block_storage/snapshots.rb +8 -8
- data/lib/fog/rackspace/models/block_storage/volume.rb +16 -16
- data/lib/fog/rackspace/models/block_storage/volume_types.rb +8 -8
- data/lib/fog/rackspace/models/block_storage/volumes.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/attachment.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/attachments.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/image.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/images.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/metadata.rb +12 -12
- data/lib/fog/rackspace/models/compute_v2/metadatum.rb +8 -8
- data/lib/fog/rackspace/models/compute_v2/server.rb +94 -55
- data/lib/fog/rackspace/models/compute_v2/servers.rb +12 -12
- data/lib/fog/rackspace/models/dns/records.rb +1 -1
- data/lib/fog/rackspace/models/dns/zones.rb +1 -1
- data/lib/fog/rackspace/models/storage/account.rb +8 -8
- data/lib/fog/rackspace/models/storage/directories.rb +8 -8
- data/lib/fog/rackspace/models/storage/directory.rb +32 -32
- data/lib/fog/rackspace/models/storage/file.rb +36 -36
- data/lib/fog/rackspace/models/storage/files.rb +20 -20
- data/lib/fog/rackspace/requests/block_storage/create_snapshot.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/create_volume.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/delete_snapshot.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/delete_volume.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/get_snapshot.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/get_volume.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/get_volume_type.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/list_snapshots.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/list_volume_types.rb +4 -4
- data/lib/fog/rackspace/requests/block_storage/list_volumes.rb +4 -4
- data/lib/fog/rackspace/requests/cdn/delete_object.rb +4 -4
- data/lib/fog/rackspace/requests/cdn/get_containers.rb +4 -4
- data/lib/fog/rackspace/requests/cdn/head_container.rb +4 -4
- data/lib/fog/rackspace/requests/cdn/post_container.rb +4 -4
- data/lib/fog/rackspace/requests/cdn/put_container.rb +4 -4
- data/lib/fog/rackspace/requests/compute/delete_image.rb +1 -1
- data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/create_image.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +11 -5
- data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +5 -4
- data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/get_image.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/get_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/rescue_server.rb +43 -0
- data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/unrescue_server.rb +40 -0
- data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +4 -4
- data/lib/fog/rackspace/requests/compute_v2/update_server.rb +4 -4
- data/lib/fog/rackspace/requests/storage/copy_object.rb +4 -4
- data/lib/fog/rackspace/requests/storage/delete_container.rb +4 -4
- data/lib/fog/rackspace/requests/storage/delete_object.rb +4 -4
- data/lib/fog/rackspace/requests/storage/get_container.rb +4 -4
- data/lib/fog/rackspace/requests/storage/get_containers.rb +4 -4
- data/lib/fog/rackspace/requests/storage/get_object.rb +4 -4
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +4 -4
- data/lib/fog/rackspace/requests/storage/head_container.rb +4 -4
- data/lib/fog/rackspace/requests/storage/head_containers.rb +4 -4
- data/lib/fog/rackspace/requests/storage/head_object.rb +4 -4
- data/lib/fog/rackspace/requests/storage/post_set_meta_temp_url_key.rb +4 -4
- data/lib/fog/rackspace/requests/storage/put_container.rb +4 -4
- data/lib/fog/rackspace/requests/storage/put_object.rb +4 -4
- data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +4 -4
- data/lib/fog/rackspace/service.rb +1 -1
- data/lib/fog/rackspace/storage.rb +12 -6
- data/lib/fog/riakcs.rb +3 -3
- data/lib/fog/riakcs/provisioning.rb +1 -3
- data/lib/fog/riakcs/requests/provisioning/create_user.rb +2 -2
- data/lib/fog/riakcs/requests/provisioning/get_user.rb +1 -1
- data/lib/fog/riakcs/requests/provisioning/list_users.rb +1 -1
- data/lib/fog/riakcs/requests/usage/get_usage.rb +1 -1
- data/lib/fog/riakcs/usage.rb +0 -1
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +21 -14
- data/lib/fog/vsphere/models/compute/networks.rb +2 -2
- data/lib/fog/vsphere/models/compute/server.rb +10 -0
- data/lib/fog/vsphere/requests/compute/get_resource_pool.rb +1 -1
- data/lib/fog/vsphere/requests/compute/get_template.rb +16 -0
- data/lib/fog/vsphere/requests/compute/list_datacenters.rb +1 -1
- data/lib/fog/vsphere/requests/compute/list_templates.rb +49 -0
- data/lib/fog/vsphere/requests/compute/list_virtual_machines.rb +9 -6
- data/lib/fog/vsphere/requests/compute/vm_clone.rb +41 -27
- data/lib/fog/xenserver/CHANGELOG.md +1 -1
- data/lib/fog/xenserver/models/compute/network.rb +2 -2
- data/lib/tasks/changelog_task.rb +2 -1
- data/tests/aws/models/storage/directory_tests.rb +41 -5
- data/tests/aws/models/storage/file_tests.rb +1 -2
- data/tests/aws/models/storage/files_tests.rb +6 -4
- data/tests/aws/models/storage/url_tests.rb +7 -5
- data/tests/aws/models/storage/version_tests.rb +2 -2
- data/tests/aws/models/storage/versions_tests.rb +5 -5
- data/tests/aws/requests/iam/user_tests.rb +10 -8
- data/tests/aws/requests/storage/multipart_upload_tests.rb +1 -1
- data/tests/aws/requests/storage/object_tests.rb +15 -13
- data/tests/brightbox/compute/image_selector_tests.rb +103 -0
- data/tests/cloudstack/compute/models/disk_offering_tests.rb +5 -0
- data/tests/cloudstack/compute/models/snapshot_tests.rb +5 -20
- data/tests/cloudstack/requests/disk_offering_tests.rb +3 -3
- data/tests/cloudstack/requests/os_type_tests.rb +2 -3
- data/tests/compute/helper.rb +9 -0
- data/tests/core/json_tests.rb +62 -0
- data/tests/dynect/requests/dns/dns_tests.rb +0 -3
- data/tests/google/models/compute/server_tests.rb +24 -0
- data/tests/google/requests/compute/disk_tests.rb +88 -0
- data/tests/google/requests/compute/firewall_tests.rb +85 -0
- data/tests/google/requests/compute/image_tests.rb +80 -0
- data/tests/google/requests/compute/network_tests.rb +74 -0
- data/tests/google/requests/compute/operation_tests.rb +19 -0
- data/tests/google/requests/compute/server_tests.rb +84 -0
- data/tests/google/requests/compute/zone_tests.rb +46 -0
- data/tests/helpers/mock_helper.rb +4 -0
- data/tests/openstack/models/compute/server_tests.rb +91 -1
- data/tests/openstack/requests/compute/volume_tests.rb +11 -9
- data/tests/openstack/requests/volume/quota_tests.rb +51 -0
- data/tests/openstack/version_tests.rb +55 -0
- data/tests/rackspace/helper.rb +10 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +26 -1
- data/tests/rackspace/requests/compute/image_tests.rb +1 -1
- data/tests/rackspace/requests/compute_v2/image_tests.rb +2 -2
- data/tests/rackspace/requests/compute_v2/server_tests.rb +13 -0
- data/tests/rackspace/requests/dns/dns_tests.rb +1 -1
- data/tests/rackspace/requests/dns/records_tests.rb +3 -3
- data/tests/vsphere/requests/compute/vm_clone_tests.rb +10 -0
- metadata +109 -747
@@ -0,0 +1,29 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_images
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_images
|
16
|
+
api_method = @compute.images.list
|
17
|
+
parameters = {
|
18
|
+
'project' => @project
|
19
|
+
}
|
20
|
+
|
21
|
+
result = self.build_result(api_method, parameters)
|
22
|
+
response = self.build_response(result)
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_machine_types
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_machine_types
|
16
|
+
api_method = @compute.machine_types.list
|
17
|
+
parameters = {
|
18
|
+
'project' => 'google'
|
19
|
+
}
|
20
|
+
|
21
|
+
result = self.build_result(api_method, parameters)
|
22
|
+
response = self.build_response(result)
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_networks
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_networks
|
16
|
+
api_method = @compute.networks.list
|
17
|
+
parameters = {
|
18
|
+
'project' => @project
|
19
|
+
}
|
20
|
+
|
21
|
+
result = self.build_result(api_method, parameters)
|
22
|
+
response = self.build_response(result)
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_servers
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_servers(zone_name)
|
16
|
+
api_method = @compute.instances.list
|
17
|
+
parameters = {
|
18
|
+
'project' => @project,
|
19
|
+
'zone' => zone_name,
|
20
|
+
}
|
21
|
+
|
22
|
+
result = self.build_result(api_method, parameters)
|
23
|
+
response = self.build_response(result)
|
24
|
+
end
|
25
|
+
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_zone_operations
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_zone_operations(zone)
|
16
|
+
api_method = @compute.zone_operations.list
|
17
|
+
parameters = {
|
18
|
+
'zone' => zone,
|
19
|
+
'project' => @project,
|
20
|
+
}
|
21
|
+
|
22
|
+
result = self.build_result(api_method, parameters)
|
23
|
+
response = self.build_response(result)
|
24
|
+
end
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def list_zones
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def list_zones
|
16
|
+
api_method = @compute.zones.list
|
17
|
+
parameters = {
|
18
|
+
'project' => @project
|
19
|
+
}
|
20
|
+
|
21
|
+
result = self.build_result(api_method, parameters)
|
22
|
+
response = self.build_response(result)
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,36 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Google
|
4
|
+
|
5
|
+
class Mock
|
6
|
+
|
7
|
+
def set_metadata(instance, zone, metadata={})
|
8
|
+
Fog::Mock.not_implemented
|
9
|
+
end
|
10
|
+
|
11
|
+
end
|
12
|
+
|
13
|
+
class Real
|
14
|
+
|
15
|
+
def set_metadata(instance, zone, metadata={})
|
16
|
+
api_method = @compute.instance.set_metadata
|
17
|
+
parameters = {
|
18
|
+
'project' => @project,
|
19
|
+
'instance' => instance,
|
20
|
+
'zone' => zone,
|
21
|
+
}
|
22
|
+
body_object = {
|
23
|
+
"items" => metadata.to_a.map {|pair| { :key => pair[0], :value => pair[1] } }
|
24
|
+
}
|
25
|
+
result = self.build_result(
|
26
|
+
api_method,
|
27
|
+
parameters,
|
28
|
+
body_object=body_object)
|
29
|
+
response = self.build_response(result)
|
30
|
+
end
|
31
|
+
|
32
|
+
end
|
33
|
+
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
data/lib/fog/hp.rb
CHANGED
@@ -25,7 +25,7 @@ module Fog
|
|
25
25
|
if message.nil? and !data.values.first.nil?
|
26
26
|
message = data.values.first['message']
|
27
27
|
end
|
28
|
-
rescue
|
28
|
+
rescue Fog::JSON::LoadError
|
29
29
|
message = error.response.body #### body is not in JSON format, so just return as is
|
30
30
|
end
|
31
31
|
end
|
data/lib/fog/hp/storage.rb
CHANGED
@@ -177,7 +177,7 @@ module Fog
|
|
177
177
|
signature = Fog::HP.escape(signature)
|
178
178
|
|
179
179
|
# generate the temp url using the signature and expiry
|
180
|
-
|
180
|
+
"#{scheme}://#{host}:#{port}#{encoded_path}?temp_url_sig=#{signature}&temp_url_expires=#{expires}"
|
181
181
|
end
|
182
182
|
|
183
183
|
end
|
@@ -3,7 +3,7 @@ module Fog
|
|
3
3
|
module IAAttributes
|
4
4
|
|
5
5
|
# you can add other x-archive-metadata-* values, but these are standard
|
6
|
-
IA_STANDARD_METADATA_FIELDS = %q[hidden, title, collection, creator, mediatype, description, date, subject, licenseurl
|
6
|
+
IA_STANDARD_METADATA_FIELDS = %q[hidden, title, collection, creator, mediatype, description, date, subject, licenseurl, pick, noindex, notes, rights, contributor, language, coverage, credits]
|
7
7
|
|
8
8
|
# for x-archive-metadata-mediatype, these are the valid values
|
9
9
|
IA_VALID_MEDIA_TYPES = %q[audio, data, etree, image, movies, software, texts, web]
|
@@ -7,12 +7,11 @@ module Fog
|
|
7
7
|
|
8
8
|
# List multipart uploads for a bucket
|
9
9
|
#
|
10
|
-
# @param
|
11
|
-
# @param
|
12
|
-
# @
|
13
|
-
# @option options
|
14
|
-
# @option options
|
15
|
-
# @option options upload-id-marker [String] limits uploads to only those that appear lexicographically after this upload id.
|
10
|
+
# @param [String] bucket_name Name of bucket to list multipart uploads for
|
11
|
+
# @param [Hash] options config arguments for list. Defaults to {}.
|
12
|
+
# @option options [String] key-marker limits parts to only those that appear lexicographically after this key.
|
13
|
+
# @option options [Integer] max-uploads limits number of uploads returned
|
14
|
+
# @option options [String] upload-id-marker limits uploads to only those that appear lexicographically after this upload id.
|
16
15
|
#
|
17
16
|
# @return [Excon::Response] response:
|
18
17
|
# * body [Hash]:
|
data/lib/fog/openstack.rb
CHANGED
@@ -202,7 +202,35 @@ module Fog
|
|
202
202
|
|
203
203
|
Fog::JSON.decode(response.body)
|
204
204
|
end
|
205
|
-
|
205
|
+
|
206
|
+
def self.get_supported_version(supported_versions, uri, auth_token, connection_options = {})
|
207
|
+
connection = Fog::Connection.new("#{uri.scheme}://#{uri.host}:#{uri.port}", false, connection_options)
|
208
|
+
response = connection.request({
|
209
|
+
:expects => [200, 204, 300],
|
210
|
+
:headers => {'Content-Type' => 'application/json',
|
211
|
+
'Accept' => 'application/json',
|
212
|
+
'X-Auth-Token' => auth_token},
|
213
|
+
:host => uri.host,
|
214
|
+
:method => 'GET'
|
215
|
+
})
|
216
|
+
|
217
|
+
body = Fog::JSON.decode(response.body)
|
218
|
+
version = nil
|
219
|
+
unless body['versions'].empty?
|
220
|
+
supported_version = body['versions'].detect do |x|
|
221
|
+
x["id"].match(supported_versions) &&
|
222
|
+
(x["status"] == "CURRENT" || x["status"] == "SUPPORTED")
|
223
|
+
end
|
224
|
+
version = supported_version["id"] if supported_version
|
225
|
+
end
|
226
|
+
if version.nil?
|
227
|
+
raise Fog::OpenStack::Errors::ServiceUnavailable.new(
|
228
|
+
"OpenStack service only supports API versions #{supported_versions.inspect}")
|
229
|
+
end
|
230
|
+
|
231
|
+
version
|
232
|
+
end
|
233
|
+
|
206
234
|
# CGI.escape, but without special treatment on spaces
|
207
235
|
def self.escape(str,extra_exclude_chars = '')
|
208
236
|
str.gsub(/([^a-zA-Z0-9_.-#{extra_exclude_chars}]+)/) do
|
@@ -226,7 +226,8 @@ module Fog
|
|
226
226
|
'volumes' => 10,
|
227
227
|
'cores' => 20,
|
228
228
|
'ram' => 51200
|
229
|
-
}
|
229
|
+
},
|
230
|
+
:volumes => {}
|
230
231
|
}
|
231
232
|
end
|
232
233
|
end
|
@@ -338,7 +339,7 @@ module Fog
|
|
338
339
|
}.merge!(params[:headers] || {}),
|
339
340
|
:host => @host,
|
340
341
|
:path => "#{@path}/#{@tenant_id}/#{params[:path]}",
|
341
|
-
:query => params[:query]
|
342
|
+
:query => params[:query]
|
342
343
|
}))
|
343
344
|
rescue Excon::Errors::Unauthorized => error
|
344
345
|
if error.response.body != 'Bad username or password' # token expiration
|
@@ -63,7 +63,6 @@ module Fog
|
|
63
63
|
|
64
64
|
class Mock
|
65
65
|
attr_reader :auth_token
|
66
|
-
attr_reader :unscoped_token
|
67
66
|
attr_reader :auth_token_expiration
|
68
67
|
attr_reader :current_user
|
69
68
|
attr_reader :current_tenant
|
@@ -96,7 +95,6 @@ module Fog
|
|
96
95
|
end
|
97
96
|
|
98
97
|
def initialize(options={})
|
99
|
-
require 'multi_json'
|
100
98
|
@openstack_username = options[:openstack_username] || 'admin'
|
101
99
|
@openstack_tenant = options[:openstack_tenant] || 'admin'
|
102
100
|
@openstack_auth_uri = URI.parse(options[:openstack_auth_url])
|
@@ -230,8 +228,6 @@ module Fog
|
|
230
228
|
}.merge!(params[:headers] || {}),
|
231
229
|
:host => @host,
|
232
230
|
:path => "#{@path}/#{params[:path]}"#,
|
233
|
-
# Causes errors for some requests like tenants?limit=1
|
234
|
-
# :query => ('ignore_awful_caching' << Time.now.to_i.to_s)
|
235
231
|
}))
|
236
232
|
rescue Excon::Errors::Unauthorized => error
|
237
233
|
raise if retried
|
@@ -249,7 +245,7 @@ module Fog
|
|
249
245
|
end
|
250
246
|
end
|
251
247
|
unless response.body.empty?
|
252
|
-
response.body =
|
248
|
+
response.body = Fog::JSON.decode(response.body)
|
253
249
|
end
|
254
250
|
response
|
255
251
|
end
|
data/lib/fog/openstack/image.rb
CHANGED
@@ -3,6 +3,8 @@ require 'fog/openstack'
|
|
3
3
|
module Fog
|
4
4
|
module Image
|
5
5
|
class OpenStack < Fog::Service
|
6
|
+
SUPPORTED_VERSIONS = /v1(\.(0|1))*/
|
7
|
+
|
6
8
|
requires :openstack_auth_url
|
7
9
|
recognizes :openstack_auth_token, :openstack_management_url, :persistent,
|
8
10
|
:openstack_service_type, :openstack_service_name, :openstack_tenant,
|
@@ -44,7 +46,6 @@ module Fog
|
|
44
46
|
end
|
45
47
|
|
46
48
|
def initialize(options={})
|
47
|
-
require 'multi_json'
|
48
49
|
@openstack_username = options[:openstack_username]
|
49
50
|
@openstack_tenant = options[:openstack_tenant]
|
50
51
|
@openstack_auth_uri = URI.parse(options[:openstack_auth_url])
|
@@ -92,8 +93,6 @@ module Fog
|
|
92
93
|
attr_reader :current_tenant
|
93
94
|
|
94
95
|
def initialize(options={})
|
95
|
-
require 'multi_json'
|
96
|
-
|
97
96
|
@openstack_auth_token = options[:openstack_auth_token]
|
98
97
|
|
99
98
|
unless @openstack_auth_token
|
@@ -148,8 +147,6 @@ module Fog
|
|
148
147
|
}.merge!(params[:headers] || {}),
|
149
148
|
:host => @host,
|
150
149
|
:path => "#{@path}/#{params[:path]}"#,
|
151
|
-
# Causes errors for some requests like tenants?limit=1
|
152
|
-
# :query => ('ignore_awful_caching' << Time.now.to_i.to_s)
|
153
150
|
}))
|
154
151
|
rescue Excon::Errors::Unauthorized => error
|
155
152
|
if error.response.body != 'Bad username or password' # token expiration
|
@@ -168,7 +165,7 @@ module Fog
|
|
168
165
|
end
|
169
166
|
end
|
170
167
|
unless response.body.empty?
|
171
|
-
response.body =
|
168
|
+
response.body = Fog::JSON.decode(response.body)
|
172
169
|
end
|
173
170
|
response
|
174
171
|
end
|
@@ -206,9 +203,11 @@ module Fog
|
|
206
203
|
@host = uri.host
|
207
204
|
@path = uri.path
|
208
205
|
@path.sub!(/\/$/, '')
|
209
|
-
unless @path.match(
|
210
|
-
|
211
|
-
|
206
|
+
unless @path.match(SUPPORTED_VERSIONS)
|
207
|
+
@path = "/" + Fog::OpenStack.get_supported_version(SUPPORTED_VERSIONS,
|
208
|
+
uri,
|
209
|
+
@auth_token,
|
210
|
+
@connection_options)
|
212
211
|
end
|
213
212
|
@port = uri.port
|
214
213
|
@scheme = uri.scheme
|
@@ -243,6 +243,30 @@ module Fog
|
|
243
243
|
service.networks(:server => self)
|
244
244
|
end
|
245
245
|
|
246
|
+
def volumes
|
247
|
+
requires :id
|
248
|
+
service.volumes.find_all do |vol|
|
249
|
+
vol.attachments.find { |attachment| attachment["serverId"] == id }
|
250
|
+
end
|
251
|
+
end
|
252
|
+
|
253
|
+
def volume_attachments
|
254
|
+
requires :id
|
255
|
+
service.get_server_volumes(id).body['volumeAttachments']
|
256
|
+
end
|
257
|
+
|
258
|
+
def attach_volume(volume_id, device_name)
|
259
|
+
requires :id
|
260
|
+
service.attach_volume(volume_id, id, device_name)
|
261
|
+
true
|
262
|
+
end
|
263
|
+
|
264
|
+
def detach_volume(volume_id)
|
265
|
+
requires :id
|
266
|
+
service.detach_volume(id, volume_id)
|
267
|
+
true
|
268
|
+
end
|
269
|
+
|
246
270
|
# TODO: Implement /os-volumes-boot support with 'block_device_mapping'
|
247
271
|
def save
|
248
272
|
raise Fog::Errors::Error.new('Resaving an existing object may create a duplicate') if persisted?
|