phpfog-fog 0.4.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.document +3 -0
- data/.gitignore +11 -0
- data/Gemfile +3 -0
- data/Gemfile.lock +45 -0
- data/README.rdoc +176 -0
- data/Rakefile +132 -0
- data/benchs/fog_vs.rb +106 -0
- data/benchs/params.rb +43 -0
- data/benchs/parse_vs_push.rb +60 -0
- data/bin/fog +46 -0
- data/examples/dns_tests.rb +76 -0
- data/examples/storage_tests.rb +103 -0
- data/fog.gemspec +62 -0
- data/lib/fog/aws/elb.rb +106 -0
- data/lib/fog/aws/iam.rb +105 -0
- data/lib/fog/aws/parsers/elb/create_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/delete_load_balancer.rb +24 -0
- data/lib/fog/aws/parsers/elb/deregister_instances_from_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/describe_instance_health.rb +30 -0
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +101 -0
- data/lib/fog/aws/parsers/elb/disable_availability_zones_for_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/enable_availability_zones_for_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/elb/register_instances_with_load_balancer.rb +26 -0
- data/lib/fog/aws/parsers/iam/basic.rb +19 -0
- data/lib/fog/aws/parsers/iam/create_access_key.rb +26 -0
- data/lib/fog/aws/parsers/iam/create_group.rb +26 -0
- data/lib/fog/aws/parsers/iam/create_user.rb +26 -0
- data/lib/fog/aws/parsers/iam/get_user.rb +27 -0
- data/lib/fog/aws/parsers/iam/list_access_keys.rb +32 -0
- data/lib/fog/aws/parsers/iam/list_groups.rb +32 -0
- data/lib/fog/aws/parsers/iam/list_policies.rb +28 -0
- data/lib/fog/aws/parsers/iam/list_users.rb +32 -0
- data/lib/fog/aws/parsers/ses/delete_verified_email_address.rb +24 -0
- data/lib/fog/aws/parsers/ses/get_send_quota.rb +26 -0
- data/lib/fog/aws/parsers/ses/get_send_statistics.rb +29 -0
- data/lib/fog/aws/parsers/ses/list_verified_email_addresses.rb +25 -0
- data/lib/fog/aws/parsers/ses/send_email.rb +26 -0
- data/lib/fog/aws/parsers/ses/send_raw_email.rb +26 -0
- data/lib/fog/aws/parsers/ses/verify_email_address.rb +24 -0
- data/lib/fog/aws/parsers/simpledb/basic.rb +31 -0
- data/lib/fog/aws/parsers/simpledb/domain_metadata.rb +32 -0
- data/lib/fog/aws/parsers/simpledb/get_attributes.rb +36 -0
- data/lib/fog/aws/parsers/simpledb/list_domains.rb +30 -0
- data/lib/fog/aws/parsers/simpledb/select.rb +41 -0
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +59 -0
- data/lib/fog/aws/requests/elb/delete_load_balancer.rb +42 -0
- data/lib/fog/aws/requests/elb/deregister_instances_from_load_balancer.rb +47 -0
- data/lib/fog/aws/requests/elb/describe_instance_health.rb +46 -0
- data/lib/fog/aws/requests/elb/describe_load_balancers.rb +59 -0
- data/lib/fog/aws/requests/elb/disable_availability_zones_for_load_balancer.rb +46 -0
- data/lib/fog/aws/requests/elb/enable_availability_zones_for_load_balancer.rb +46 -0
- data/lib/fog/aws/requests/elb/register_instances_with_load_balancer.rb +47 -0
- data/lib/fog/aws/requests/iam/add_user_to_group.rb +42 -0
- data/lib/fog/aws/requests/iam/create_access_key.rb +45 -0
- data/lib/fog/aws/requests/iam/create_group.rb +47 -0
- data/lib/fog/aws/requests/iam/create_user.rb +47 -0
- data/lib/fog/aws/requests/iam/delete_access_key.rb +42 -0
- data/lib/fog/aws/requests/iam/delete_group.rb +40 -0
- data/lib/fog/aws/requests/iam/delete_group_policy.rb +42 -0
- data/lib/fog/aws/requests/iam/delete_user.rb +40 -0
- data/lib/fog/aws/requests/iam/delete_user_policy.rb +42 -0
- data/lib/fog/aws/requests/iam/get_user.rb +44 -0
- data/lib/fog/aws/requests/iam/list_access_keys.rb +48 -0
- data/lib/fog/aws/requests/iam/list_group_policies.rb +47 -0
- data/lib/fog/aws/requests/iam/list_groups.rb +50 -0
- data/lib/fog/aws/requests/iam/list_user_policies.rb +47 -0
- data/lib/fog/aws/requests/iam/list_users.rb +50 -0
- data/lib/fog/aws/requests/iam/put_group_policy.rb +44 -0
- data/lib/fog/aws/requests/iam/put_user_policy.rb +44 -0
- data/lib/fog/aws/requests/iam/remove_user_from_group.rb +42 -0
- data/lib/fog/aws/requests/iam/update_access_key.rb +44 -0
- data/lib/fog/aws/requests/ses/delete_verified_email_address.rb +38 -0
- data/lib/fog/aws/requests/ses/get_send_quota.rb +40 -0
- data/lib/fog/aws/requests/ses/get_send_statistics.rb +43 -0
- data/lib/fog/aws/requests/ses/list_verified_email_addresses.rb +38 -0
- data/lib/fog/aws/requests/ses/send_email.rb +58 -0
- data/lib/fog/aws/requests/ses/send_raw_email.rb +44 -0
- data/lib/fog/aws/requests/ses/verify_email_address.rb +38 -0
- data/lib/fog/aws/requests/simpledb/batch_put_attributes.rb +64 -0
- data/lib/fog/aws/requests/simpledb/create_domain.rb +44 -0
- data/lib/fog/aws/requests/simpledb/delete_attributes.rb +63 -0
- data/lib/fog/aws/requests/simpledb/delete_domain.rb +45 -0
- data/lib/fog/aws/requests/simpledb/domain_metadata.rb +76 -0
- data/lib/fog/aws/requests/simpledb/get_attributes.rb +72 -0
- data/lib/fog/aws/requests/simpledb/list_domains.rb +59 -0
- data/lib/fog/aws/requests/simpledb/put_attributes.rb +78 -0
- data/lib/fog/aws/requests/simpledb/select.rb +43 -0
- data/lib/fog/aws/ses.rb +99 -0
- data/lib/fog/aws/simpledb.rb +172 -0
- data/lib/fog/bin/aws.rb +71 -0
- data/lib/fog/bin/bluebox.rb +36 -0
- data/lib/fog/bin/brightbox.rb +34 -0
- data/lib/fog/bin/go_grid.rb +36 -0
- data/lib/fog/bin/google.rb +30 -0
- data/lib/fog/bin/linode.rb +40 -0
- data/lib/fog/bin/local.rb +36 -0
- data/lib/fog/bin/new_servers.rb +36 -0
- data/lib/fog/bin/rackspace.rb +52 -0
- data/lib/fog/bin/slicehost.rb +40 -0
- data/lib/fog/bin/terremark.rb +36 -0
- data/lib/fog/bin/terremark_ecloud.rb +28 -0
- data/lib/fog/bin/vcloud.rb +59 -0
- data/lib/fog/bin/zerigo.rb +30 -0
- data/lib/fog/bin.rb +89 -0
- data/lib/fog/cdn/aws.rb +115 -0
- data/lib/fog/cdn/parsers/aws/distribution.rb +59 -0
- data/lib/fog/cdn/parsers/aws/get_distribution_list.rb +61 -0
- data/lib/fog/cdn/parsers/aws/post_invalidation.rb +28 -0
- data/lib/fog/cdn/rackspace.rb +97 -0
- data/lib/fog/cdn/requests/aws/delete_distribution.rb +36 -0
- data/lib/fog/cdn/requests/aws/get_distribution.rb +65 -0
- data/lib/fog/cdn/requests/aws/get_distribution_list.rb +67 -0
- data/lib/fog/cdn/requests/aws/post_distribution.rb +99 -0
- data/lib/fog/cdn/requests/aws/post_invalidation.rb +59 -0
- data/lib/fog/cdn/requests/aws/put_distribution_config.rb +102 -0
- data/lib/fog/cdn/requests/rackspace/get_containers.rb +39 -0
- data/lib/fog/cdn/requests/rackspace/head_container.rb +41 -0
- data/lib/fog/cdn/requests/rackspace/put_container.rb +38 -0
- data/lib/fog/cdn.rb +19 -0
- data/lib/fog/compute/aws.rb +273 -0
- data/lib/fog/compute/bluebox.rb +104 -0
- data/lib/fog/compute/brightbox.rb +159 -0
- data/lib/fog/compute/go_grid.rb +118 -0
- data/lib/fog/compute/linode.rb +100 -0
- data/lib/fog/compute/models/aws/address.rb +69 -0
- data/lib/fog/compute/models/aws/addresses.rb +100 -0
- data/lib/fog/compute/models/aws/flavor.rb +21 -0
- data/lib/fog/compute/models/aws/flavors.rb +166 -0
- data/lib/fog/compute/models/aws/image.rb +43 -0
- data/lib/fog/compute/models/aws/images.rb +62 -0
- data/lib/fog/compute/models/aws/key_pair.rb +44 -0
- data/lib/fog/compute/models/aws/key_pairs.rb +88 -0
- data/lib/fog/compute/models/aws/security_group.rb +205 -0
- data/lib/fog/compute/models/aws/security_groups.rb +95 -0
- data/lib/fog/compute/models/aws/server.rb +212 -0
- data/lib/fog/compute/models/aws/servers.rb +158 -0
- data/lib/fog/compute/models/aws/snapshot.rb +58 -0
- data/lib/fog/compute/models/aws/snapshots.rb +52 -0
- data/lib/fog/compute/models/aws/tag.rb +36 -0
- data/lib/fog/compute/models/aws/tags.rb +34 -0
- data/lib/fog/compute/models/aws/volume.rb +109 -0
- data/lib/fog/compute/models/aws/volumes.rb +121 -0
- data/lib/fog/compute/models/bluebox/flavor.rb +45 -0
- data/lib/fog/compute/models/bluebox/flavors.rb +28 -0
- data/lib/fog/compute/models/bluebox/image.rb +19 -0
- data/lib/fog/compute/models/bluebox/images.rb +28 -0
- data/lib/fog/compute/models/bluebox/server.rb +126 -0
- data/lib/fog/compute/models/bluebox/servers.rb +36 -0
- data/lib/fog/compute/models/brightbox/account.rb +51 -0
- data/lib/fog/compute/models/brightbox/cloud_ip.rb +47 -0
- data/lib/fog/compute/models/brightbox/cloud_ips.rb +34 -0
- data/lib/fog/compute/models/brightbox/flavor.rb +33 -0
- data/lib/fog/compute/models/brightbox/flavors.rb +28 -0
- data/lib/fog/compute/models/brightbox/image.rb +56 -0
- data/lib/fog/compute/models/brightbox/images.rb +28 -0
- data/lib/fog/compute/models/brightbox/load_balancer.rb +50 -0
- data/lib/fog/compute/models/brightbox/load_balancers.rb +28 -0
- data/lib/fog/compute/models/brightbox/server.rb +94 -0
- data/lib/fog/compute/models/brightbox/servers.rb +29 -0
- data/lib/fog/compute/models/brightbox/user.rb +39 -0
- data/lib/fog/compute/models/brightbox/users.rb +29 -0
- data/lib/fog/compute/models/brightbox/zone.rb +21 -0
- data/lib/fog/compute/models/brightbox/zones.rb +29 -0
- data/lib/fog/compute/models/go_grid/image.rb +60 -0
- data/lib/fog/compute/models/go_grid/images.rb +33 -0
- data/lib/fog/compute/models/go_grid/server.rb +56 -0
- data/lib/fog/compute/models/go_grid/servers.rb +35 -0
- data/lib/fog/compute/models/rackspace/flavor.rb +43 -0
- data/lib/fog/compute/models/rackspace/flavors.rb +28 -0
- data/lib/fog/compute/models/rackspace/image.rb +48 -0
- data/lib/fog/compute/models/rackspace/images.rb +33 -0
- data/lib/fog/compute/models/rackspace/server.rb +129 -0
- data/lib/fog/compute/models/rackspace/servers.rb +36 -0
- data/lib/fog/compute/models/slicehost/flavor.rb +45 -0
- data/lib/fog/compute/models/slicehost/flavors.rb +28 -0
- data/lib/fog/compute/models/slicehost/image.rb +17 -0
- data/lib/fog/compute/models/slicehost/images.rb +27 -0
- data/lib/fog/compute/models/slicehost/server.rb +112 -0
- data/lib/fog/compute/models/slicehost/servers.rb +38 -0
- data/lib/fog/compute/new_servers.rb +103 -0
- data/lib/fog/compute/parsers/aws/allocate_address.rb +19 -0
- data/lib/fog/compute/parsers/aws/attach_volume.rb +22 -0
- data/lib/fog/compute/parsers/aws/basic.rb +25 -0
- data/lib/fog/compute/parsers/aws/create_image.rb +20 -0
- data/lib/fog/compute/parsers/aws/create_key_pair.rb +20 -0
- data/lib/fog/compute/parsers/aws/create_snapshot.rb +26 -0
- data/lib/fog/compute/parsers/aws/create_volume.rb +24 -0
- data/lib/fog/compute/parsers/aws/deregister_image.rb +20 -0
- data/lib/fog/compute/parsers/aws/describe_addresses.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_availability_zones.rb +32 -0
- data/lib/fog/compute/parsers/aws/describe_images.rb +72 -0
- data/lib/fog/compute/parsers/aws/describe_instances.rb +119 -0
- data/lib/fog/compute/parsers/aws/describe_key_pairs.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_regions.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_reserved_instances.rb +36 -0
- data/lib/fog/compute/parsers/aws/describe_security_groups.rb +76 -0
- data/lib/fog/compute/parsers/aws/describe_snapshots.rb +54 -0
- data/lib/fog/compute/parsers/aws/describe_tags.rb +30 -0
- data/lib/fog/compute/parsers/aws/describe_volumes.rb +73 -0
- data/lib/fog/compute/parsers/aws/detach_volume.rb +22 -0
- data/lib/fog/compute/parsers/aws/get_console_output.rb +32 -0
- data/lib/fog/compute/parsers/aws/import_key_pair.rb +20 -0
- data/lib/fog/compute/parsers/aws/register_image.rb +20 -0
- data/lib/fog/compute/parsers/aws/run_instances.rb +89 -0
- data/lib/fog/compute/parsers/aws/start_stop_instances.rb +41 -0
- data/lib/fog/compute/parsers/aws/terminate_instances.rb +55 -0
- data/lib/fog/compute/parsers/slicehost/create_slice.rb +31 -0
- data/lib/fog/compute/parsers/slicehost/get_backups.rb +32 -0
- data/lib/fog/compute/parsers/slicehost/get_flavor.rb +26 -0
- data/lib/fog/compute/parsers/slicehost/get_flavors.rb +30 -0
- data/lib/fog/compute/parsers/slicehost/get_image.rb +26 -0
- data/lib/fog/compute/parsers/slicehost/get_images.rb +30 -0
- data/lib/fog/compute/parsers/slicehost/get_slice.rb +31 -0
- data/lib/fog/compute/parsers/slicehost/get_slices.rb +35 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_catalog.rb +36 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_catalog_item.rb +43 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_ip_addresses.rb +27 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_network.rb +59 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_organization.rb +35 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_vdc.rb +110 -0
- data/lib/fog/compute/parsers/terremark_ecloud/get_versions.rb +28 -0
- data/lib/fog/compute/parsers/terremark_ecloud/login.rb +27 -0
- data/lib/fog/compute/rackspace.rb +144 -0
- data/lib/fog/compute/requests/aws/allocate_address.rb +51 -0
- data/lib/fog/compute/requests/aws/associate_address.rb +57 -0
- data/lib/fog/compute/requests/aws/attach_volume.rb +81 -0
- data/lib/fog/compute/requests/aws/authorize_security_group_ingress.rb +86 -0
- data/lib/fog/compute/requests/aws/create_image.rb +64 -0
- data/lib/fog/compute/requests/aws/create_key_pair.rb +54 -0
- data/lib/fog/compute/requests/aws/create_security_group.rb +53 -0
- data/lib/fog/compute/requests/aws/create_snapshot.rb +71 -0
- data/lib/fog/compute/requests/aws/create_tags.rb +78 -0
- data/lib/fog/compute/requests/aws/create_volume.rb +74 -0
- data/lib/fog/compute/requests/aws/delete_key_pair.rb +43 -0
- data/lib/fog/compute/requests/aws/delete_security_group.rb +45 -0
- data/lib/fog/compute/requests/aws/delete_snapshot.rb +46 -0
- data/lib/fog/compute/requests/aws/delete_tags.rb +45 -0
- data/lib/fog/compute/requests/aws/delete_volume.rb +52 -0
- data/lib/fog/compute/requests/aws/deregister_image.rb +51 -0
- data/lib/fog/compute/requests/aws/describe_addresses.rb +64 -0
- data/lib/fog/compute/requests/aws/describe_availability_zones.rb +70 -0
- data/lib/fog/compute/requests/aws/describe_images.rb +112 -0
- data/lib/fog/compute/requests/aws/describe_instances.rb +201 -0
- data/lib/fog/compute/requests/aws/describe_key_pairs.rb +66 -0
- data/lib/fog/compute/requests/aws/describe_regions.rb +66 -0
- data/lib/fog/compute/requests/aws/describe_reserved_instances.rb +52 -0
- data/lib/fog/compute/requests/aws/describe_security_groups.rb +95 -0
- data/lib/fog/compute/requests/aws/describe_snapshots.rb +120 -0
- data/lib/fog/compute/requests/aws/describe_tags.rb +42 -0
- data/lib/fog/compute/requests/aws/describe_volumes.rb +118 -0
- data/lib/fog/compute/requests/aws/detach_volume.rb +58 -0
- data/lib/fog/compute/requests/aws/disassociate_address.rb +52 -0
- data/lib/fog/compute/requests/aws/get_console_output.rb +52 -0
- data/lib/fog/compute/requests/aws/import_key_pair.rb +54 -0
- data/lib/fog/compute/requests/aws/modify_image_attributes.rb +39 -0
- data/lib/fog/compute/requests/aws/modify_snapshot_attribute.rb +38 -0
- data/lib/fog/compute/requests/aws/reboot_instances.rb +50 -0
- data/lib/fog/compute/requests/aws/register_image.rb +89 -0
- data/lib/fog/compute/requests/aws/release_address.rb +43 -0
- data/lib/fog/compute/requests/aws/revoke_security_group_ingress.rb +74 -0
- data/lib/fog/compute/requests/aws/run_instances.rb +167 -0
- data/lib/fog/compute/requests/aws/start_instances.rb +38 -0
- data/lib/fog/compute/requests/aws/stop_instances.rb +38 -0
- data/lib/fog/compute/requests/aws/terminate_instances.rb +94 -0
- data/lib/fog/compute/requests/bluebox/create_block.rb +41 -0
- data/lib/fog/compute/requests/bluebox/destroy_block.rb +34 -0
- data/lib/fog/compute/requests/bluebox/get_block.rb +34 -0
- data/lib/fog/compute/requests/bluebox/get_blocks.rb +36 -0
- data/lib/fog/compute/requests/bluebox/get_product.rb +34 -0
- data/lib/fog/compute/requests/bluebox/get_products.rb +33 -0
- data/lib/fog/compute/requests/bluebox/get_template.rb +34 -0
- data/lib/fog/compute/requests/bluebox/get_templates.rb +34 -0
- data/lib/fog/compute/requests/bluebox/reboot_block.rb +35 -0
- data/lib/fog/compute/requests/brightbox/add_nodes_load_balancer.rb +28 -0
- data/lib/fog/compute/requests/brightbox/create_api_client.rb +27 -0
- data/lib/fog/compute/requests/brightbox/create_cloud_ip.rb +27 -0
- data/lib/fog/compute/requests/brightbox/create_image.rb +27 -0
- data/lib/fog/compute/requests/brightbox/create_load_balancer.rb +27 -0
- data/lib/fog/compute/requests/brightbox/create_server.rb +27 -0
- data/lib/fog/compute/requests/brightbox/destroy_api_client.rb +28 -0
- data/lib/fog/compute/requests/brightbox/destroy_cloud_ip.rb +28 -0
- data/lib/fog/compute/requests/brightbox/destroy_image.rb +28 -0
- data/lib/fog/compute/requests/brightbox/destroy_load_balancer.rb +28 -0
- data/lib/fog/compute/requests/brightbox/destroy_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_account.rb +27 -0
- data/lib/fog/compute/requests/brightbox/get_api_client.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_cloud_ip.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_image.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_interface.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_load_balancer.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_server_type.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_user.rb +28 -0
- data/lib/fog/compute/requests/brightbox/get_zone.rb +28 -0
- data/lib/fog/compute/requests/brightbox/list_api_clients.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_cloud_ips.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_images.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_load_balancers.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_server_types.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_servers.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_users.rb +27 -0
- data/lib/fog/compute/requests/brightbox/list_zones.rb +27 -0
- data/lib/fog/compute/requests/brightbox/map_cloud_ip.rb +28 -0
- data/lib/fog/compute/requests/brightbox/remove_nodes_load_balancer.rb +28 -0
- data/lib/fog/compute/requests/brightbox/reset_ftp_password_account.rb +27 -0
- data/lib/fog/compute/requests/brightbox/resize_server.rb +27 -0
- data/lib/fog/compute/requests/brightbox/shutdown_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/snapshot_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/start_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/stop_server.rb +28 -0
- data/lib/fog/compute/requests/brightbox/unmap_cloud_ip.rb +28 -0
- data/lib/fog/compute/requests/brightbox/update_account.rb +28 -0
- data/lib/fog/compute/requests/brightbox/update_api_client.rb +29 -0
- data/lib/fog/compute/requests/brightbox/update_image.rb +29 -0
- data/lib/fog/compute/requests/brightbox/update_load_balancer.rb +29 -0
- data/lib/fog/compute/requests/brightbox/update_server.rb +29 -0
- data/lib/fog/compute/requests/brightbox/update_user.rb +29 -0
- data/lib/fog/compute/requests/go_grid/common_lookup_list.rb +36 -0
- data/lib/fog/compute/requests/go_grid/grid_image_get.rb +41 -0
- data/lib/fog/compute/requests/go_grid/grid_image_list.rb +44 -0
- data/lib/fog/compute/requests/go_grid/grid_ip_list.rb +38 -0
- data/lib/fog/compute/requests/go_grid/grid_loadbalancer_list.rb +36 -0
- data/lib/fog/compute/requests/go_grid/grid_server_add.rb +44 -0
- data/lib/fog/compute/requests/go_grid/grid_server_delete.rb +33 -0
- data/lib/fog/compute/requests/go_grid/grid_server_get.rb +33 -0
- data/lib/fog/compute/requests/go_grid/grid_server_list.rb +38 -0
- data/lib/fog/compute/requests/go_grid/grid_server_power.rb +34 -0
- data/lib/fog/compute/requests/linode/avail_datacenters.rb +31 -0
- data/lib/fog/compute/requests/linode/avail_distributions.rb +38 -0
- data/lib/fog/compute/requests/linode/avail_kernels.rb +36 -0
- data/lib/fog/compute/requests/linode/avail_linodeplans.rb +35 -0
- data/lib/fog/compute/requests/linode/avail_stackscripts.rb +37 -0
- data/lib/fog/compute/requests/linode/linode_create.rb +41 -0
- data/lib/fog/compute/requests/linode/linode_delete.rb +36 -0
- data/lib/fog/compute/requests/linode/linode_list.rb +38 -0
- data/lib/fog/compute/requests/linode/linode_reboot.rb +36 -0
- data/lib/fog/compute/requests/new_servers/add_server.rb +41 -0
- data/lib/fog/compute/requests/new_servers/cancel_server.rb +38 -0
- data/lib/fog/compute/requests/new_servers/get_server.rb +44 -0
- data/lib/fog/compute/requests/new_servers/list_images.rb +35 -0
- data/lib/fog/compute/requests/new_servers/list_plans.rb +38 -0
- data/lib/fog/compute/requests/new_servers/list_servers.rb +44 -0
- data/lib/fog/compute/requests/new_servers/reboot_server.rb +32 -0
- data/lib/fog/compute/requests/rackspace/confirm_resized_server.rb +34 -0
- data/lib/fog/compute/requests/rackspace/create_image.rb +62 -0
- data/lib/fog/compute/requests/rackspace/create_server.rb +94 -0
- data/lib/fog/compute/requests/rackspace/delete_image.rb +45 -0
- data/lib/fog/compute/requests/rackspace/delete_server.rb +43 -0
- data/lib/fog/compute/requests/rackspace/get_flavor_details.rb +52 -0
- data/lib/fog/compute/requests/rackspace/get_image_details.rb +35 -0
- data/lib/fog/compute/requests/rackspace/get_server_details.rb +52 -0
- data/lib/fog/compute/requests/rackspace/list_addresses.rb +43 -0
- data/lib/fog/compute/requests/rackspace/list_flavors.rb +45 -0
- data/lib/fog/compute/requests/rackspace/list_flavors_detail.rb +47 -0
- data/lib/fog/compute/requests/rackspace/list_images.rb +40 -0
- data/lib/fog/compute/requests/rackspace/list_images_detail.rb +49 -0
- data/lib/fog/compute/requests/rackspace/list_private_addresses.rb +41 -0
- data/lib/fog/compute/requests/rackspace/list_public_addresses.rb +41 -0
- data/lib/fog/compute/requests/rackspace/list_servers.rb +41 -0
- data/lib/fog/compute/requests/rackspace/list_servers_detail.rb +56 -0
- data/lib/fog/compute/requests/rackspace/reboot_server.rb +30 -0
- data/lib/fog/compute/requests/rackspace/resize_server.rb +39 -0
- data/lib/fog/compute/requests/rackspace/revert_resized_server.rb +35 -0
- data/lib/fog/compute/requests/rackspace/server_action.rb +33 -0
- data/lib/fog/compute/requests/rackspace/update_server.rb +45 -0
- data/lib/fog/compute/requests/slicehost/create_slice.rb +49 -0
- data/lib/fog/compute/requests/slicehost/delete_slice.rb +31 -0
- data/lib/fog/compute/requests/slicehost/get_backups.rb +37 -0
- data/lib/fog/compute/requests/slicehost/get_flavor.rb +40 -0
- data/lib/fog/compute/requests/slicehost/get_flavors.rb +37 -0
- data/lib/fog/compute/requests/slicehost/get_image.rb +38 -0
- data/lib/fog/compute/requests/slicehost/get_images.rb +35 -0
- data/lib/fog/compute/requests/slicehost/get_slice.rb +46 -0
- data/lib/fog/compute/requests/slicehost/get_slices.rb +43 -0
- data/lib/fog/compute/requests/slicehost/reboot_slice.rb +44 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_catalog.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_catalog_item.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_ip_addresses.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_network.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_organization.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_vdc.rb +27 -0
- data/lib/fog/compute/requests/terremark_ecloud/get_versions.rb +32 -0
- data/lib/fog/compute/slicehost.rb +107 -0
- data/lib/fog/compute/terremark_ecloud.rb +109 -0
- data/lib/fog/compute.rb +40 -0
- data/lib/fog/core/attributes.rb +178 -0
- data/lib/fog/core/collection.rb +126 -0
- data/lib/fog/core/connection.rb +35 -0
- data/lib/fog/core/credentials.rb +88 -0
- data/lib/fog/core/deprecation.rb +23 -0
- data/lib/fog/core/errors.rb +20 -0
- data/lib/fog/core/hmac.rb +48 -0
- data/lib/fog/core/mock.rb +68 -0
- data/lib/fog/core/model.rb +56 -0
- data/lib/fog/core/parser.rb +97 -0
- data/lib/fog/core/provider.rb +14 -0
- data/lib/fog/core/service.rb +158 -0
- data/lib/fog/core/ssh.rb +120 -0
- data/lib/fog/core/time.rb +21 -0
- data/lib/fog/core/wait_for.rb +17 -0
- data/lib/fog/core.rb +31 -0
- data/lib/fog/dns/aws.rb +120 -0
- data/lib/fog/dns/linode.rb +99 -0
- data/lib/fog/dns/models/aws/record.rb +64 -0
- data/lib/fog/dns/models/aws/records.rb +49 -0
- data/lib/fog/dns/models/aws/zone.rb +53 -0
- data/lib/fog/dns/models/aws/zones.rb +33 -0
- data/lib/fog/dns/models/linode/record.rb +69 -0
- data/lib/fog/dns/models/linode/records.rb +37 -0
- data/lib/fog/dns/models/linode/zone.rb +84 -0
- data/lib/fog/dns/models/linode/zones.rb +29 -0
- data/lib/fog/dns/models/slicehost/record.rb +66 -0
- data/lib/fog/dns/models/slicehost/records.rb +36 -0
- data/lib/fog/dns/models/slicehost/zone.rb +69 -0
- data/lib/fog/dns/models/slicehost/zones.rb +28 -0
- data/lib/fog/dns/models/zerigo/record.rb +65 -0
- data/lib/fog/dns/models/zerigo/records.rb +41 -0
- data/lib/fog/dns/models/zerigo/zone.rb +88 -0
- data/lib/fog/dns/models/zerigo/zones.rb +30 -0
- data/lib/fog/dns/parsers/aws/change_resource_record_sets.rb +26 -0
- data/lib/fog/dns/parsers/aws/create_hosted_zone.rb +55 -0
- data/lib/fog/dns/parsers/aws/delete_hosted_zone.rb +25 -0
- data/lib/fog/dns/parsers/aws/get_change.rb +26 -0
- data/lib/fog/dns/parsers/aws/get_hosted_zone.rb +43 -0
- data/lib/fog/dns/parsers/aws/list_hosted_zones.rb +37 -0
- data/lib/fog/dns/parsers/aws/list_resource_record_sets.rb +46 -0
- data/lib/fog/dns/parsers/slicehost/create_record.rb +26 -0
- data/lib/fog/dns/parsers/slicehost/create_zone.rb +26 -0
- data/lib/fog/dns/parsers/slicehost/get_record.rb +26 -0
- data/lib/fog/dns/parsers/slicehost/get_records.rb +30 -0
- data/lib/fog/dns/parsers/slicehost/get_zone.rb +26 -0
- data/lib/fog/dns/parsers/slicehost/get_zones.rb +30 -0
- data/lib/fog/dns/parsers/zerigo/count_hosts.rb +24 -0
- data/lib/fog/dns/parsers/zerigo/count_zones.rb +24 -0
- data/lib/fog/dns/parsers/zerigo/create_host.rb +26 -0
- data/lib/fog/dns/parsers/zerigo/create_zone.rb +26 -0
- data/lib/fog/dns/parsers/zerigo/find_hosts.rb +30 -0
- data/lib/fog/dns/parsers/zerigo/get_host.rb +26 -0
- data/lib/fog/dns/parsers/zerigo/get_zone.rb +56 -0
- data/lib/fog/dns/parsers/zerigo/get_zone_stats.rb +26 -0
- data/lib/fog/dns/parsers/zerigo/list_hosts.rb +30 -0
- data/lib/fog/dns/parsers/zerigo/list_zones.rb +30 -0
- data/lib/fog/dns/requests/aws/change_resource_record_sets.rb +90 -0
- data/lib/fog/dns/requests/aws/create_hosted_zone.rb +68 -0
- data/lib/fog/dns/requests/aws/delete_hosted_zone.rb +48 -0
- data/lib/fog/dns/requests/aws/get_change.rb +47 -0
- data/lib/fog/dns/requests/aws/get_hosted_zone.rb +51 -0
- data/lib/fog/dns/requests/aws/list_hosted_zones.rb +63 -0
- data/lib/fog/dns/requests/aws/list_resource_record_sets.rb +68 -0
- data/lib/fog/dns/requests/linode/domain_create.rb +51 -0
- data/lib/fog/dns/requests/linode/domain_delete.rb +35 -0
- data/lib/fog/dns/requests/linode/domain_list.rb +50 -0
- data/lib/fog/dns/requests/linode/domain_resource_create.rb +52 -0
- data/lib/fog/dns/requests/linode/domain_resource_delete.rb +36 -0
- data/lib/fog/dns/requests/linode/domain_resource_list.rb +51 -0
- data/lib/fog/dns/requests/linode/domain_resource_update.rb +54 -0
- data/lib/fog/dns/requests/linode/domain_update.rb +48 -0
- data/lib/fog/dns/requests/slicehost/create_record.rb +60 -0
- data/lib/fog/dns/requests/slicehost/create_zone.rb +54 -0
- data/lib/fog/dns/requests/slicehost/delete_record.rb +31 -0
- data/lib/fog/dns/requests/slicehost/delete_zone.rb +31 -0
- data/lib/fog/dns/requests/slicehost/get_record.rb +40 -0
- data/lib/fog/dns/requests/slicehost/get_records.rb +41 -0
- data/lib/fog/dns/requests/slicehost/get_zone.rb +40 -0
- data/lib/fog/dns/requests/slicehost/get_zones.rb +38 -0
- data/lib/fog/dns/requests/zerigo/count_hosts.rb +36 -0
- data/lib/fog/dns/requests/zerigo/count_zones.rb +36 -0
- data/lib/fog/dns/requests/zerigo/create_host.rb +70 -0
- data/lib/fog/dns/requests/zerigo/create_zone.rb +97 -0
- data/lib/fog/dns/requests/zerigo/delete_host.rb +32 -0
- data/lib/fog/dns/requests/zerigo/delete_zone.rb +33 -0
- data/lib/fog/dns/requests/zerigo/find_hosts.rb +63 -0
- data/lib/fog/dns/requests/zerigo/get_host.rb +47 -0
- data/lib/fog/dns/requests/zerigo/get_zone.rb +57 -0
- data/lib/fog/dns/requests/zerigo/get_zone_stats.rb +44 -0
- data/lib/fog/dns/requests/zerigo/list_hosts.rb +48 -0
- data/lib/fog/dns/requests/zerigo/list_zones.rb +53 -0
- data/lib/fog/dns/requests/zerigo/update_host.rb +60 -0
- data/lib/fog/dns/requests/zerigo/update_zone.rb +78 -0
- data/lib/fog/dns/slicehost.rb +103 -0
- data/lib/fog/dns/zerigo.rb +113 -0
- data/lib/fog/dns.rb +25 -0
- data/lib/fog/providers/aws.rb +181 -0
- data/lib/fog/providers/bluebox.rb +19 -0
- data/lib/fog/providers/brightbox.rb +9 -0
- data/lib/fog/providers/go_grid.rb +19 -0
- data/lib/fog/providers/google.rb +26 -0
- data/lib/fog/providers/linode.rb +21 -0
- data/lib/fog/providers/local.rb +19 -0
- data/lib/fog/providers/new_servers.rb +22 -0
- data/lib/fog/providers/rackspace.rb +35 -0
- data/lib/fog/providers/slicehost.rb +23 -0
- data/lib/fog/providers/terremark_ecloud.rb +17 -0
- data/lib/fog/providers/zerigo.rb +14 -0
- data/lib/fog/providers.rb +12 -0
- data/lib/fog/storage/aws.rb +362 -0
- data/lib/fog/storage/google.rb +277 -0
- data/lib/fog/storage/local.rb +75 -0
- data/lib/fog/storage/models/aws/directories.rb +43 -0
- data/lib/fog/storage/models/aws/directory.rb +103 -0
- data/lib/fog/storage/models/aws/file.rb +147 -0
- data/lib/fog/storage/models/aws/files.rb +79 -0
- data/lib/fog/storage/models/google/directories.rb +43 -0
- data/lib/fog/storage/models/google/directory.rb +81 -0
- data/lib/fog/storage/models/google/file.rb +148 -0
- data/lib/fog/storage/models/google/files.rb +79 -0
- data/lib/fog/storage/models/local/directories.rb +33 -0
- data/lib/fog/storage/models/local/directory.rb +60 -0
- data/lib/fog/storage/models/local/file.rb +75 -0
- data/lib/fog/storage/models/local/files.rb +84 -0
- data/lib/fog/storage/models/rackspace/directories.rb +39 -0
- data/lib/fog/storage/models/rackspace/directory.rb +66 -0
- data/lib/fog/storage/models/rackspace/file.rb +80 -0
- data/lib/fog/storage/models/rackspace/files.rb +75 -0
- data/lib/fog/storage/parsers/aws/access_control_list.rb +46 -0
- data/lib/fog/storage/parsers/aws/complete_multipart_upload.rb +24 -0
- data/lib/fog/storage/parsers/aws/copy_object.rb +22 -0
- data/lib/fog/storage/parsers/aws/get_bucket.rb +62 -0
- data/lib/fog/storage/parsers/aws/get_bucket_location.rb +20 -0
- data/lib/fog/storage/parsers/aws/get_bucket_logging.rb +40 -0
- data/lib/fog/storage/parsers/aws/get_bucket_object_versions.rb +88 -0
- data/lib/fog/storage/parsers/aws/get_bucket_versioning.rb +24 -0
- data/lib/fog/storage/parsers/aws/get_request_payment.rb +20 -0
- data/lib/fog/storage/parsers/aws/get_service.rb +32 -0
- data/lib/fog/storage/parsers/aws/initiate_multipart_upload.rb +24 -0
- data/lib/fog/storage/parsers/aws/list_multipart_uploads.rb +56 -0
- data/lib/fog/storage/parsers/aws/list_parts.rb +40 -0
- data/lib/fog/storage/parsers/google/access_control_list.rb +48 -0
- data/lib/fog/storage/parsers/google/copy_object.rb +22 -0
- data/lib/fog/storage/parsers/google/get_bucket.rb +62 -0
- data/lib/fog/storage/parsers/google/get_bucket_logging.rb +40 -0
- data/lib/fog/storage/parsers/google/get_bucket_object_versions.rb +88 -0
- data/lib/fog/storage/parsers/google/get_bucket_versioning.rb +24 -0
- data/lib/fog/storage/parsers/google/get_request_payment.rb +20 -0
- data/lib/fog/storage/parsers/google/get_service.rb +32 -0
- data/lib/fog/storage/rackspace.rb +164 -0
- data/lib/fog/storage/requests/aws/abort_multipart_upload.rb +38 -0
- data/lib/fog/storage/requests/aws/complete_multipart_upload.rb +60 -0
- data/lib/fog/storage/requests/aws/copy_object.rb +75 -0
- data/lib/fog/storage/requests/aws/delete_bucket.rb +50 -0
- data/lib/fog/storage/requests/aws/delete_object.rb +49 -0
- data/lib/fog/storage/requests/aws/get_bucket.rb +111 -0
- data/lib/fog/storage/requests/aws/get_bucket_acl.rb +66 -0
- data/lib/fog/storage/requests/aws/get_bucket_location.rb +52 -0
- data/lib/fog/storage/requests/aws/get_bucket_logging.rb +58 -0
- data/lib/fog/storage/requests/aws/get_bucket_object_versions.rb +83 -0
- data/lib/fog/storage/requests/aws/get_bucket_versioning.rb +48 -0
- data/lib/fog/storage/requests/aws/get_object.rb +107 -0
- data/lib/fog/storage/requests/aws/get_object_acl.rb +77 -0
- data/lib/fog/storage/requests/aws/get_object_torrent.rb +58 -0
- data/lib/fog/storage/requests/aws/get_object_url.rb +57 -0
- data/lib/fog/storage/requests/aws/get_request_payment.rb +52 -0
- data/lib/fog/storage/requests/aws/get_service.rb +57 -0
- data/lib/fog/storage/requests/aws/head_object.rb +68 -0
- data/lib/fog/storage/requests/aws/initiate_multipart_upload.rb +55 -0
- data/lib/fog/storage/requests/aws/list_multipart_uploads.rb +68 -0
- data/lib/fog/storage/requests/aws/list_parts.rb +67 -0
- data/lib/fog/storage/requests/aws/post_object_hidden_fields.rb +50 -0
- data/lib/fog/storage/requests/aws/put_bucket.rb +77 -0
- data/lib/fog/storage/requests/aws/put_bucket_acl.rb +84 -0
- data/lib/fog/storage/requests/aws/put_bucket_logging.rb +91 -0
- data/lib/fog/storage/requests/aws/put_bucket_versioning.rb +44 -0
- data/lib/fog/storage/requests/aws/put_object.rb +91 -0
- data/lib/fog/storage/requests/aws/put_object_acl.rb +93 -0
- data/lib/fog/storage/requests/aws/put_object_url.rb +57 -0
- data/lib/fog/storage/requests/aws/put_request_payment.rb +51 -0
- data/lib/fog/storage/requests/aws/sync_clock.rb +28 -0
- data/lib/fog/storage/requests/aws/upload_part.rb +51 -0
- data/lib/fog/storage/requests/google/copy_object.rb +72 -0
- data/lib/fog/storage/requests/google/delete_bucket.rb +46 -0
- data/lib/fog/storage/requests/google/delete_object.rb +50 -0
- data/lib/fog/storage/requests/google/get_bucket.rb +111 -0
- data/lib/fog/storage/requests/google/get_bucket_acl.rb +63 -0
- data/lib/fog/storage/requests/google/get_object.rb +104 -0
- data/lib/fog/storage/requests/google/get_object_acl.rb +74 -0
- data/lib/fog/storage/requests/google/get_object_torrent.rb +55 -0
- data/lib/fog/storage/requests/google/get_object_url.rb +54 -0
- data/lib/fog/storage/requests/google/get_service.rb +53 -0
- data/lib/fog/storage/requests/google/head_object.rb +64 -0
- data/lib/fog/storage/requests/google/put_bucket.rb +75 -0
- data/lib/fog/storage/requests/google/put_bucket_acl.rb +81 -0
- data/lib/fog/storage/requests/google/put_object.rb +86 -0
- data/lib/fog/storage/requests/google/put_object_url.rb +54 -0
- data/lib/fog/storage/requests/rackspace/delete_container.rb +31 -0
- data/lib/fog/storage/requests/rackspace/delete_object.rb +32 -0
- data/lib/fog/storage/requests/rackspace/get_container.rb +52 -0
- data/lib/fog/storage/requests/rackspace/get_containers.rb +41 -0
- data/lib/fog/storage/requests/rackspace/get_object.rb +33 -0
- data/lib/fog/storage/requests/rackspace/head_container.rb +37 -0
- data/lib/fog/storage/requests/rackspace/head_containers.rb +34 -0
- data/lib/fog/storage/requests/rackspace/head_object.rb +32 -0
- data/lib/fog/storage/requests/rackspace/put_container.rb +31 -0
- data/lib/fog/storage/requests/rackspace/put_object.rb +35 -0
- data/lib/fog/storage.rb +25 -0
- data/lib/fog/terremark/ecloud.rb +73 -0
- data/lib/fog/terremark/models/shared/address.rb +29 -0
- data/lib/fog/terremark/models/shared/addresses.rb +49 -0
- data/lib/fog/terremark/models/shared/network.rb +35 -0
- data/lib/fog/terremark/models/shared/networks.rb +52 -0
- data/lib/fog/terremark/models/shared/server.rb +110 -0
- data/lib/fog/terremark/models/shared/servers.rb +55 -0
- data/lib/fog/terremark/models/shared/task.rb +50 -0
- data/lib/fog/terremark/models/shared/tasks.rb +58 -0
- data/lib/fog/terremark/models/shared/vdc.rb +39 -0
- data/lib/fog/terremark/models/shared/vdcs.rb +52 -0
- data/lib/fog/terremark/parser.rb +19 -0
- data/lib/fog/terremark/parsers/shared/get_catalog.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_catalog_item.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_internet_services.rb +60 -0
- data/lib/fog/terremark/parsers/shared/get_network_ips.rb +29 -0
- data/lib/fog/terremark/parsers/shared/get_node_services.rb +36 -0
- data/lib/fog/terremark/parsers/shared/get_organization.rb +52 -0
- data/lib/fog/terremark/parsers/shared/get_organizations.rb +32 -0
- data/lib/fog/terremark/parsers/shared/get_public_ips.rb +30 -0
- data/lib/fog/terremark/parsers/shared/get_tasks_list.rb +52 -0
- data/lib/fog/terremark/parsers/shared/get_vapp_template.rb +46 -0
- data/lib/fog/terremark/parsers/shared/get_vdc.rb +123 -0
- data/lib/fog/terremark/parsers/shared/instantiate_vapp_template.rb +41 -0
- data/lib/fog/terremark/parsers/shared/internet_service.rb +65 -0
- data/lib/fog/terremark/parsers/shared/network.rb +51 -0
- data/lib/fog/terremark/parsers/shared/node_service.rb +32 -0
- data/lib/fog/terremark/parsers/shared/public_ip.rb +26 -0
- data/lib/fog/terremark/parsers/shared/task.rb +40 -0
- data/lib/fog/terremark/parsers/shared/vapp.rb +77 -0
- data/lib/fog/terremark/requests/shared/add_internet_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/add_node_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/create_internet_service.rb +63 -0
- data/lib/fog/terremark/requests/shared/delete_internet_service.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_node_service.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_public_ip.rb +30 -0
- data/lib/fog/terremark/requests/shared/delete_vapp.rb +30 -0
- data/lib/fog/terremark/requests/shared/deploy_vapp.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_catalog.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_catalog_item.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_internet_services.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_network.rb +73 -0
- data/lib/fog/terremark/requests/shared/get_network_ips.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_node_services.rb +38 -0
- data/lib/fog/terremark/requests/shared/get_organization.rb +86 -0
- data/lib/fog/terremark/requests/shared/get_organizations.rb +49 -0
- data/lib/fog/terremark/requests/shared/get_public_ip.rb +41 -0
- data/lib/fog/terremark/requests/shared/get_public_ips.rb +72 -0
- data/lib/fog/terremark/requests/shared/get_task.rb +47 -0
- data/lib/fog/terremark/requests/shared/get_tasks_list.rb +40 -0
- data/lib/fog/terremark/requests/shared/get_vapp.rb +50 -0
- data/lib/fog/terremark/requests/shared/get_vapp_template.rb +43 -0
- data/lib/fog/terremark/requests/shared/get_vdc.rb +125 -0
- data/lib/fog/terremark/requests/shared/instantiate_vapp_template.rb +79 -0
- data/lib/fog/terremark/requests/shared/power_off.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_on.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_reset.rb +43 -0
- data/lib/fog/terremark/requests/shared/power_shutdown.rb +32 -0
- data/lib/fog/terremark/shared.rb +289 -0
- data/lib/fog/terremark/vcloud.rb +117 -0
- data/lib/fog/terremark.rb +16 -0
- data/lib/fog/vcloud/collection.rb +30 -0
- data/lib/fog/vcloud/generators.rb +33 -0
- data/lib/fog/vcloud/mock_data_classes.rb +767 -0
- data/lib/fog/vcloud/model.rb +22 -0
- data/lib/fog/vcloud/models/vdc.rb +26 -0
- data/lib/fog/vcloud/models/vdcs.rb +35 -0
- data/lib/fog/vcloud/requests/get_network.rb +47 -0
- data/lib/fog/vcloud/requests/get_organization.rb +47 -0
- data/lib/fog/vcloud/requests/get_vdc.rb +82 -0
- data/lib/fog/vcloud/requests/get_versions.rb +34 -0
- data/lib/fog/vcloud/requests/login.rb +46 -0
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_service.rb +60 -0
- data/lib/fog/vcloud/terremark/ecloud/models/backup_internet_services.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/models/catalog.rb +31 -0
- data/lib/fog/vcloud/terremark/ecloud/models/catalog_item.rb +31 -0
- data/lib/fog/vcloud/terremark/ecloud/models/firewall_acl.rb +28 -0
- data/lib/fog/vcloud/terremark/ecloud/models/firewall_acls.rb +34 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_service.rb +99 -0
- data/lib/fog/vcloud/terremark/ecloud/models/internet_services.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/models/ip.rb +51 -0
- data/lib/fog/vcloud/terremark/ecloud/models/ips.rb +35 -0
- data/lib/fog/vcloud/terremark/ecloud/models/network.rb +77 -0
- data/lib/fog/vcloud/terremark/ecloud/models/networks.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/models/node.rb +47 -0
- data/lib/fog/vcloud/terremark/ecloud/models/nodes.rb +33 -0
- data/lib/fog/vcloud/terremark/ecloud/models/public_ip.rb +25 -0
- data/lib/fog/vcloud/terremark/ecloud/models/public_ips.rb +39 -0
- data/lib/fog/vcloud/terremark/ecloud/models/server.rb +211 -0
- data/lib/fog/vcloud/terremark/ecloud/models/servers.rb +57 -0
- data/lib/fog/vcloud/terremark/ecloud/models/task.rb +23 -0
- data/lib/fog/vcloud/terremark/ecloud/models/tasks.rb +33 -0
- data/lib/fog/vcloud/terremark/ecloud/models/vdc.rb +83 -0
- data/lib/fog/vcloud/terremark/ecloud/models/vdcs.rb +42 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_backup_internet_service.rb +111 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_internet_service.rb +140 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/add_node.rb +64 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/clone_vapp.rb +50 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_internet_service.rb +110 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network.rb +53 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_network_ip.rb +68 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_node.rb +58 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/configure_vapp.rb +147 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_internet_service.rb +25 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_node.rb +24 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/delete_vapp.rb +32 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_catalog.rb +46 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_catalog_item.rb +49 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_customization_options.rb +24 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_firewall_acl.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_firewall_acls.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_internet_services.rb +84 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network.rb +47 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_extensions.rb +35 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ip.rb +45 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_network_ips.rb +37 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_node.rb +42 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_nodes.rb +43 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_public_ip.rb +36 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_public_ips.rb +41 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_task.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_task_list.rb +19 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vapp.rb +101 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vapp_template.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/get_vdc.rb +87 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/instantiate_vapp_template.rb +144 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_off.rb +25 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_on.rb +25 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_reset.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud/requests/power_shutdown.rb +18 -0
- data/lib/fog/vcloud/terremark/ecloud.rb +187 -0
- data/lib/fog/vcloud/terremark/vcloud/requests/get_vdc.rb +57 -0
- data/lib/fog/vcloud/terremark/vcloud.rb +39 -0
- data/lib/fog/vcloud.rb +337 -0
- data/lib/fog.rb +19 -0
- data/spec/aws/models/compute/address_spec.rb +103 -0
- data/spec/aws/models/compute/addresses_spec.rb +70 -0
- data/spec/aws/models/compute/key_pair_spec.rb +86 -0
- data/spec/aws/models/compute/key_pairs_spec.rb +71 -0
- data/spec/aws/models/compute/security_group_spec.rb +88 -0
- data/spec/aws/models/compute/security_groups_spec.rb +71 -0
- data/spec/aws/models/compute/server_spec.rb +105 -0
- data/spec/aws/models/compute/snapshot_spec.rb +79 -0
- data/spec/aws/models/compute/snapshots_spec.rb +85 -0
- data/spec/aws/models/compute/volume_spec.rb +174 -0
- data/spec/aws/models/compute/volumes_spec.rb +71 -0
- data/spec/spec_helper.rb +13 -0
- data/spec/vcloud/bin_spec.rb +28 -0
- data/spec/vcloud/models/vdc_spec.rb +52 -0
- data/spec/vcloud/models/vdcs_spec.rb +1 -0
- data/spec/vcloud/requests/get_network_spec.rb +44 -0
- data/spec/vcloud/requests/get_organization_spec.rb +53 -0
- data/spec/vcloud/requests/get_vdc_spec.rb +63 -0
- data/spec/vcloud/requests/get_versions_spec.rb +54 -0
- data/spec/vcloud/requests/login_spec.rb +24 -0
- data/spec/vcloud/spec_helper.rb +398 -0
- data/spec/vcloud/terremark/ecloud/models/backup_internet_service_spec.rb +49 -0
- data/spec/vcloud/terremark/ecloud/models/backup_internet_services_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/internet_service_spec.rb +81 -0
- data/spec/vcloud/terremark/ecloud/models/internet_services_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/ip_spec.rb +33 -0
- data/spec/vcloud/terremark/ecloud/models/ips_spec.rb +28 -0
- data/spec/vcloud/terremark/ecloud/models/network_spec.rb +71 -0
- data/spec/vcloud/terremark/ecloud/models/networks_spec.rb +27 -0
- data/spec/vcloud/terremark/ecloud/models/node_spec.rb +38 -0
- data/spec/vcloud/terremark/ecloud/models/nodes_spec.rb +29 -0
- data/spec/vcloud/terremark/ecloud/models/public_ip_spec.rb +36 -0
- data/spec/vcloud/terremark/ecloud/models/public_ips_spec.rb +27 -0
- data/spec/vcloud/terremark/ecloud/models/server_spec.rb +62 -0
- data/spec/vcloud/terremark/ecloud/models/vdc_spec.rb +63 -0
- data/spec/vcloud/terremark/ecloud/models/vdcs_spec.rb +28 -0
- data/spec/vcloud/terremark/ecloud/requests/add_backup_internet_service_spec.rb +60 -0
- data/spec/vcloud/terremark/ecloud/requests/add_internet_service_spec.rb +65 -0
- data/spec/vcloud/terremark/ecloud/requests/add_node_spec.rb +56 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_internet_service_spec.rb +61 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_network_ip_spec.rb +55 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_node_spec.rb +52 -0
- data/spec/vcloud/terremark/ecloud/requests/configure_vapp_spec.rb +71 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_internet_service_spec.rb +34 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_node_spec.rb +30 -0
- data/spec/vcloud/terremark/ecloud/requests/delete_vapp_spec.rb +92 -0
- data/spec/vcloud/terremark/ecloud/requests/get_catalog_item_spec.rb +63 -0
- data/spec/vcloud/terremark/ecloud/requests/get_catalog_spec.rb +44 -0
- data/spec/vcloud/terremark/ecloud/requests/get_customization_options_spec.rb +39 -0
- data/spec/vcloud/terremark/ecloud/requests/get_internet_services_spec.rb +150 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ip_spec.rb +40 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_ips_spec.rb +59 -0
- data/spec/vcloud/terremark/ecloud/requests/get_network_spec.rb +49 -0
- data/spec/vcloud/terremark/ecloud/requests/get_node_spec.rb +41 -0
- data/spec/vcloud/terremark/ecloud/requests/get_nodes_spec.rb +58 -0
- data/spec/vcloud/terremark/ecloud/requests/get_public_ip_spec.rb +38 -0
- data/spec/vcloud/terremark/ecloud/requests/get_public_ips_spec.rb +52 -0
- data/spec/vcloud/terremark/ecloud/requests/get_vapp_spec.rb +126 -0
- data/spec/vcloud/terremark/ecloud/requests/get_vdc_spec.rb +113 -0
- data/spec/vcloud/terremark/ecloud/requests/instantiate_vapp_template_spec.rb +96 -0
- data/spec/vcloud/terremark/ecloud/requests/login_spec.rb +10 -0
- data/spec/vcloud/terremark/ecloud/requests/power_off_spec.rb +34 -0
- data/spec/vcloud/terremark/ecloud/requests/power_on_spec.rb +34 -0
- data/spec/vcloud/vcloud_spec.rb +18 -0
- data/tests/aws/requests/iam/access_key_tests.rb +60 -0
- data/tests/aws/requests/iam/group_policy_tests.rb +42 -0
- data/tests/aws/requests/iam/group_tests.rb +47 -0
- data/tests/aws/requests/iam/helper.rb +15 -0
- data/tests/aws/requests/iam/user_policy_tests.rb +42 -0
- data/tests/aws/requests/iam/user_tests.rb +65 -0
- data/tests/aws/requests/simpledb/attributes_tests.rb +75 -0
- data/tests/aws/requests/simpledb/domain_tests.rb +51 -0
- data/tests/aws/requests/simpledb/helper.rb +16 -0
- data/tests/compute/helper.rb +36 -0
- data/tests/compute/models/flavors_tests.rb +9 -0
- data/tests/compute/models/server_tests.rb +9 -0
- data/tests/compute/models/servers_tests.rb +9 -0
- data/tests/compute/requests/aws/address_tests.rb +76 -0
- data/tests/compute/requests/aws/availability_zone_tests.rb +25 -0
- data/tests/compute/requests/aws/helper.rb +20 -0
- data/tests/compute/requests/aws/image_tests.rb +37 -0
- data/tests/compute/requests/aws/instance_tests.rb +121 -0
- data/tests/compute/requests/aws/key_pair_tests.rb +63 -0
- data/tests/compute/requests/aws/region_tests.rb +23 -0
- data/tests/compute/requests/aws/security_group_tests.rb +124 -0
- data/tests/compute/requests/aws/snapshot_tests.rb +57 -0
- data/tests/compute/requests/aws/tag_tests.rb +49 -0
- data/tests/compute/requests/aws/volume_tests.rb +102 -0
- data/tests/compute/requests/bluebox/block_tests.rb +80 -0
- data/tests/compute/requests/bluebox/helper.rb +17 -0
- data/tests/compute/requests/bluebox/product_tests.rb +28 -0
- data/tests/compute/requests/bluebox/template_tests.rb +35 -0
- data/tests/compute/requests/brightbox/account_tests.rb +40 -0
- data/tests/compute/requests/brightbox/api_client_tests.rb +49 -0
- data/tests/compute/requests/brightbox/cloud_ip_tests.rb +71 -0
- data/tests/compute/requests/brightbox/helper.rb +418 -0
- data/tests/compute/requests/brightbox/image_tests.rb +57 -0
- data/tests/compute/requests/brightbox/interface_tests.rb +30 -0
- data/tests/compute/requests/brightbox/load_balancer_tests.rb +74 -0
- data/tests/compute/requests/brightbox/server_tests.rb +70 -0
- data/tests/compute/requests/brightbox/server_type_tests.rb +33 -0
- data/tests/compute/requests/brightbox/user_tests.rb +41 -0
- data/tests/compute/requests/brightbox/zone_tests.rb +33 -0
- data/tests/compute/requests/go_grid/image_tests.rb +0 -0
- data/tests/compute/requests/linode/datacenter_tests.rb +19 -0
- data/tests/compute/requests/linode/distribution_tests.rb +32 -0
- data/tests/compute/requests/linode/helper.rb +16 -0
- data/tests/compute/requests/linode/linode_tests.rb +85 -0
- data/tests/compute/requests/linode/linodeplans_tests.rb +39 -0
- data/tests/compute/requests/rackspace/address_tests.rb +40 -0
- data/tests/compute/requests/rackspace/flavor_tests.rb +38 -0
- data/tests/compute/requests/rackspace/helper.rb +16 -0
- data/tests/compute/requests/rackspace/image_tests.rb +68 -0
- data/tests/compute/requests/rackspace/resize_tests.rb +33 -0
- data/tests/compute/requests/rackspace/server_tests.rb +92 -0
- data/tests/compute/requests/slicehost/backup_tests.rb +18 -0
- data/tests/compute/requests/slicehost/flavor_tests.rb +33 -0
- data/tests/compute/requests/slicehost/image_tests.rb +31 -0
- data/tests/compute/requests/slicehost/slice_tests.rb +75 -0
- data/tests/compute/requests/terremark_ecloud/catalog_tests.rb +47 -0
- data/tests/compute/requests/terremark_ecloud/helper.rb +45 -0
- data/tests/compute/requests/terremark_ecloud/network_tests.rb +30 -0
- data/tests/compute/requests/terremark_ecloud/organization_tests.rb +23 -0
- data/tests/compute/requests/terremark_ecloud/vdc_tests.rb +60 -0
- data/tests/core/attribute_tests.rb +45 -0
- data/tests/dns/helper.rb +19 -0
- data/tests/dns/models/record_tests.rb +25 -0
- data/tests/dns/models/records_tests.rb +25 -0
- data/tests/dns/models/zone_tests.rb +13 -0
- data/tests/dns/models/zones_tests.rb +13 -0
- data/tests/dns/requests/aws/dns_tests.rb +276 -0
- data/tests/dns/requests/linode/dns_tests.rb +262 -0
- data/tests/dns/requests/slicehost/dns_tests.rb +279 -0
- data/tests/dns/requests/zerigo/dns_tests.rb +374 -0
- data/tests/helper.rb +17 -0
- data/tests/helpers/collection_helper.rb +51 -0
- data/tests/helpers/compute/flavors_helper.rb +34 -0
- data/tests/helpers/compute/server_helper.rb +19 -0
- data/tests/helpers/compute/servers_helper.rb +11 -0
- data/tests/helpers/formats_helper.rb +70 -0
- data/tests/helpers/formats_helper_tests.rb +43 -0
- data/tests/helpers/mock_helper.rb +33 -0
- data/tests/helpers/model_helper.rb +28 -0
- data/tests/helpers/responds_to_helper.rb +13 -0
- data/tests/helpers/succeeds_helper.rb +12 -0
- data/tests/lorem.txt +1 -0
- data/tests/storage/helper.rb +16 -0
- data/tests/storage/models/directories_tests.rb +13 -0
- data/tests/storage/models/directory_test.rb +24 -0
- data/tests/storage/models/file_tests.rb +41 -0
- data/tests/storage/models/files_tests.rb +26 -0
- data/tests/storage/requests/aws/bucket_tests.rb +104 -0
- data/tests/storage/requests/aws/multipart_upload_tests.rb +135 -0
- data/tests/storage/requests/aws/object_tests.rb +81 -0
- data/tests/storage/requests/google/bucket_tests.rb +79 -0
- data/tests/storage/requests/google/object_tests.rb +81 -0
- data/tests/storage/requests/rackspace/container_tests.rb +64 -0
- data/tests/storage/requests/rackspace/object_tests.rb +69 -0
- metadata +1275 -0
@@ -0,0 +1,118 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/compute/parsers/aws/describe_volumes'
|
7
|
+
|
8
|
+
# Describe all or specified volumes.
|
9
|
+
#
|
10
|
+
# ==== Parameters
|
11
|
+
# * filters<~Hash> - List of filters to limit results with
|
12
|
+
#
|
13
|
+
# ==== Returns
|
14
|
+
# * response<~Excon::Response>:
|
15
|
+
# * body<~Hash>:
|
16
|
+
# * 'volumeSet'<~Array>:
|
17
|
+
# * 'availabilityZone'<~String> - Availability zone for volume
|
18
|
+
# * 'createTime'<~Time> - Timestamp for creation
|
19
|
+
# * 'size'<~Integer> - Size in GiBs for volume
|
20
|
+
# * 'snapshotId'<~String> - Snapshot volume was created from, if any
|
21
|
+
# * 'status'<~String> - State of volume
|
22
|
+
# * 'volumeId'<~String> - Reference to volume
|
23
|
+
# * 'attachmentSet'<~Array>:
|
24
|
+
# * 'attachmentTime'<~Time> - Timestamp for attachment
|
25
|
+
# * 'deleteOnTermination'<~Boolean> - Whether or not to delete volume on instance termination
|
26
|
+
# * 'device'<~String> - How value is exposed to instance
|
27
|
+
# * 'instanceId'<~String> - Reference to attached instance
|
28
|
+
# * 'status'<~String> - Attachment state
|
29
|
+
# * 'volumeId'<~String> - Reference to volume
|
30
|
+
def describe_volumes(filters = {})
|
31
|
+
unless filters.is_a?(Hash)
|
32
|
+
Formatador.display_line("[yellow][WARN] describe_volumes with #{filters.class} param is deprecated, use describe_volumes('volume-id' => []) instead[/] [light_black](#{caller.first})[/]")
|
33
|
+
filters = {'volume-id' => [*filters]}
|
34
|
+
end
|
35
|
+
params = AWS.indexed_filters(filters)
|
36
|
+
request({
|
37
|
+
'Action' => 'DescribeVolumes',
|
38
|
+
:idempotent => true,
|
39
|
+
:parser => Fog::Parsers::AWS::Compute::DescribeVolumes.new
|
40
|
+
}.merge!(params))
|
41
|
+
end
|
42
|
+
|
43
|
+
end
|
44
|
+
|
45
|
+
class Mock
|
46
|
+
|
47
|
+
def describe_volumes(filters = {})
|
48
|
+
unless filters.is_a?(Hash)
|
49
|
+
Formatador.display_line("[yellow][WARN] describe_volumes with #{filters.class} param is deprecated, use describe_volumes('volume-id' => []) instead[/] [light_black](#{caller.first})[/]")
|
50
|
+
filters = {'volume-id' => [*filters]}
|
51
|
+
end
|
52
|
+
|
53
|
+
if filters.keys.any? {|key| key =~ /^tag/}
|
54
|
+
Formatador.display_line("[yellow][WARN] describe_volumes tag filters are not yet mocked[/] [light_black](#{caller.first})[/]")
|
55
|
+
Fog::Mock.not_implemented
|
56
|
+
end
|
57
|
+
|
58
|
+
response = Excon::Response.new
|
59
|
+
|
60
|
+
volume_set = @data[:volumes].values
|
61
|
+
|
62
|
+
aliases = {
|
63
|
+
'availability-zone' => 'availabilityZone',
|
64
|
+
'create-time' => 'createTime',
|
65
|
+
'size' => 'size',
|
66
|
+
'snapshot-id' => 'snapshotId',
|
67
|
+
'status' => 'status',
|
68
|
+
'volume-id' => 'volumeId'
|
69
|
+
}
|
70
|
+
attachment_aliases = {
|
71
|
+
'attach-time' => 'attachTime',
|
72
|
+
'delete-on-termination' => 'deleteOnTermination',
|
73
|
+
'device' => 'device',
|
74
|
+
'instance-id' => 'instanceId',
|
75
|
+
'status' => 'status'
|
76
|
+
}
|
77
|
+
for filter_key, filter_value in filters
|
78
|
+
if attachment_key = filter_key.split('attachment.')[1]
|
79
|
+
aliased_key = permission_aliases[filter_key]
|
80
|
+
volume_set = volume_set.reject{|volume| !volume['attachmentSet'].detect {|attachment| [*filter_value].include?(attachment[aliased_key])}}
|
81
|
+
else
|
82
|
+
aliased_key = aliases[filter_key]
|
83
|
+
volume_set = volume_set.reject{|volume| ![*filter_value].include?(volume[aliased_key])}
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
volume_set.each do |volume|
|
88
|
+
case volume['status']
|
89
|
+
when 'attaching'
|
90
|
+
if Time.now - volume['attachmentSet'].first['attachTime'] > Fog::Mock.delay
|
91
|
+
volume['attachmentSet'].first['status'] = 'in-use'
|
92
|
+
volume['status'] = 'in-use'
|
93
|
+
end
|
94
|
+
when 'creating'
|
95
|
+
if Time.now - volume['createTime'] > Fog::Mock.delay
|
96
|
+
volume['status'] = 'available'
|
97
|
+
end
|
98
|
+
when 'deleting'
|
99
|
+
if Time.now - @data[:deleted_at][volume['volumeId']] > Fog::Mock.delay
|
100
|
+
@data[:deleted_at].delete(volume['volumeId'])
|
101
|
+
@data[:volumes].delete(volume['volumeId'])
|
102
|
+
end
|
103
|
+
end
|
104
|
+
end
|
105
|
+
volume_set = volume_set.reject {|volume| !@data[:volumes][volume['volumeId']]}
|
106
|
+
|
107
|
+
response.status = 200
|
108
|
+
response.body = {
|
109
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
110
|
+
'volumeSet' => volume_set
|
111
|
+
}
|
112
|
+
response
|
113
|
+
end
|
114
|
+
|
115
|
+
end
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/compute/parsers/aws/detach_volume'
|
7
|
+
|
8
|
+
# Detach an Amazon EBS volume from a running instance
|
9
|
+
#
|
10
|
+
# ==== Parameters
|
11
|
+
# * volume_id<~String> - Id of amazon EBS volume to associate with instance
|
12
|
+
# * options<~Hash>:
|
13
|
+
# * 'Device'<~String> - Specifies how the device is exposed to the instance (e.g. "/dev/sdh")
|
14
|
+
# * 'Force'<~Boolean> - If true forces detach, can cause data loss/corruption
|
15
|
+
# * 'InstanceId'<~String> - Id of instance to associate volume with
|
16
|
+
#
|
17
|
+
# ==== Returns
|
18
|
+
# * response<~Excon::Response>:
|
19
|
+
# * body<~Hash>:
|
20
|
+
# * 'attachTime'<~Time> - Time of attachment was initiated at
|
21
|
+
# * 'device'<~String> - Device as it is exposed to the instance
|
22
|
+
# * 'instanceId'<~String> - Id of instance for volume
|
23
|
+
# * 'requestId'<~String> - Id of request
|
24
|
+
# * 'status'<~String> - Status of volume
|
25
|
+
# * 'volumeId'<~String> - Reference to volume
|
26
|
+
def detach_volume(volume_id, options = {})
|
27
|
+
request({
|
28
|
+
'Action' => 'DetachVolume',
|
29
|
+
'VolumeId' => volume_id,
|
30
|
+
:idempotent => true,
|
31
|
+
:parser => Fog::Parsers::AWS::Compute::DetachVolume.new
|
32
|
+
}.merge!(options))
|
33
|
+
end
|
34
|
+
|
35
|
+
end
|
36
|
+
|
37
|
+
class Mock
|
38
|
+
|
39
|
+
def detach_volume(volume_id, options = {})
|
40
|
+
response = Excon::Response.new
|
41
|
+
response.status = 200
|
42
|
+
if (volume = @data[:volumes][volume_id]) && !volume['attachmentSet'].empty?
|
43
|
+
data = volume['attachmentSet'].pop
|
44
|
+
volume['status'] = 'available'
|
45
|
+
response.status = 200
|
46
|
+
response.body = {
|
47
|
+
'requestId' => Fog::AWS::Mock.request_id
|
48
|
+
}.merge!(data)
|
49
|
+
response
|
50
|
+
else
|
51
|
+
raise Fog::AWS::Compute::NotFound.new("The volume '#{volume_id}' does not exist.")
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
end
|
56
|
+
end
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Disassociate an elastic IP address from its instance (if any)
|
7
|
+
#
|
8
|
+
# ==== Parameters
|
9
|
+
# * public_ip<~String> - Public ip to assign to instance
|
10
|
+
#
|
11
|
+
# ==== Returns
|
12
|
+
# * response<~Excon::Response>:
|
13
|
+
# * body<~Hash>:
|
14
|
+
# * 'requestId'<~String> - Id of request
|
15
|
+
# * 'return'<~Boolean> - success?
|
16
|
+
def disassociate_address(public_ip)
|
17
|
+
request(
|
18
|
+
'Action' => 'DisassociateAddress',
|
19
|
+
'PublicIp' => public_ip,
|
20
|
+
:idempotent => true,
|
21
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
22
|
+
)
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
class Mock
|
28
|
+
|
29
|
+
def disassociate_address(public_ip)
|
30
|
+
response = Excon::Response.new
|
31
|
+
response.status = 200
|
32
|
+
if address = @data[:addresses][public_ip]
|
33
|
+
instance_id = address['instanceId']
|
34
|
+
instance = @data[:instances][instance_id]
|
35
|
+
instance['ipAddress'] = instance['originalIpAddress']
|
36
|
+
instance['dnsName'] = Fog::AWS::Mock.dns_name_for(instance['ipAddress'])
|
37
|
+
address['instanceId'] = nil
|
38
|
+
response.status = 200
|
39
|
+
response.body = {
|
40
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
41
|
+
'return' => true
|
42
|
+
}
|
43
|
+
response
|
44
|
+
else
|
45
|
+
raise Fog::AWS::Compute::Error.new("AuthFailure => The address '#{public_ip}' does not belong to you.")
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,52 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/compute/parsers/aws/get_console_output'
|
7
|
+
|
8
|
+
# Retrieve console output for specified instance
|
9
|
+
#
|
10
|
+
# ==== Parameters
|
11
|
+
# * instance_id<~String> - Id of instance to get console output from
|
12
|
+
#
|
13
|
+
# ==== Returns
|
14
|
+
# # * response<~Excon::Response>:
|
15
|
+
# * body<~Hash>:
|
16
|
+
# * 'instanceId'<~String> - Id of instance
|
17
|
+
# * 'output'<~String> - Console output
|
18
|
+
# * 'requestId'<~String> - Id of request
|
19
|
+
# * 'timestamp'<~Time> - Timestamp of last update to output
|
20
|
+
def get_console_output(instance_id)
|
21
|
+
request(
|
22
|
+
'Action' => 'GetConsoleOutput',
|
23
|
+
'InstanceId' => instance_id,
|
24
|
+
:idempotent => true,
|
25
|
+
:parser => Fog::Parsers::AWS::Compute::GetConsoleOutput.new
|
26
|
+
)
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
class Mock
|
32
|
+
|
33
|
+
def get_console_output(instance_id)
|
34
|
+
response = Excon::Response.new
|
35
|
+
if instance = @data[:instances][instance_id]
|
36
|
+
response.status = 200
|
37
|
+
response.body = {
|
38
|
+
'instanceId' => instance_id,
|
39
|
+
'output' => nil,
|
40
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
41
|
+
'timestamp' => Time.now
|
42
|
+
}
|
43
|
+
response
|
44
|
+
else;
|
45
|
+
raise Fog::AWS::Compute::NotFound.new("The instance ID '#{instance_id}' does not exist")
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/compute/parsers/aws/import_key_pair'
|
7
|
+
|
8
|
+
# Import an existing public key to create a new key pair
|
9
|
+
#
|
10
|
+
# ==== Parameters
|
11
|
+
# * key_name<~String> - Unique name for key pair.
|
12
|
+
# * public_key_material<~String> - RSA public key
|
13
|
+
#
|
14
|
+
# ==== Returns
|
15
|
+
# * response<~Excon::Response>:
|
16
|
+
# * body<~Hash>:
|
17
|
+
# * 'keyFingerprint'<~String> - SHA-1 digest of DER encoded private key
|
18
|
+
# * 'keyName'<~String> - Name of key
|
19
|
+
# * 'requestId'<~String> - Id of request
|
20
|
+
def import_key_pair(key_name, public_key_material)
|
21
|
+
request(
|
22
|
+
'Action' => 'ImportKeyPair',
|
23
|
+
'KeyName' => key_name,
|
24
|
+
'PublicKeyMaterial' => Base64::encode64(public_key_material),
|
25
|
+
:parser => Fog::Parsers::AWS::Compute::ImportKeyPair.new
|
26
|
+
)
|
27
|
+
end
|
28
|
+
|
29
|
+
end
|
30
|
+
|
31
|
+
class Mock
|
32
|
+
|
33
|
+
def import_key_pair(key_name, public_key_material)
|
34
|
+
response = Excon::Response.new
|
35
|
+
unless @data[:key_pairs][key_name]
|
36
|
+
response.status = 200
|
37
|
+
data = {
|
38
|
+
'keyFingerprint' => Fog::AWS::Mock.key_fingerprint,
|
39
|
+
'keyName' => key_name
|
40
|
+
}
|
41
|
+
@data[:key_pairs][key_name] = data
|
42
|
+
response.body = {
|
43
|
+
'requestId' => Fog::AWS::Mock.request_id
|
44
|
+
}.merge!(data)
|
45
|
+
response
|
46
|
+
else
|
47
|
+
raise Fog::AWS::Compute::Error.new("InvalidKeyPair.Duplicate => The keypair '#{key_name}' already exists.")
|
48
|
+
end
|
49
|
+
end
|
50
|
+
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Modify image attributes
|
7
|
+
#
|
8
|
+
# ==== Parameters
|
9
|
+
# * image_id<~String> - Id of machine image to modify
|
10
|
+
# * attribute<~String> - Attribute to modify, in ['launchPermission', 'productCodes']
|
11
|
+
# * operation_type<~String> - Operation to perform on attribute, in ['add', 'remove']
|
12
|
+
#
|
13
|
+
def modify_image_attributes(image_id, attribute, operation_type, options = {})
|
14
|
+
params = {}
|
15
|
+
params.merge!(AWS.indexed_param('UserId', options['UserId']))
|
16
|
+
params.merge!(AWS.indexed_param('UserGroup', options['UserGroup']))
|
17
|
+
params.merge!(AWS.indexed_param('ProductCode', options['ProductCode']))
|
18
|
+
request({
|
19
|
+
'Action' => 'ModifyImageAttribute',
|
20
|
+
'Attribute' => attribute,
|
21
|
+
'ImageId' => image_id,
|
22
|
+
'OperationType' => operation_type,
|
23
|
+
:idempotent => true,
|
24
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
25
|
+
}.merge!(params))
|
26
|
+
end
|
27
|
+
|
28
|
+
end
|
29
|
+
|
30
|
+
class Mock
|
31
|
+
|
32
|
+
def modify_image_attributes(image_id, attribute, operation_type, options = {})
|
33
|
+
Fog::Mock.not_implemented
|
34
|
+
end
|
35
|
+
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
@@ -0,0 +1,38 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Modify snapshot attributes
|
7
|
+
#
|
8
|
+
# ==== Parameters
|
9
|
+
# * snapshot_id<~String> - Id of snapshot to modify
|
10
|
+
# * attribute<~String> - Attribute to modify, in ['createVolumePermission']
|
11
|
+
# * operation_type<~String> - Operation to perform on attribute, in ['add', 'remove']
|
12
|
+
#
|
13
|
+
def modify_snapshot_attribute(snapshot_id, attribute, operation_type, options = {})
|
14
|
+
params = {}
|
15
|
+
params.merge!(AWS.indexed_param('UserId', options['UserId']))
|
16
|
+
params.merge!(AWS.indexed_param('UserGroup', options['UserGroup']))
|
17
|
+
request({
|
18
|
+
'Action' => 'ModifySnapshotAttribute',
|
19
|
+
'Attribute' => attribute,
|
20
|
+
'SnapshotId' => snapshot_id,
|
21
|
+
'OperationType' => operation_type,
|
22
|
+
:idempotent => true,
|
23
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
24
|
+
}.merge!(params))
|
25
|
+
end
|
26
|
+
|
27
|
+
end
|
28
|
+
|
29
|
+
class Mock
|
30
|
+
|
31
|
+
def modify_snapshot_attribute(snapshot_id, attribute, operation_type, options = {})
|
32
|
+
Fog::Mock.not_implemented
|
33
|
+
end
|
34
|
+
|
35
|
+
end
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Reboot specified instances
|
7
|
+
#
|
8
|
+
# ==== Parameters
|
9
|
+
# * instance_id<~Array> - Ids of instances to reboot
|
10
|
+
#
|
11
|
+
# ==== Returns
|
12
|
+
# # * response<~Excon::Response>:
|
13
|
+
# * body<~Hash>:
|
14
|
+
# * 'requestId'<~String> - Id of request
|
15
|
+
# * 'return'<~Boolean> - success?
|
16
|
+
def reboot_instances(instance_id = [])
|
17
|
+
params = AWS.indexed_param('InstanceId', instance_id)
|
18
|
+
request({
|
19
|
+
'Action' => 'RebootInstances',
|
20
|
+
:idempotent => true,
|
21
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
22
|
+
}.merge!(params))
|
23
|
+
end
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
class Mock
|
28
|
+
|
29
|
+
def reboot_instances(instance_id = [])
|
30
|
+
response = Excon::Response.new
|
31
|
+
instance_id = [*instance_id]
|
32
|
+
if (@data[:instances].keys & instance_id).length == instance_id.length
|
33
|
+
for instance_id in instance_id
|
34
|
+
@data[:instances][instance_id]['status'] = 'rebooting'
|
35
|
+
end
|
36
|
+
response.status = 200
|
37
|
+
response.body = {
|
38
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
39
|
+
'return' => true
|
40
|
+
}
|
41
|
+
response
|
42
|
+
else
|
43
|
+
raise Fog::AWS::Compute::NotFound.new("The instance ID #{instance_id.inspect} does not exist")
|
44
|
+
end
|
45
|
+
end
|
46
|
+
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
require 'fog/compute/parsers/aws/register_image'
|
7
|
+
|
8
|
+
# register an image
|
9
|
+
#
|
10
|
+
# ==== Parameters
|
11
|
+
# * Name<~String> - Name of the AMI to be registered
|
12
|
+
# * Description<~String> - AMI description
|
13
|
+
# * Location<~String> - S3 manifest location (for S3 backed AMIs)
|
14
|
+
# or
|
15
|
+
# * RootDeviceName<~String> - Name of Root Device (for EBS snapshot backed AMIs)
|
16
|
+
# * BlockDevices<~Array>:
|
17
|
+
# * BlockDeviceOptions<~Hash>:
|
18
|
+
# * DeviceName<~String> - Name of the Block Device
|
19
|
+
# * VirtualName<~String> - Name of the Virtual Device
|
20
|
+
# * SnapshotId<~String> - id of the EBS Snapshot
|
21
|
+
# * VolumeSize<~Integer> - Size of the snapshot (optional)
|
22
|
+
# * NoDevice<~Boolean> - Do not use an ebs device (def: true)
|
23
|
+
# * DeleteOnTermation<~Boolean> - Delete EBS volume on instance term (def: true)
|
24
|
+
# * Options<~Hash>:
|
25
|
+
# * Architecture<~String> - i386 or x86_64
|
26
|
+
# * KernelId<~String> - kernelId
|
27
|
+
# * RamdiskId<~String> - ramdiskId
|
28
|
+
#
|
29
|
+
# ==== Returns
|
30
|
+
# * response<~Excon::Response>:
|
31
|
+
# * body<~Hash>:
|
32
|
+
# * 'imageId'<~String> - Id of newly created AMI
|
33
|
+
|
34
|
+
def register_image(name, description, location, block_devices=[], options={})
|
35
|
+
common_options = {
|
36
|
+
'Action' => 'RegisterImage',
|
37
|
+
'Name' => name,
|
38
|
+
'Description' => description,
|
39
|
+
:parser => Fog::Parsers::AWS::Compute::RegisterImage.new
|
40
|
+
}
|
41
|
+
|
42
|
+
# This determines if we are doing a snapshot or a S3 backed AMI.
|
43
|
+
if(location =~ /^\/dev\/sd[a-p]\d{0,2}$/)
|
44
|
+
common_options['RootDeviceName'] = location
|
45
|
+
else
|
46
|
+
common_options['ImageLocation'] = location
|
47
|
+
end
|
48
|
+
|
49
|
+
bdi = 0
|
50
|
+
block_devices.each do |bd|
|
51
|
+
bdi += 1
|
52
|
+
["DeviceName","VirtualName"].each do |n|
|
53
|
+
common_options["BlockDeviceMapping.#{bdi}.#{n}"] = bd["#{n}"] if bd["#{n}"]
|
54
|
+
end
|
55
|
+
["SnapshotId","VolumeSize","NoDevice","DeleteOnTermination"].each do |n|
|
56
|
+
common_options["BlockDeviceMapping.#{bdi}.Ebs.#{n}"] = bd["#{n}"] if bd["#{n}"]
|
57
|
+
end
|
58
|
+
|
59
|
+
end
|
60
|
+
|
61
|
+
request(common_options.merge!(options))
|
62
|
+
end
|
63
|
+
|
64
|
+
end
|
65
|
+
|
66
|
+
class Mock
|
67
|
+
|
68
|
+
def register_image(name, description, location, block_devices=[], options={})
|
69
|
+
response = Excon::Response.new
|
70
|
+
if !name.empty?
|
71
|
+
response.status = 200
|
72
|
+
response.body = {
|
73
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
74
|
+
'imageId' => Fog::AWS::Mock.image_id
|
75
|
+
}
|
76
|
+
response
|
77
|
+
else
|
78
|
+
message = 'MissingParameter => '
|
79
|
+
if name.empty?
|
80
|
+
message << 'The request must contain the parameter name'
|
81
|
+
end
|
82
|
+
raise Fog::AWS::Compute::Error.new(message)
|
83
|
+
end
|
84
|
+
end
|
85
|
+
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -0,0 +1,43 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Release an elastic IP address.
|
7
|
+
#
|
8
|
+
# ==== Returns
|
9
|
+
# * response<~Excon::Response>:
|
10
|
+
# * body<~Hash>:
|
11
|
+
# * 'requestId'<~String> - Id of request
|
12
|
+
# * 'return'<~Boolean> - success?
|
13
|
+
def release_address(public_ip)
|
14
|
+
request(
|
15
|
+
'Action' => 'ReleaseAddress',
|
16
|
+
'PublicIp' => public_ip,
|
17
|
+
:idempotent => true,
|
18
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
19
|
+
)
|
20
|
+
end
|
21
|
+
|
22
|
+
end
|
23
|
+
|
24
|
+
class Mock
|
25
|
+
|
26
|
+
def release_address(public_ip)
|
27
|
+
response = Excon::Response.new
|
28
|
+
if (address = @data[:addresses].delete(public_ip))
|
29
|
+
response.status = 200
|
30
|
+
response.body = {
|
31
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
32
|
+
'return' => true
|
33
|
+
}
|
34
|
+
response
|
35
|
+
else
|
36
|
+
raise Fog::AWS::Compute::Error.new("AuthFailure => The address '#{public_ip}' does not belong to you.")
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
end
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
@@ -0,0 +1,74 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
|
6
|
+
# Remove permissions from a security group
|
7
|
+
#
|
8
|
+
# ==== Parameters
|
9
|
+
# * options<~Hash>:
|
10
|
+
# * 'GroupName'<~String> - Name of group
|
11
|
+
# * 'SourceSecurityGroupName'<~String> - Name of security group to authorize
|
12
|
+
# * 'SourceSecurityGroupOwnerId'<~String> - Name of owner to authorize
|
13
|
+
# or
|
14
|
+
# * 'CidrIp' - CIDR range
|
15
|
+
# * 'FromPort' - Start of port range (or -1 for ICMP wildcard)
|
16
|
+
# * 'GroupName' - Name of group to modify
|
17
|
+
# * 'IpProtocol' - Ip protocol, must be in ['tcp', 'udp', 'icmp']
|
18
|
+
# * 'ToPort' - End of port range (or -1 for ICMP wildcard)
|
19
|
+
#
|
20
|
+
# === Returns
|
21
|
+
# * response<~Excon::Response>:
|
22
|
+
# * body<~Hash>:
|
23
|
+
# * 'requestId'<~String> - Id of request
|
24
|
+
# * 'return'<~Boolean> - success?
|
25
|
+
def revoke_security_group_ingress(options = {})
|
26
|
+
request({
|
27
|
+
'Action' => 'RevokeSecurityGroupIngress',
|
28
|
+
:idempotent => true,
|
29
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
30
|
+
}.merge!(options))
|
31
|
+
end
|
32
|
+
|
33
|
+
end
|
34
|
+
|
35
|
+
class Mock
|
36
|
+
|
37
|
+
def revoke_security_group_ingress(options = {})
|
38
|
+
response = Excon::Response.new
|
39
|
+
group = @data[:security_groups][options['GroupName']]
|
40
|
+
if group
|
41
|
+
if options['GroupName'] && options['SourceSecurityGroupName'] && options['SourceSecurityGroupOwnerId']
|
42
|
+
group['ipPermissions'].delete_if {|permission|
|
43
|
+
permission['groups'].first['groupName'] == options['GroupName']
|
44
|
+
}
|
45
|
+
else
|
46
|
+
ingress = group['ipPermissions'].select {|permission|
|
47
|
+
permission['fromPort'] == options['FromPort'] &&
|
48
|
+
permission['ipProtocol'] == options['IpProtocol'] &&
|
49
|
+
permission['toPort'] == options['ToPort'] &&
|
50
|
+
(
|
51
|
+
permission['ipRanges'].empty? ||
|
52
|
+
(
|
53
|
+
permission['ipRanges'].first &&
|
54
|
+
permission['ipRanges'].first['cidrIp'] == options['CidrIp']
|
55
|
+
)
|
56
|
+
)
|
57
|
+
}.first
|
58
|
+
group['ipPermissions'].delete(ingress)
|
59
|
+
end
|
60
|
+
response.status = 200
|
61
|
+
response.body = {
|
62
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
63
|
+
'return' => true
|
64
|
+
}
|
65
|
+
response
|
66
|
+
else
|
67
|
+
raise Fog::AWS::Compute::NotFound.new("The security group '#{options['GroupName']}' does not exist")
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
end
|