fog 1.10.0 → 1.10.1
Sign up to get free protection for your applications and to get access to all the features.
- data/benchs/load_times.rb +31 -0
- data/changelog.txt +320 -0
- data/fog.gemspec +3 -3
- data/lib/fog.rb +42 -15
- data/lib/fog/aws/auto_scaling.rb +1 -1
- data/lib/fog/aws/beanstalk.rb +1 -1
- data/lib/fog/aws/cloud_formation.rb +1 -1
- data/lib/fog/aws/compute.rb +1 -1
- data/lib/fog/aws/elasticache.rb +1 -1
- data/lib/fog/aws/elb.rb +1 -1
- data/lib/fog/aws/iam.rb +1 -1
- data/lib/fog/aws/models/beanstalk/environment.rb +6 -2
- data/lib/fog/aws/models/cdn/distributions.rb +2 -1
- data/lib/fog/aws/models/cdn/distributions_helper.rb +2 -1
- data/lib/fog/aws/models/cdn/streaming_distributions.rb +2 -1
- data/lib/fog/aws/models/compute/server.rb +1 -1
- data/lib/fog/aws/models/storage/directory.rb +1 -1
- data/lib/fog/aws/models/storage/file.rb +1 -1
- data/lib/fog/aws/parsers/beanstalk/describe_environment_resources.rb +11 -0
- data/lib/fog/aws/rds.rb +1 -1
- data/lib/fog/aws/requests/cdn/delete_distribution.rb +5 -7
- data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +5 -7
- data/lib/fog/aws/requests/cdn/get_distribution.rb +28 -31
- data/lib/fog/aws/requests/cdn/get_distribution_list.rb +29 -33
- data/lib/fog/aws/requests/cdn/get_invalidation.rb +15 -13
- data/lib/fog/aws/requests/cdn/get_invalidation_list.rb +15 -17
- data/lib/fog/aws/requests/cdn/get_streaming_distribution.rb +23 -26
- data/lib/fog/aws/requests/cdn/get_streaming_distribution_list.rb +29 -33
- data/lib/fog/aws/requests/cdn/post_distribution.rb +40 -42
- data/lib/fog/aws/requests/cdn/post_invalidation.rb +14 -18
- data/lib/fog/aws/requests/cdn/post_streaming_distribution.rb +28 -30
- data/lib/fog/aws/requests/cdn/put_distribution_config.rb +41 -43
- data/lib/fog/aws/requests/cdn/put_streaming_distribution_config.rb +31 -33
- data/lib/fog/aws/requests/cloud_formation/create_stack.rb +16 -20
- data/lib/fog/aws/requests/cloud_formation/delete_stack.rb +5 -8
- data/lib/fog/aws/requests/cloud_formation/describe_stack_events.rb +19 -22
- data/lib/fog/aws/requests/cloud_formation/describe_stack_resources.rb +18 -21
- data/lib/fog/aws/requests/cloud_formation/describe_stacks.rb +18 -21
- data/lib/fog/aws/requests/cloud_formation/get_template.rb +7 -10
- data/lib/fog/aws/requests/cloud_formation/update_stack.rb +12 -16
- data/lib/fog/aws/requests/cloud_formation/validate_template.rb +9 -12
- data/lib/fog/aws/requests/compute/associate_address.rb +13 -7
- data/lib/fog/aws/requests/compute/describe_reserved_instances_offerings.rb +16 -2
- data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -2
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +10 -0
- data/lib/fog/aws/requests/iam/update_server_certificate.rb +27 -0
- data/lib/fog/aws/requests/storage/get_object.rb +6 -2
- data/lib/fog/aws/storage.rb +6 -4
- data/lib/fog/aws/sts.rb +1 -1
- data/lib/fog/bin.rb +2 -0
- data/lib/fog/bin/digitalocean.rb +31 -0
- data/lib/fog/bin/riakcs.rb +27 -0
- data/lib/fog/cloudstack/compute.rb +3 -0
- data/lib/fog/cloudstack/models/compute/snapshot.rb +46 -0
- data/lib/fog/cloudstack/models/compute/snapshots.rb +25 -0
- data/lib/fog/cloudstack/requests/compute/create_snapshot.rb +24 -0
- data/lib/fog/compute.rb +3 -0
- data/lib/fog/compute/models/server.rb +6 -7
- data/lib/fog/core.rb +10 -5
- data/lib/fog/core/errors.rb +2 -0
- data/lib/fog/core/scp.rb +3 -3
- data/lib/fog/core/ssh.rb +1 -1
- data/lib/fog/digitalocean.rb +9 -0
- data/lib/fog/digitalocean/CHANGELOG.md +6 -0
- data/lib/fog/digitalocean/compute.rb +107 -0
- data/lib/fog/digitalocean/examples/getting_started.md +106 -0
- data/lib/fog/digitalocean/models/compute/flavor.rb +14 -0
- data/lib/fog/digitalocean/models/compute/flavors.rb +25 -0
- data/lib/fog/digitalocean/models/compute/image.rb +15 -0
- data/lib/fog/digitalocean/models/compute/images.rb +25 -0
- data/lib/fog/digitalocean/models/compute/region.rb +14 -0
- data/lib/fog/digitalocean/models/compute/regions.rb +25 -0
- data/lib/fog/digitalocean/models/compute/server.rb +150 -0
- data/lib/fog/digitalocean/models/compute/servers.rb +27 -0
- data/lib/fog/digitalocean/models/compute/ssh_key.rb +28 -0
- data/lib/fog/digitalocean/models/compute/ssh_keys.rb +27 -0
- data/lib/fog/digitalocean/requests/compute/create_server.rb +68 -0
- data/lib/fog/digitalocean/requests/compute/create_ssh_key.rb +38 -0
- data/lib/fog/digitalocean/requests/compute/destroy_server.rb +34 -0
- data/lib/fog/digitalocean/requests/compute/destroy_ssh_key.rb +37 -0
- data/lib/fog/digitalocean/requests/compute/get_server_details.rb +35 -0
- data/lib/fog/digitalocean/requests/compute/get_ssh_key.rb +39 -0
- data/lib/fog/digitalocean/requests/compute/list_flavors.rb +38 -0
- data/lib/fog/digitalocean/requests/compute/list_images.rb +49 -0
- data/lib/fog/digitalocean/requests/compute/list_regions.rb +34 -0
- data/lib/fog/digitalocean/requests/compute/list_servers.rb +31 -0
- data/lib/fog/digitalocean/requests/compute/list_ssh_keys.rb +31 -0
- data/lib/fog/digitalocean/requests/compute/power_cycle_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/power_off_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/power_on_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/reboot_server.rb +33 -0
- data/lib/fog/digitalocean/requests/compute/shutdown_server.rb +36 -0
- data/lib/fog/dreamhost/CHANGELOG.md +8 -0
- data/lib/fog/glesys/models/compute/server.rb +3 -3
- data/lib/fog/google/storage.rb +1 -1
- data/lib/fog/hp.rb +1 -1
- data/lib/fog/hp/CHANGELOG.hp +12 -2
- data/lib/fog/hp/block_storage.rb +1 -0
- data/lib/fog/hp/cdn.rb +1 -0
- data/lib/fog/hp/compute.rb +1 -0
- data/lib/fog/hp/models/compute/server.rb +14 -8
- data/lib/fog/hp/models/storage/directories.rb +1 -1
- data/lib/fog/hp/models/storage/directory.rb +28 -3
- data/lib/fog/hp/models/storage/files.rb +1 -1
- data/lib/fog/hp/requests/compute/create_server.rb +4 -14
- data/lib/fog/hp/storage.rb +2 -0
- data/lib/fog/internet_archive.rb +3 -1
- data/lib/fog/internet_archive/models/storage/directory.rb +25 -42
- data/lib/fog/internet_archive/models/storage/file.rb +45 -64
- data/lib/fog/internet_archive/models/storage/ia_attributes.rb +39 -0
- data/lib/fog/internet_archive/requests/storage/delete_multiple_objects.rb +4 -78
- data/lib/fog/internet_archive/requests/storage/delete_object.rb +2 -70
- data/lib/fog/internet_archive/requests/storage/get_object.rb +1 -22
- data/lib/fog/internet_archive/requests/storage/get_object_acl.rb +0 -4
- data/lib/fog/internet_archive/requests/storage/get_service.rb +1 -2
- data/lib/fog/internet_archive/requests/storage/head_object.rb +0 -4
- data/lib/fog/internet_archive/requests/storage/post_object_hidden_fields.rb +1 -1
- data/lib/fog/internet_archive/requests/storage/put_object.rb +2 -17
- data/lib/fog/internet_archive/requests/storage/put_object_acl.rb +0 -5
- data/lib/fog/internet_archive/storage.rb +6 -18
- data/lib/fog/joyent.rb +2 -0
- data/lib/fog/libvirt/requests/compute/get_node_info.rb +1 -1
- data/lib/fog/openstack/CHANGELOG.md +47 -0
- data/lib/fog/openstack/examples/identity/basics.rb +69 -0
- data/lib/fog/openstack/examples/image/upload-test-image.rb +77 -0
- data/lib/fog/openstack/examples/network/network_subnets_routers.rb +63 -0
- data/lib/fog/openstack/examples/storage/set-account-quota.rb +66 -0
- data/lib/fog/openstack/image.rb +4 -0
- data/lib/fog/openstack/models/compute/server.rb +4 -2
- data/lib/fog/openstack/models/network/floating_ip.rb +2 -2
- data/lib/fog/openstack/models/network/floating_ips.rb +1 -1
- data/lib/fog/openstack/models/network/router.rb +56 -0
- data/lib/fog/openstack/models/network/routers.rb +34 -0
- data/lib/fog/openstack/network.rb +15 -2
- data/lib/fog/openstack/requests/compute/create_server.rb +11 -0
- data/lib/fog/openstack/requests/compute/rebuild_server.rb +9 -1
- data/lib/fog/openstack/requests/network/add_router_interface.rb +48 -0
- data/lib/fog/openstack/requests/network/create_network.rb +57 -2
- data/lib/fog/openstack/requests/network/create_router.rb +57 -0
- data/lib/fog/openstack/requests/network/delete_router.rb +30 -0
- data/lib/fog/openstack/requests/network/get_router.rb +32 -0
- data/lib/fog/openstack/requests/network/list_routers.rb +27 -0
- data/lib/fog/openstack/requests/network/remove_router_interface.rb +36 -0
- data/lib/fog/openstack/requests/network/update_router.rb +85 -0
- data/lib/fog/openstack/storage.rb +57 -0
- data/lib/fog/ovirt/compute.rb +4 -0
- data/lib/fog/ovirt/models/compute/quota.rb +21 -0
- data/lib/fog/ovirt/models/compute/quotas.rb +24 -0
- data/lib/fog/ovirt/models/compute/server.rb +2 -1
- data/lib/fog/ovirt/models/compute/volume.rb +1 -0
- data/lib/fog/ovirt/requests/compute/get_quota.rb +19 -0
- data/lib/fog/ovirt/requests/compute/list_quotas.rb +21 -0
- data/lib/fog/ovirt/requests/compute/mock_files/quotas.xml +7 -0
- data/lib/fog/rackspace.rb +11 -0
- data/lib/fog/rackspace/block_storage.rb +73 -20
- data/lib/fog/rackspace/cdn.rb +57 -19
- data/lib/fog/rackspace/compute.rb +53 -28
- data/lib/fog/rackspace/compute_v2.rb +99 -22
- data/lib/fog/rackspace/databases.rb +74 -18
- data/lib/fog/rackspace/dns.rb +55 -22
- data/lib/fog/rackspace/docs/block_storage.md +417 -0
- data/lib/fog/rackspace/docs/compute_v2.md +114 -55
- data/lib/fog/rackspace/docs/getting_started.md +20 -10
- data/lib/fog/rackspace/docs/storage.md +496 -0
- data/lib/fog/rackspace/examples/README.md +1 -1
- data/lib/fog/rackspace/examples/block_storage/create_snapshot.rb +118 -0
- data/lib/fog/rackspace/examples/block_storage/create_volume.rb +58 -0
- data/lib/fog/rackspace/examples/block_storage/delete_volume.rb +53 -0
- data/lib/fog/rackspace/examples/compute_v2/create_image.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/create_server.rb +1 -1
- data/lib/fog/rackspace/examples/compute_v2/delete_image.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/delete_server.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/detach_volume.rb +4 -4
- data/lib/fog/rackspace/examples/compute_v2/resize_server.rb +2 -2
- data/lib/fog/rackspace/examples/compute_v2/server_attachments.rb +3 -3
- data/lib/fog/rackspace/examples/compute_v2/server_metadata.rb +2 -2
- data/lib/fog/rackspace/examples/storage/create_cdn_directory.rb +44 -0
- data/lib/fog/rackspace/examples/storage/create_private_directory.rb +46 -0
- data/lib/fog/rackspace/examples/storage/delete_directory.rb +62 -0
- data/lib/fog/rackspace/examples/storage/delete_file.rb +70 -0
- data/lib/fog/rackspace/examples/storage/download_file.rb +75 -0
- data/lib/fog/rackspace/examples/storage/lorem.txt +1 -0
- data/lib/fog/rackspace/examples/storage/storage_metadata.rb +82 -0
- data/lib/fog/rackspace/examples/storage/upload_file.rb +45 -0
- data/lib/fog/rackspace/identity.rb +10 -3
- data/lib/fog/rackspace/load_balancers.rb +76 -18
- data/lib/fog/rackspace/models/block_storage/snapshot.rb +42 -0
- data/lib/fog/rackspace/models/block_storage/snapshots.rb +15 -0
- data/lib/fog/rackspace/models/block_storage/volume.rb +65 -0
- data/lib/fog/rackspace/models/block_storage/volume_type.rb +6 -0
- data/lib/fog/rackspace/models/block_storage/volume_types.rb +15 -0
- data/lib/fog/rackspace/models/block_storage/volumes.rb +15 -0
- data/lib/fog/rackspace/models/compute_v2/attachment.rb +8 -0
- data/lib/fog/rackspace/models/compute_v2/attachments.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/flavors.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/image.rb +10 -2
- data/lib/fog/rackspace/models/compute_v2/images.rb +9 -1
- data/lib/fog/rackspace/models/compute_v2/meta_parent.rb +1 -1
- data/lib/fog/rackspace/models/compute_v2/metadata.rb +17 -5
- data/lib/fog/rackspace/models/compute_v2/metadatum.rb +8 -0
- data/lib/fog/rackspace/models/compute_v2/server.rb +72 -13
- data/lib/fog/rackspace/models/compute_v2/servers.rb +16 -2
- data/lib/fog/rackspace/models/dns/zones.rb +5 -9
- data/lib/fog/rackspace/models/identity/service_catalog.rb +83 -0
- data/lib/fog/rackspace/models/storage/account.rb +26 -0
- data/lib/fog/rackspace/models/storage/directories.rb +23 -3
- data/lib/fog/rackspace/models/storage/directory.rb +89 -5
- data/lib/fog/rackspace/models/storage/file.rb +112 -2
- data/lib/fog/rackspace/models/storage/files.rb +78 -0
- data/lib/fog/rackspace/models/storage/metadata.rb +28 -5
- data/lib/fog/rackspace/requests/block_storage/create_snapshot.rb +24 -0
- data/lib/fog/rackspace/requests/block_storage/create_volume.rb +29 -0
- data/lib/fog/rackspace/requests/block_storage/delete_snapshot.rb +10 -0
- data/lib/fog/rackspace/requests/block_storage/delete_volume.rb +11 -0
- data/lib/fog/rackspace/requests/block_storage/get_snapshot.rb +20 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume.rb +24 -0
- data/lib/fog/rackspace/requests/block_storage/get_volume_type.rb +14 -0
- data/lib/fog/rackspace/requests/block_storage/list_snapshots.rb +17 -0
- data/lib/fog/rackspace/requests/block_storage/list_volume_types.rb +13 -0
- data/lib/fog/rackspace/requests/block_storage/list_volumes.rb +21 -0
- data/lib/fog/rackspace/requests/cdn/delete_object.rb +5 -1
- data/lib/fog/rackspace/requests/cdn/get_containers.rb +5 -0
- data/lib/fog/rackspace/requests/cdn/head_container.rb +5 -0
- data/lib/fog/rackspace/requests/cdn/post_container.rb +6 -1
- data/lib/fog/rackspace/requests/cdn/put_container.rb +6 -1
- data/lib/fog/rackspace/requests/compute_v2/attach_volume.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/change_server_password.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/confirm_resize_server.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/create_image.rb +9 -4
- data/lib/fog/rackspace/requests/compute_v2/create_server.rb +9 -5
- data/lib/fog/rackspace/requests/compute_v2/delete_attachment.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_image.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_metadata_item.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/delete_server.rb +5 -0
- data/lib/fog/rackspace/requests/compute_v2/get_attachment.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_flavor.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_image.rb +5 -1
- data/lib/fog/rackspace/requests/compute_v2/get_metadata_item.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/get_server.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_addresses.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_addresses_by_network.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_attachments.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_flavors.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_images.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/list_servers.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/reboot_server.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/rebuild_server.rb +8 -4
- data/lib/fog/rackspace/requests/compute_v2/resize_server.rb +6 -1
- data/lib/fog/rackspace/requests/compute_v2/revert_resize_server.rb +8 -3
- data/lib/fog/rackspace/requests/compute_v2/set_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/set_metadata_item.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/update_metadata.rb +4 -0
- data/lib/fog/rackspace/requests/compute_v2/update_server.rb +4 -0
- data/lib/fog/rackspace/requests/storage/copy_object.rb +4 -0
- data/lib/fog/rackspace/requests/storage/delete_container.rb +4 -1
- data/lib/fog/rackspace/requests/storage/delete_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/get_container.rb +4 -0
- data/lib/fog/rackspace/requests/storage/get_containers.rb +4 -0
- data/lib/fog/rackspace/requests/storage/get_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/get_object_https_url.rb +7 -4
- data/lib/fog/rackspace/requests/storage/head_container.rb +4 -0
- data/lib/fog/rackspace/requests/storage/head_containers.rb +4 -0
- data/lib/fog/rackspace/requests/storage/head_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/post_set_meta_temp_url_key.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_container.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_object.rb +4 -1
- data/lib/fog/rackspace/requests/storage/put_object_manifest.rb +4 -1
- data/lib/fog/rackspace/service.rb +78 -0
- data/lib/fog/rackspace/storage.rb +62 -22
- data/lib/fog/riakcs.rb +122 -0
- data/lib/fog/riakcs/provisioning.rb +100 -0
- data/lib/fog/riakcs/requests/provisioning/create_user.rb +77 -0
- data/lib/fog/riakcs/requests/provisioning/disable_user.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/enable_user.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/get_user.rb +41 -0
- data/lib/fog/riakcs/requests/provisioning/list_users.rb +43 -0
- data/lib/fog/riakcs/requests/provisioning/regrant_secret.rb +23 -0
- data/lib/fog/riakcs/requests/provisioning/update_user.rb +23 -0
- data/lib/fog/riakcs/requests/usage/get_usage.rb +68 -0
- data/lib/fog/riakcs/usage.rb +66 -0
- data/lib/fog/vcloud/compute.rb +1 -1
- data/lib/fog/vcloud/models/compute/catalog_item.rb +8 -0
- data/lib/fog/vcloud/models/compute/server.rb +1 -0
- data/lib/fog/vcloud/requests/compute/configure_vm_network.rb +1 -2
- data/lib/fog/version.rb +1 -1
- data/lib/fog/vsphere/compute.rb +1 -1
- data/lib/fog/vsphere/models/compute/servers.rb +9 -9
- data/lib/fog/xenserver.rb +2 -0
- data/lib/fog/xenserver/CHANGELOG.md +7 -1
- data/lib/fog/xenserver/compute.rb +6 -0
- data/lib/fog/xenserver/examples/networks-and-vlans.rb +45 -0
- data/lib/fog/xenserver/models/compute/network.rb +33 -0
- data/lib/fog/xenserver/models/compute/vlan.rb +80 -0
- data/lib/fog/xenserver/models/compute/vlans.rb +39 -0
- data/lib/fog/xenserver/requests/compute/create_network.rb +42 -0
- data/lib/fog/xenserver/requests/compute/create_vlan.rb +35 -0
- data/lib/fog/xenserver/requests/compute/destroy_network.rb +33 -0
- data/lib/fog/xenserver/requests/compute/destroy_vlan.rb +32 -0
- data/lib/fog/zerigo/models/dns/records.rb +15 -12
- data/lib/tasks/changelog_task.rb +1 -0
- data/tests/aws/requests/compute/address_tests.rb +4 -0
- data/tests/aws/requests/iam/server_certificate_tests.rb +32 -0
- data/tests/cloudstack/compute/models/snapshot_tests.rb +34 -0
- data/tests/digitalocean/helper.rb +44 -0
- data/tests/digitalocean/models/compute/flavor_tests.rb +30 -0
- data/tests/digitalocean/models/compute/image_tests.rb +31 -0
- data/tests/digitalocean/models/compute/region_tests.rb +30 -0
- data/tests/digitalocean/models/compute/server_tests.rb +84 -0
- data/tests/digitalocean/models/compute/servers_tests.rb +35 -0
- data/tests/digitalocean/models/compute/ssh_key_tests.rb +40 -0
- data/tests/digitalocean/models/compute/ssh_keys_tests.rb +28 -0
- data/tests/digitalocean/requests/compute/create_server_tests.rb +28 -0
- data/tests/digitalocean/requests/compute/create_ssh_key_tests.rb +22 -0
- data/tests/digitalocean/requests/compute/destroy_server_tests.rb +15 -0
- data/tests/digitalocean/requests/compute/destroy_ssh_key_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/get_server_details_tests.rb +13 -0
- data/tests/digitalocean/requests/compute/get_ssh_key_tests.rb +22 -0
- data/tests/digitalocean/requests/compute/list_flavors_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/list_images_tests.rb +24 -0
- data/tests/digitalocean/requests/compute/list_regions_tests.rb +23 -0
- data/tests/digitalocean/requests/compute/list_servers_tests.rb +26 -0
- data/tests/digitalocean/requests/compute/list_ssh_keys_tests.rb +21 -0
- data/tests/digitalocean/requests/compute/power_cycle_server_tests.rb +20 -0
- data/tests/digitalocean/requests/compute/power_state_tests.rb +25 -0
- data/tests/digitalocean/requests/compute/reboot_server_tests.rb +14 -0
- data/tests/helpers/collection_helper.rb +36 -1
- data/tests/helpers/mock_helper.rb +2 -0
- data/tests/internet_archive/models/storage/directory_tests.rb +24 -32
- data/tests/internet_archive/models/storage/file_tests.rb +16 -35
- data/tests/internet_archive/models/storage/files_tests.rb +33 -31
- data/tests/internet_archive/models/storage/url_tests.rb +1 -1
- data/tests/internet_archive/requests/storage/bucket_tests.rb +34 -38
- data/tests/internet_archive/requests/storage/multipart_upload_tests.rb +1 -1
- data/tests/openstack/models/network/network_tests.rb +17 -0
- data/tests/openstack/models/network/router_tests.rb +38 -0
- data/tests/openstack/models/network/routers_tests.rb +21 -0
- data/tests/openstack/requests/network/network_tests.rb +61 -10
- data/tests/openstack/requests/network/router_tests.rb +75 -0
- data/tests/openstack/storage_tests.rb +19 -0
- data/tests/ovirt/requests/compute/list_quotas_tests.rb +12 -0
- data/tests/rackspace/block_storage_tests.rb +101 -0
- data/tests/rackspace/cdn_tests.rb +144 -52
- data/tests/rackspace/compute_tests.rb +88 -0
- data/tests/rackspace/compute_v2_tests.rb +101 -0
- data/tests/rackspace/databases_tests.rb +98 -0
- data/tests/rackspace/dns_tests.rb +82 -0
- data/tests/rackspace/load_balancer_tests.rb +99 -0
- data/tests/rackspace/models/compute_v2/image_tests.rb +51 -0
- data/tests/rackspace/models/compute_v2/server_tests.rb +51 -0
- data/tests/rackspace/models/identity/service_catalog_tests.rb +81 -0
- data/tests/rackspace/models/storage/file_tests.rb +10 -1
- data/tests/rackspace/rackspace_tests.rb +21 -0
- data/tests/rackspace/requests/compute_v2/metadata_tests.rb +2 -2
- data/tests/rackspace/requests/storage/object_tests.rb +2 -2
- data/tests/rackspace/storage_tests.rb +99 -3
- data/tests/riakcs/requests/provisioning/provisioning_tests.rb +174 -0
- data/tests/riakcs/requests/usage/usage_tests.rb +29 -0
- data/tests/xenserver/models/compute/network_tests.rb +18 -6
- data/tests/xenserver/models/compute/vlan_tests.rb +76 -0
- data/tests/xenserver/models/compute/vlans_tests.rb +36 -0
- data/tests/xenserver/requests/compute/create_network_tests.rb +20 -0
- data/tests/xenserver/requests/compute/create_vlan_tests.rb +36 -0
- data/tests/xenserver/requests/compute/destroy_network_tests.rb +13 -0
- data/tests/xenserver/requests/compute/destroy_vlan_tests.rb +36 -0
- metadata +178 -21
- data/lib/fog/internet_archive/models/storage/version.rb +0 -36
- data/lib/fog/internet_archive/models/storage/versions.rb +0 -38
- data/lib/fog/internet_archive/parsers/storage/get_bucket_object_versions.rb +0 -88
- data/lib/fog/internet_archive/parsers/storage/get_bucket_versioning.rb +0 -24
- data/lib/fog/internet_archive/requests/storage/get_bucket_object_versions.rb +0 -162
- data/lib/fog/internet_archive/requests/storage/get_bucket_versioning.rb +0 -69
- data/lib/fog/internet_archive/requests/storage/put_bucket_versioning.rb +0 -75
- data/lib/fog/openstack/README.identity.md +0 -69
- data/lib/fog/providers.rb +0 -34
- data/lib/fog/rackspace/examples/compute_v2/README.md +0 -47
- data/tests/internet_archive/models/storage/version_tests.rb +0 -52
- data/tests/internet_archive/models/storage/versions_tests.rb +0 -56
- data/tests/internet_archive/requests/storage/versioning_tests.rb +0 -258
@@ -14,6 +14,7 @@ module Fog
|
|
14
14
|
# @option options If-Unmodified-Since [Time] Returns object only if it has not been modified since this time, otherwise returns 412 (Precodition Failed).
|
15
15
|
# @option options Range [String] Range of object to download
|
16
16
|
# @option options versionId [String] specify a particular version to retrieve
|
17
|
+
# @option options query[Hash] specify additional query string
|
17
18
|
#
|
18
19
|
# @return [Excon::Response] response:
|
19
20
|
# * body [String]- Contents of object
|
@@ -34,8 +35,11 @@ module Fog
|
|
34
35
|
end
|
35
36
|
|
36
37
|
params = { :headers => {} }
|
38
|
+
|
39
|
+
params[:query] = options.delete('query') || {}
|
40
|
+
|
37
41
|
if version_id = options.delete('versionId')
|
38
|
-
params[:query] = {'versionId' => version_id}
|
42
|
+
params[:query] = params[:query].merge({'versionId' => version_id})
|
39
43
|
end
|
40
44
|
params[:headers].merge!(options)
|
41
45
|
if options['If-Modified-Since']
|
@@ -54,7 +58,7 @@ module Fog
|
|
54
58
|
:host => "#{bucket_name}.#{@host}",
|
55
59
|
:idempotent => true,
|
56
60
|
:method => 'GET',
|
57
|
-
:path => CGI.escape(object_name)
|
61
|
+
:path => CGI.escape(object_name)
|
58
62
|
}))
|
59
63
|
end
|
60
64
|
|
data/lib/fog/aws/storage.rb
CHANGED
@@ -7,7 +7,7 @@ module Fog
|
|
7
7
|
extend Fog::AWS::CredentialFetcher::ServiceMethods
|
8
8
|
|
9
9
|
requires :aws_access_key_id, :aws_secret_access_key
|
10
|
-
recognizes :endpoint, :region, :host, :path, :port, :scheme, :persistent, :use_iam_profile, :aws_session_token, :aws_credentials_expire_at
|
10
|
+
recognizes :endpoint, :region, :host, :path, :port, :scheme, :persistent, :use_iam_profile, :aws_session_token, :aws_credentials_expire_at, :path_style
|
11
11
|
|
12
12
|
secrets :aws_secret_access_key, :hmac
|
13
13
|
|
@@ -294,6 +294,7 @@ module Fog
|
|
294
294
|
@persistent = options.fetch(:persistent, false)
|
295
295
|
@port = options[:port] || 443
|
296
296
|
@scheme = options[:scheme] || 'https'
|
297
|
+
@path_style = options[:path_style] || false
|
297
298
|
end
|
298
299
|
@connection = Fog::Connection.new("#{@scheme}://#{@host}:#{@port}#{@path}", @persistent, @connection_options)
|
299
300
|
end
|
@@ -324,11 +325,12 @@ DATA
|
|
324
325
|
string_to_sign << canonical_amz_headers
|
325
326
|
|
326
327
|
subdomain = params[:host].split(".#{@host}").first
|
327
|
-
|
328
|
-
|
328
|
+
valid_dns = !!(subdomain =~ /^(?:[a-z]|\d(?!\d{0,2}(?:\.\d{1,3}){3}$))(?:[a-z0-9]|\.(?![\.\-])|\-(?![\.])){1,61}[a-z0-9]$/)
|
329
|
+
if !valid_dns || @path_style
|
330
|
+
Fog::Logger.warning("fog: the specified s3 bucket name(#{subdomain}) is not a valid dns name, which will negatively impact performance. For details see: http://docs.amazonwebservices.com/AmazonS3/latest/dev/BucketRestrictions.html") unless valid_dns
|
329
331
|
params[:host] = params[:host].split("#{subdomain}.")[-1]
|
330
332
|
if params[:path]
|
331
|
-
params[:path] = "#{subdomain}/#{params[:path]}"
|
333
|
+
params[:path] = "#{subdomain}/#{params[:path]}" unless subdomain == @host
|
332
334
|
else
|
333
335
|
params[:path] = subdomain
|
334
336
|
end
|
data/lib/fog/aws/sts.rb
CHANGED
@@ -114,7 +114,7 @@ module Fog
|
|
114
114
|
|
115
115
|
response
|
116
116
|
rescue Excon::Errors::HTTPStatusError => error
|
117
|
-
if match = error.message.match(
|
117
|
+
if match = error.message.match(/(?:.*<Code>(.*)<\/Code>)(?:.*<Message>(.*)<\/Message>)/m)
|
118
118
|
case match[1]
|
119
119
|
when 'EntityAlreadyExists', 'KeyPairMismatch', 'LimitExceeded', 'MalformedCertificate', 'ValidationError'
|
120
120
|
raise Fog::AWS::STS.const_get(match[1]).slurp(error, match[2])
|
data/lib/fog/bin.rb
CHANGED
@@ -63,6 +63,7 @@ require 'fog/bin/bluebox'
|
|
63
63
|
require 'fog/bin/brightbox'
|
64
64
|
require 'fog/bin/cloudstack'
|
65
65
|
require 'fog/bin/clodo'
|
66
|
+
require 'fog/bin/digitalocean'
|
66
67
|
require 'fog/bin/dnsimple'
|
67
68
|
require 'fog/bin/dnsmadeeasy'
|
68
69
|
require 'fog/bin/dreamhost'
|
@@ -81,6 +82,7 @@ require 'fog/bin/local'
|
|
81
82
|
require 'fog/bin/bare_metal_cloud'
|
82
83
|
require 'fog/bin/ninefold'
|
83
84
|
require 'fog/bin/rackspace'
|
85
|
+
require 'fog/bin/riakcs'
|
84
86
|
require 'fog/bin/openstack'
|
85
87
|
require 'fog/bin/ovirt'
|
86
88
|
require 'fog/bin/serverlove'
|
@@ -0,0 +1,31 @@
|
|
1
|
+
class DigitalOcean < Fog::Bin
|
2
|
+
class << self
|
3
|
+
|
4
|
+
def class_for(key)
|
5
|
+
case key
|
6
|
+
when :compute
|
7
|
+
Fog::Compute::DigitalOcean
|
8
|
+
else
|
9
|
+
raise ArgumentError, "Unsupported #{self} service: #{key}"
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def [](service)
|
14
|
+
@@connections ||= Hash.new do |hash, key|
|
15
|
+
hash[key] = case key
|
16
|
+
when :compute
|
17
|
+
Fog::Logger.warning("DigitalOcean[:compute] is not recommended, use Compute[:digitalocean] for portability")
|
18
|
+
Fog::Compute.new(:provider => 'DigitalOcean')
|
19
|
+
else
|
20
|
+
raise ArgumentError, "Unrecognized service: #{key.inspect}"
|
21
|
+
end
|
22
|
+
end
|
23
|
+
@@connections[service]
|
24
|
+
end
|
25
|
+
|
26
|
+
def services
|
27
|
+
Fog::DigitalOcean.services
|
28
|
+
end
|
29
|
+
|
30
|
+
end
|
31
|
+
end
|
@@ -0,0 +1,27 @@
|
|
1
|
+
class RiakCS < Fog::Bin
|
2
|
+
class << self
|
3
|
+
|
4
|
+
def class_for(key)
|
5
|
+
case key
|
6
|
+
when :provisioning
|
7
|
+
Fog::RiakCS::Provisioning
|
8
|
+
when :usage
|
9
|
+
Fog::RiakCS::Usage
|
10
|
+
else
|
11
|
+
raise ArgumentError, "Unrecognized service: #{key}"
|
12
|
+
end
|
13
|
+
end
|
14
|
+
|
15
|
+
def [](service)
|
16
|
+
@@connections ||= Hash.new do |hash, key|
|
17
|
+
hash[key] = class_for(key)
|
18
|
+
end
|
19
|
+
@@connections[service]
|
20
|
+
end
|
21
|
+
|
22
|
+
def services
|
23
|
+
Fog::RiakCS.services
|
24
|
+
end
|
25
|
+
|
26
|
+
end
|
27
|
+
end
|
@@ -33,6 +33,8 @@ module Fog
|
|
33
33
|
collection :security_group_rules
|
34
34
|
model :volume
|
35
35
|
collection :volumes
|
36
|
+
model :snapshot
|
37
|
+
collection :snapshots
|
36
38
|
model :zone
|
37
39
|
collection :zones
|
38
40
|
|
@@ -420,6 +422,7 @@ module Fog
|
|
420
422
|
:jobs => {},
|
421
423
|
:volumes => {},
|
422
424
|
:security_groups => {},
|
425
|
+
:snapshots => {}
|
423
426
|
}
|
424
427
|
end
|
425
428
|
end
|
@@ -0,0 +1,46 @@
|
|
1
|
+
module Fog
|
2
|
+
module Compute
|
3
|
+
class Cloudstack
|
4
|
+
class Snapshot < Fog::Model
|
5
|
+
identity :id, :aliases => 'id'
|
6
|
+
|
7
|
+
attribute :name, :aliases => 'name'
|
8
|
+
attribute :volume_type, :aliases => 'volumetype'
|
9
|
+
attribute :volume_name, :aliases => 'volumename'
|
10
|
+
attribute :volume_id, :aliases => 'volumeid'
|
11
|
+
attribute :created, :aliases => 'created'
|
12
|
+
attribute :state, :aliases => 'state'
|
13
|
+
attribute :account, :aliases => 'account'
|
14
|
+
attribute :domain_id, :aliases => 'domainid'
|
15
|
+
attribute :domain, :aliases => 'domain'
|
16
|
+
attribute :snapshot_type, :aliases => 'snapshot_type'
|
17
|
+
attribute :interval_type, :aliases => 'interval_type'
|
18
|
+
|
19
|
+
def save
|
20
|
+
requires :volume_id
|
21
|
+
|
22
|
+
options = {
|
23
|
+
'volumeid' => volume_id,
|
24
|
+
'domainid' => domain_id
|
25
|
+
}
|
26
|
+
data = service.create_snapshot(options)
|
27
|
+
merge_attributes(data['createsnapshotresponse'])
|
28
|
+
end
|
29
|
+
|
30
|
+
def ready?
|
31
|
+
state == 'BackedUp'
|
32
|
+
end
|
33
|
+
|
34
|
+
def volume
|
35
|
+
service.volumes.get(volume_id) if volume_id
|
36
|
+
end
|
37
|
+
|
38
|
+
def destroy
|
39
|
+
requires :id
|
40
|
+
service.delete_snapshot('id' => id)
|
41
|
+
true
|
42
|
+
end
|
43
|
+
end # Snapshot
|
44
|
+
end # Cloudstack
|
45
|
+
end # Compute
|
46
|
+
end # Fog
|
@@ -0,0 +1,25 @@
|
|
1
|
+
require 'fog/core/collection'
|
2
|
+
require 'fog/cloudstack/models/compute/snapshot'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class Cloudstack
|
7
|
+
|
8
|
+
class Snapshots < Fog::Collection
|
9
|
+
|
10
|
+
model Fog::Compute::Cloudstack::Snapshot
|
11
|
+
|
12
|
+
def all
|
13
|
+
data = service.list_snapshots["listsnapshotsresponse"]["snapshot"] || []
|
14
|
+
load(data)
|
15
|
+
end
|
16
|
+
|
17
|
+
def get(snapshot_id)
|
18
|
+
snapshot = service.list_snapshots('id' => snapshot_id)["listsnapshotsresponse"]["snapshot"].first
|
19
|
+
new(snapshot) if snapshot
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -15,6 +15,30 @@ module Fog
|
|
15
15
|
end
|
16
16
|
|
17
17
|
end
|
18
|
+
|
19
|
+
class Mock
|
20
|
+
def create_snapshot(options={})
|
21
|
+
snapshot_id = Fog::Cloudstack.uuid
|
22
|
+
|
23
|
+
unless volume_id = options['volumeid']
|
24
|
+
raise Fog::Compute::Cloudstack::BadRequest.new('Unable to execute API command createsnapshot due to missing parameter volumeid')
|
25
|
+
end
|
26
|
+
|
27
|
+
snapshot = {
|
28
|
+
"id" => snapshot_id,
|
29
|
+
"name" => "ROOT-6",
|
30
|
+
"created" => "2013-05-22T14:52:55-0500",
|
31
|
+
"state" => "BackedUp",
|
32
|
+
"account" => "accountname",
|
33
|
+
"domainid" => "6023b6fe-5bef-4358-bc76-9f4e75afa52f",
|
34
|
+
"domain" => "ROOT",
|
35
|
+
"intervaltype" => "weekly"
|
36
|
+
}
|
37
|
+
|
38
|
+
self.data[:snapshots][snapshot_id]= snapshot
|
39
|
+
{'createsnapshotresponse' => snapshot}
|
40
|
+
end
|
41
|
+
end
|
18
42
|
end
|
19
43
|
end
|
20
44
|
end
|
data/lib/fog/compute.rb
CHANGED
@@ -35,6 +35,9 @@ module Fog
|
|
35
35
|
when :stormondemand
|
36
36
|
require 'fog/storm_on_demand/compute'
|
37
37
|
Fog::Compute::StormOnDemand.new(attributes)
|
38
|
+
when :vcloud
|
39
|
+
require 'fog/vcloud/compute'
|
40
|
+
Fog::Vcloud::Compute.new(attributes)
|
38
41
|
else
|
39
42
|
if self.providers.include?(provider)
|
40
43
|
require "fog/#{provider}/compute"
|
@@ -4,7 +4,7 @@ module Fog
|
|
4
4
|
module Compute
|
5
5
|
class Server < Fog::Model
|
6
6
|
|
7
|
-
attr_writer :username, :private_key, :private_key_path, :public_key, :public_key_path
|
7
|
+
attr_writer :username, :private_key, :private_key_path, :public_key, :public_key_path, :ssh_port
|
8
8
|
|
9
9
|
def username
|
10
10
|
@username ||= 'root'
|
@@ -28,6 +28,9 @@ module Fog
|
|
28
28
|
@public_key ||= public_key_path && File.read(public_key_path)
|
29
29
|
end
|
30
30
|
|
31
|
+
def ssh_port
|
32
|
+
@ssh_port ||= 22
|
33
|
+
end
|
31
34
|
|
32
35
|
def scp(local_path, remote_path, upload_options = {})
|
33
36
|
require 'net/scp'
|
@@ -58,12 +61,8 @@ module Fog
|
|
58
61
|
Fog::SSH.new(public_ip_address, username, options).run(commands, &blk)
|
59
62
|
end
|
60
63
|
|
61
|
-
def
|
62
|
-
|
63
|
-
end
|
64
|
-
|
65
|
-
def sshable?
|
66
|
-
ready? && !public_ip_address.nil? && !!Timeout::timeout(8) { ssh 'pwd' }
|
64
|
+
def sshable?(options={})
|
65
|
+
ready? && !public_ip_address.nil? && !!Timeout::timeout(8) { ssh('pwd', options) }
|
67
66
|
rescue SystemCallError, Net::SSH::AuthenticationFailed, Timeout::Error
|
68
67
|
false
|
69
68
|
end
|
data/lib/fog/core.rb
CHANGED
@@ -1,8 +1,3 @@
|
|
1
|
-
__LIB_DIR__ = File.expand_path(File.join(File.dirname(__FILE__), '..'))
|
2
|
-
|
3
|
-
$LOAD_PATH.unshift __LIB_DIR__ unless
|
4
|
-
$LOAD_PATH.include?(__LIB_DIR__)
|
5
|
-
|
6
1
|
# external core dependencies
|
7
2
|
require 'base64'
|
8
3
|
require 'cgi'
|
@@ -36,3 +31,13 @@ require 'fog/core/scp'
|
|
36
31
|
require 'fog/core/time'
|
37
32
|
require 'fog/core/timeout'
|
38
33
|
require 'fog/core/wait_for'
|
34
|
+
|
35
|
+
# service wrappers
|
36
|
+
require 'fog/compute'
|
37
|
+
require 'fog/identity'
|
38
|
+
require 'fog/image'
|
39
|
+
require 'fog/volume'
|
40
|
+
require 'fog/cdn'
|
41
|
+
require 'fog/dns'
|
42
|
+
require 'fog/network'
|
43
|
+
require 'fog/storage'
|
data/lib/fog/core/errors.rb
CHANGED
@@ -71,6 +71,8 @@ An alternate file may be used by placing its path in the FOG_RC environment vari
|
|
71
71
|
:rackspace_username:
|
72
72
|
:rackspace_servicenet:
|
73
73
|
:rackspace_cdn_ssl:
|
74
|
+
:riakcs_access_key_id:
|
75
|
+
:riakcs_secret_access_key:
|
74
76
|
:stormondemand_username:
|
75
77
|
:stormondemand_password:
|
76
78
|
:terremark_username:
|
data/lib/fog/core/scp.rb
CHANGED
@@ -66,11 +66,11 @@ module Fog
|
|
66
66
|
@options = { :paranoid => false }.merge(options)
|
67
67
|
end
|
68
68
|
|
69
|
-
def upload(local_path, remote_path, upload_options = {})
|
69
|
+
def upload(local_path, remote_path, upload_options = {}, &block)
|
70
70
|
begin
|
71
71
|
Net::SCP.start(@address, @username, @options) do |scp|
|
72
72
|
scp.upload!(local_path, remote_path, upload_options) do |ch, name, sent, total|
|
73
|
-
|
73
|
+
block.call(ch, name, sent, total) if block
|
74
74
|
end
|
75
75
|
end
|
76
76
|
rescue Exception => error
|
@@ -82,7 +82,7 @@ module Fog
|
|
82
82
|
begin
|
83
83
|
Net::SCP.start(@address, @username, @options) do |scp|
|
84
84
|
scp.download!(remote_path, local_path, download_options) do |ch, name, sent, total|
|
85
|
-
|
85
|
+
block.call(ch, name, sent, total) if block
|
86
86
|
end
|
87
87
|
end
|
88
88
|
rescue Exception => error
|
data/lib/fog/core/ssh.rb
CHANGED
@@ -46,7 +46,7 @@ module Fog
|
|
46
46
|
raise ArgumentError.new(':key_data, :keys, :password or a loaded ssh-agent is required to initialize SSH')
|
47
47
|
end
|
48
48
|
|
49
|
-
options[:timeout]
|
49
|
+
options[:timeout] ||= 30
|
50
50
|
if options[:key_data] || options[:keys]
|
51
51
|
options[:keys_only] = true
|
52
52
|
#Explicitly set these so net-ssh doesn't add the default keys
|
@@ -0,0 +1,107 @@
|
|
1
|
+
require 'fog/digitalocean'
|
2
|
+
require 'fog/compute'
|
3
|
+
|
4
|
+
module Fog
|
5
|
+
module Compute
|
6
|
+
class DigitalOcean < Fog::Service
|
7
|
+
|
8
|
+
requires :digitalocean_api_key
|
9
|
+
requires :digitalocean_client_id
|
10
|
+
|
11
|
+
recognizes :digitalocean_api_url
|
12
|
+
|
13
|
+
model_path 'fog/digitalocean/models/compute'
|
14
|
+
model :server
|
15
|
+
collection :servers
|
16
|
+
model :flavor
|
17
|
+
collection :flavors
|
18
|
+
model :image
|
19
|
+
collection :images
|
20
|
+
model :region
|
21
|
+
collection :regions
|
22
|
+
model :ssh_key
|
23
|
+
collection :ssh_keys
|
24
|
+
|
25
|
+
request_path 'fog/digitalocean/requests/compute'
|
26
|
+
request :list_servers
|
27
|
+
request :list_images
|
28
|
+
request :list_regions
|
29
|
+
request :list_flavors
|
30
|
+
request :get_server_details
|
31
|
+
request :create_server
|
32
|
+
request :destroy_server
|
33
|
+
request :reboot_server
|
34
|
+
request :power_cycle_server
|
35
|
+
request :power_off_server
|
36
|
+
request :power_on_server
|
37
|
+
request :shutdown_server
|
38
|
+
request :list_ssh_keys
|
39
|
+
request :create_ssh_key
|
40
|
+
request :get_ssh_key
|
41
|
+
request :destroy_ssh_key
|
42
|
+
|
43
|
+
# request :digitalocean_resize
|
44
|
+
|
45
|
+
class Mock
|
46
|
+
|
47
|
+
def self.data
|
48
|
+
@data ||= Hash.new do |hash, key|
|
49
|
+
hash[key] = {
|
50
|
+
:servers => [],
|
51
|
+
:ssh_keys => []
|
52
|
+
}
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
def self.reset
|
57
|
+
@data = nil
|
58
|
+
end
|
59
|
+
|
60
|
+
def initialize(options={})
|
61
|
+
@digitalocean_api_key = options[:digitalocean_api_key]
|
62
|
+
end
|
63
|
+
|
64
|
+
def data
|
65
|
+
self.class.data[@digitalocean_api_key]
|
66
|
+
end
|
67
|
+
|
68
|
+
def reset_data
|
69
|
+
self.class.data.delete(@digitalocean_api_key)
|
70
|
+
end
|
71
|
+
|
72
|
+
end
|
73
|
+
|
74
|
+
class Real
|
75
|
+
|
76
|
+
def initialize(options={})
|
77
|
+
@digitalocean_api_key = options[:digitalocean_api_key]
|
78
|
+
@digitalocean_client_id = options[:digitalocean_client_id]
|
79
|
+
@digitalocean_api_url = options[:digitalocean_api_url] || \
|
80
|
+
"https://api.digitalocean.com"
|
81
|
+
@connection = Fog::Connection.new(@digitalocean_api_url)
|
82
|
+
end
|
83
|
+
|
84
|
+
def reload
|
85
|
+
@connection.reset
|
86
|
+
end
|
87
|
+
|
88
|
+
def request(params)
|
89
|
+
params[:query] ||= {}
|
90
|
+
params[:query].merge!(:api_key => @digitalocean_api_key)
|
91
|
+
params[:query].merge!(:client_id => @digitalocean_client_id)
|
92
|
+
|
93
|
+
response = @connection.request(params)
|
94
|
+
|
95
|
+
unless response.body.empty?
|
96
|
+
response.body = Fog::JSON.decode(response.body)
|
97
|
+
if response.body['status'] != 'OK'
|
98
|
+
raise Fog::Errors::Error.new response.body.to_s
|
99
|
+
end
|
100
|
+
end
|
101
|
+
response
|
102
|
+
end
|
103
|
+
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|