fog-aws 0.11.0 → 3.18.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.md +813 -22
- data/CONTRIBUTING.md +6 -6
- data/CONTRIBUTORS.md +104 -1
- data/LICENSE.md +1 -1
- data/README.md +121 -7
- data/fog-aws.gemspec +12 -9
- data/lib/fog/aws/auto_scaling.rb +4 -1
- data/lib/fog/aws/cdn.rb +15 -2
- data/lib/fog/aws/cloud_formation.rb +14 -0
- data/lib/fog/aws/compute.rb +158 -27
- data/lib/fog/aws/credential_fetcher.rb +81 -13
- data/lib/fog/aws/data_pipeline.rb +65 -2
- data/lib/fog/aws/dns.rb +154 -5
- data/lib/fog/aws/efs.rb +177 -0
- data/lib/fog/aws/elasticache.rb +4 -2
- data/lib/fog/aws/elb.rb +3 -2
- data/lib/fog/aws/elbv2.rb +72 -0
- data/lib/fog/aws/glacier.rb +83 -21
- data/lib/fog/aws/iam/default_policy_versions.json +1 -0
- data/lib/fog/aws/iam.rb +3 -0
- data/lib/fog/aws/kinesis.rb +23 -15
- data/lib/fog/aws/mock.rb +12 -0
- data/lib/fog/aws/models/auto_scaling/group.rb +24 -0
- data/lib/fog/aws/models/cdn/distribution.rb +4 -4
- data/lib/fog/aws/models/cdn/distribution_helper.rb +2 -2
- data/lib/fog/aws/models/cdn/distributions.rb +4 -4
- data/lib/fog/aws/models/cdn/distributions_helper.rb +2 -2
- data/lib/fog/aws/models/cdn/invalidation.rb +2 -2
- data/lib/fog/aws/models/cdn/invalidations.rb +3 -3
- data/lib/fog/aws/models/cdn/streaming_distribution.rb +3 -3
- data/lib/fog/aws/models/cdn/streaming_distributions.rb +4 -4
- data/lib/fog/aws/models/compute/address.rb +19 -3
- data/lib/fog/aws/models/compute/addresses.rb +3 -3
- data/lib/fog/aws/models/compute/dhcp_option.rb +2 -2
- data/lib/fog/aws/models/compute/dhcp_options.rb +7 -7
- data/lib/fog/aws/models/compute/flavor.rb +2 -2
- data/lib/fog/aws/models/compute/flavors.rb +3138 -296
- data/lib/fog/aws/models/compute/image.rb +4 -2
- data/lib/fog/aws/models/compute/images.rb +6 -4
- data/lib/fog/aws/models/compute/internet_gateway.rb +2 -2
- data/lib/fog/aws/models/compute/internet_gateways.rb +7 -7
- data/lib/fog/aws/models/compute/key_pair.rb +2 -2
- data/lib/fog/aws/models/compute/key_pairs.rb +3 -3
- data/lib/fog/aws/models/compute/network_acl.rb +4 -4
- data/lib/fog/aws/models/compute/network_acls.rb +6 -6
- data/lib/fog/aws/models/compute/network_interface.rb +2 -2
- data/lib/fog/aws/models/compute/network_interfaces.rb +4 -4
- data/lib/fog/aws/models/compute/route_table.rb +2 -2
- data/lib/fog/aws/models/compute/route_tables.rb +7 -7
- data/lib/fog/aws/models/compute/security_group.rb +61 -30
- data/lib/fog/aws/models/compute/security_groups.rb +3 -3
- data/lib/fog/aws/models/compute/server.rb +8 -4
- data/lib/fog/aws/models/compute/servers.rb +13 -8
- data/lib/fog/aws/models/compute/snapshot.rb +9 -8
- data/lib/fog/aws/models/compute/snapshots.rb +3 -3
- data/lib/fog/aws/models/compute/spot_request.rb +5 -4
- data/lib/fog/aws/models/compute/spot_requests.rb +3 -3
- data/lib/fog/aws/models/compute/subnet.rb +7 -2
- data/lib/fog/aws/models/compute/subnets.rb +3 -3
- data/lib/fog/aws/models/compute/tag.rb +2 -2
- data/lib/fog/aws/models/compute/tags.rb +3 -3
- data/lib/fog/aws/models/compute/volume.rb +46 -38
- data/lib/fog/aws/models/compute/volumes.rb +3 -3
- data/lib/fog/aws/models/compute/vpc.rb +64 -3
- data/lib/fog/aws/models/compute/vpcs.rb +3 -3
- data/lib/fog/aws/models/dns/record.rb +2 -2
- data/lib/fog/aws/models/dns/records.rb +4 -4
- data/lib/fog/aws/models/dns/zone.rb +3 -3
- data/lib/fog/aws/models/dns/zones.rb +4 -4
- data/lib/fog/aws/models/efs/file_system.rb +46 -0
- data/lib/fog/aws/models/efs/file_systems.rb +23 -0
- data/lib/fog/aws/models/efs/mount_target.rb +59 -0
- data/lib/fog/aws/models/efs/mount_targets.rb +25 -0
- data/lib/fog/aws/models/elb/backend_server_descriptions.rb +1 -1
- data/lib/fog/aws/models/elb/listeners.rb +3 -4
- data/lib/fog/aws/models/elb/load_balancer.rb +10 -2
- data/lib/fog/aws/models/elb/load_balancers.rb +5 -6
- data/lib/fog/aws/models/iam/access_keys.rb +0 -2
- data/lib/fog/aws/models/iam/instance_profile.rb +40 -0
- data/lib/fog/aws/models/iam/instance_profiles.rb +24 -0
- data/lib/fog/aws/models/iam/managed_policies.rb +12 -0
- data/lib/fog/aws/models/iam/managed_policy.rb +20 -0
- data/lib/fog/aws/models/iam/role.rb +35 -0
- data/lib/fog/aws/models/rds/cluster.rb +9 -1
- data/lib/fog/aws/models/rds/instance_option.rb +6 -0
- data/lib/fog/aws/models/rds/security_group.rb +4 -2
- data/lib/fog/aws/models/rds/server.rb +66 -63
- data/lib/fog/aws/models/storage/directories.rb +4 -3
- data/lib/fog/aws/models/storage/directory.rb +40 -6
- data/lib/fog/aws/models/storage/file.rb +175 -25
- data/lib/fog/aws/models/storage/files.rb +36 -6
- data/lib/fog/aws/models/storage/version.rb +2 -2
- data/lib/fog/aws/models/storage/versions.rb +3 -3
- data/lib/fog/aws/models/support/flagged_resource.rb +14 -0
- data/lib/fog/aws/models/support/flagged_resources.rb +11 -0
- data/lib/fog/aws/models/support/trusted_advisor_check.rb +65 -0
- data/lib/fog/aws/models/support/trusted_advisor_checks.rb +21 -0
- data/lib/fog/aws/parsers/auto_scaling/describe_auto_scaling_groups.rb +8 -0
- data/lib/fog/aws/parsers/cdn/distribution.rb +2 -2
- data/lib/fog/aws/parsers/cdn/get_distribution_list.rb +2 -2
- data/lib/fog/aws/parsers/cdn/get_invalidation.rb +2 -2
- data/lib/fog/aws/parsers/cdn/get_invalidation_list.rb +2 -2
- data/lib/fog/aws/parsers/cdn/get_streaming_distribution_list.rb +2 -2
- data/lib/fog/aws/parsers/cdn/post_invalidation.rb +2 -2
- data/lib/fog/aws/parsers/cdn/streaming_distribution.rb +1 -1
- data/lib/fog/aws/parsers/cloud_formation/basic.rb +8 -0
- data/lib/fog/aws/parsers/cloud_formation/create_change_set.rb +16 -0
- data/lib/fog/aws/parsers/cloud_formation/describe_account_limits.rb +26 -0
- data/lib/fog/aws/parsers/cloud_formation/describe_change_set.rb +135 -0
- data/lib/fog/aws/parsers/cloud_formation/describe_stack_resource.rb +28 -0
- data/lib/fog/aws/parsers/cloud_formation/estimate_template_cost.rb +16 -0
- data/lib/fog/aws/parsers/cloud_formation/get_stack_policy.rb +16 -0
- data/lib/fog/aws/parsers/cloud_formation/get_template_summary.rb +62 -0
- data/lib/fog/aws/parsers/cloud_formation/list_change_sets.rb +30 -0
- data/lib/fog/aws/parsers/compute/allocate_address.rb +2 -2
- data/lib/fog/aws/parsers/compute/assign_private_ip_addresses.rb +2 -2
- data/lib/fog/aws/parsers/compute/associate_address.rb +2 -2
- data/lib/fog/aws/parsers/compute/associate_route_table.rb +2 -2
- data/lib/fog/aws/parsers/compute/attach_network_interface.rb +2 -2
- data/lib/fog/aws/parsers/compute/attach_volume.rb +2 -2
- data/lib/fog/aws/parsers/compute/basic.rb +2 -2
- data/lib/fog/aws/parsers/compute/cancel_spot_instance_requests.rb +2 -2
- data/lib/fog/aws/parsers/compute/copy_image.rb +2 -2
- data/lib/fog/aws/parsers/compute/copy_snapshot.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_dhcp_options.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_image.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_internet_gateway.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_key_pair.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_network_acl.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_network_interface.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_route_table.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_security_group.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_snapshot.rb +3 -3
- data/lib/fog/aws/parsers/compute/create_subnet.rb +37 -8
- data/lib/fog/aws/parsers/compute/create_volume.rb +2 -2
- data/lib/fog/aws/parsers/compute/create_vpc.rb +2 -2
- data/lib/fog/aws/parsers/compute/deregister_image.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_account_attributes.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_addresses.rb +32 -11
- data/lib/fog/aws/parsers/compute/describe_availability_zones.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_classic_link_instances.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_dhcp_options.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_image_attribute.rb +122 -0
- data/lib/fog/aws/parsers/compute/describe_images.rb +5 -3
- data/lib/fog/aws/parsers/compute/describe_instance_attribute.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_instance_status.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_instances.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_internet_gateways.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_key_pairs.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_network_acls.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_network_interface_attribute.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_network_interfaces.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_placement_groups.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_regions.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_reserved_instances.rb +19 -8
- data/lib/fog/aws/parsers/compute/describe_reserved_instances_offerings.rb +3 -3
- data/lib/fog/aws/parsers/compute/describe_route_tables.rb +5 -5
- data/lib/fog/aws/parsers/compute/describe_security_groups.rb +21 -7
- data/lib/fog/aws/parsers/compute/describe_snapshots.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_spot_price_history.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_subnets.rb +36 -9
- data/lib/fog/aws/parsers/compute/describe_tags.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_volume_status.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_volumes.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_volumes_modifications.rb +30 -0
- data/lib/fog/aws/parsers/compute/describe_vpc_attribute.rb +2 -2
- data/lib/fog/aws/parsers/compute/describe_vpc_classic_link.rb +5 -3
- data/lib/fog/aws/parsers/compute/describe_vpc_classic_link_dns_support.rb +26 -0
- data/lib/fog/aws/parsers/compute/describe_vpcs.rb +73 -25
- data/lib/fog/aws/parsers/compute/detach_volume.rb +2 -2
- data/lib/fog/aws/parsers/compute/get_console_output.rb +2 -2
- data/lib/fog/aws/parsers/compute/get_password_data.rb +2 -2
- data/lib/fog/aws/parsers/compute/import_key_pair.rb +2 -2
- data/lib/fog/aws/parsers/compute/modify_subnet_attribute.rb +2 -2
- data/lib/fog/aws/parsers/compute/modify_volume.rb +26 -0
- data/lib/fog/aws/parsers/compute/monitor_unmonitor_instances.rb +2 -2
- data/lib/fog/aws/parsers/compute/move_address_to_vpc.rb +16 -0
- data/lib/fog/aws/parsers/compute/network_acl_parser.rb +2 -2
- data/lib/fog/aws/parsers/compute/network_interface_parser.rb +2 -2
- data/lib/fog/aws/parsers/compute/purchase_reserved_instances_offering.rb +2 -2
- data/lib/fog/aws/parsers/compute/register_image.rb +2 -2
- data/lib/fog/aws/parsers/compute/replace_network_acl_association.rb +2 -2
- data/lib/fog/aws/parsers/compute/restore_address_to_classic.rb +16 -0
- data/lib/fog/aws/parsers/compute/run_instances.rb +2 -2
- data/lib/fog/aws/parsers/compute/spot_datafeed_subscription.rb +2 -2
- data/lib/fog/aws/parsers/compute/spot_instance_requests.rb +2 -2
- data/lib/fog/aws/parsers/compute/start_stop_instances.rb +2 -2
- data/lib/fog/aws/parsers/compute/terminate_instances.rb +2 -2
- data/lib/fog/aws/parsers/dns/change_resource_record_sets.rb +2 -2
- data/lib/fog/aws/parsers/dns/create_hosted_zone.rb +3 -3
- data/lib/fog/aws/parsers/dns/delete_hosted_zone.rb +2 -2
- data/lib/fog/aws/parsers/dns/get_change.rb +2 -2
- data/lib/fog/aws/parsers/dns/get_hosted_zone.rb +5 -5
- data/lib/fog/aws/parsers/dns/health_check.rb +2 -2
- data/lib/fog/aws/parsers/dns/list_health_checks.rb +2 -2
- data/lib/fog/aws/parsers/dns/list_hosted_zones.rb +5 -3
- data/lib/fog/aws/parsers/dns/list_resource_record_sets.rb +2 -2
- data/lib/fog/aws/parsers/elb/describe_load_balancers.rb +3 -3
- data/lib/fog/aws/parsers/elbv2/create_load_balancer.rb +88 -0
- data/lib/fog/aws/parsers/elbv2/describe_listeners.rb +110 -0
- data/lib/fog/aws/parsers/elbv2/describe_load_balancers.rb +88 -0
- data/lib/fog/aws/parsers/elbv2/describe_tags.rb +53 -0
- data/lib/fog/aws/parsers/elbv2/empty.rb +10 -0
- data/lib/fog/aws/parsers/iam/get_group_policy.rb +1 -1
- data/lib/fog/aws/parsers/iam/get_role_policy.rb +1 -1
- data/lib/fog/aws/parsers/iam/get_user_policy.rb +1 -1
- data/lib/fog/aws/parsers/iam/list_access_keys.rb +1 -1
- data/lib/fog/aws/parsers/iam/policy_version.rb +1 -1
- data/lib/fog/aws/parsers/rds/db_parser.rb +41 -2
- data/lib/fog/aws/parsers/rds/describe_orderable_db_instance_options.rb +4 -3
- data/lib/fog/aws/parsers/rds/modify_db_subnet_group.rb +24 -0
- data/lib/fog/aws/parsers/storage/access_control_list.rb +2 -2
- data/lib/fog/aws/parsers/storage/complete_multipart_upload.rb +2 -2
- data/lib/fog/aws/parsers/storage/copy_object.rb +2 -2
- data/lib/fog/aws/parsers/storage/cors_configuration.rb +2 -2
- data/lib/fog/aws/parsers/storage/delete_multiple_objects.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket.rb +3 -3
- data/lib/fog/aws/parsers/storage/get_bucket_lifecycle.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_location.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_logging.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_notification.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_object_versions.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_tagging.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_versioning.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_bucket_website.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_object_tagging.rb +33 -0
- data/lib/fog/aws/parsers/storage/get_request_payment.rb +2 -2
- data/lib/fog/aws/parsers/storage/get_service.rb +2 -2
- data/lib/fog/aws/parsers/storage/initiate_multipart_upload.rb +2 -2
- data/lib/fog/aws/parsers/storage/list_multipart_uploads.rb +2 -2
- data/lib/fog/aws/parsers/storage/list_parts.rb +2 -2
- data/lib/fog/aws/parsers/storage/upload_part_copy_object.rb +18 -0
- data/lib/fog/aws/parsers/sts/assume_role_with_web_identity.rb +1 -1
- data/lib/fog/aws/rds.rb +2 -2
- data/lib/fog/aws/requests/auto_scaling/attach_load_balancer_target_groups.rb +58 -0
- data/lib/fog/aws/requests/auto_scaling/create_auto_scaling_group.rb +3 -4
- data/lib/fog/aws/requests/auto_scaling/detach_instances.rb +3 -4
- data/lib/fog/aws/requests/auto_scaling/detach_load_balancer_target_groups.rb +57 -0
- data/lib/fog/aws/requests/auto_scaling/put_scaling_policy.rb +1 -1
- data/lib/fog/aws/requests/auto_scaling/set_instance_protection.rb +67 -0
- data/lib/fog/aws/requests/cdn/delete_distribution.rb +6 -6
- data/lib/fog/aws/requests/cdn/delete_streaming_distribution.rb +6 -6
- data/lib/fog/aws/requests/cdn/get_distribution.rb +5 -5
- data/lib/fog/aws/requests/cdn/get_distribution_list.rb +3 -3
- data/lib/fog/aws/requests/cdn/get_invalidation.rb +5 -5
- data/lib/fog/aws/requests/cdn/get_invalidation_list.rb +4 -4
- data/lib/fog/aws/requests/cdn/get_streaming_distribution.rb +5 -5
- data/lib/fog/aws/requests/cdn/get_streaming_distribution_list.rb +3 -3
- data/lib/fog/aws/requests/cdn/post_distribution.rb +6 -6
- data/lib/fog/aws/requests/cdn/post_invalidation.rb +5 -5
- data/lib/fog/aws/requests/cdn/post_streaming_distribution.rb +6 -6
- data/lib/fog/aws/requests/cdn/put_distribution_config.rb +7 -7
- data/lib/fog/aws/requests/cdn/put_streaming_distribution_config.rb +7 -7
- data/lib/fog/aws/requests/cloud_formation/cancel_update_stack.rb +25 -0
- data/lib/fog/aws/requests/cloud_formation/continue_update_rollback.rb +26 -0
- data/lib/fog/aws/requests/cloud_formation/create_change_set.rb +75 -0
- data/lib/fog/aws/requests/cloud_formation/create_stack.rb +14 -0
- data/lib/fog/aws/requests/cloud_formation/delete_change_set.rb +26 -0
- data/lib/fog/aws/requests/cloud_formation/delete_stack.rb +1 -1
- data/lib/fog/aws/requests/cloud_formation/describe_account_limits.rb +27 -0
- data/lib/fog/aws/requests/cloud_formation/describe_change_set.rb +43 -0
- data/lib/fog/aws/requests/cloud_formation/describe_stack_resource.rb +40 -0
- data/lib/fog/aws/requests/cloud_formation/estimate_template_cost.rb +48 -0
- data/lib/fog/aws/requests/cloud_formation/execute_change_set.rb +26 -0
- data/lib/fog/aws/requests/cloud_formation/get_stack_policy.rb +27 -0
- data/lib/fog/aws/requests/cloud_formation/get_template_summary.rb +46 -0
- data/lib/fog/aws/requests/cloud_formation/list_change_sets.rb +40 -0
- data/lib/fog/aws/requests/cloud_formation/set_stack_policy.rb +38 -0
- data/lib/fog/aws/requests/cloud_formation/signal_resource.rb +32 -0
- data/lib/fog/aws/requests/cloud_formation/update_stack.rb +49 -0
- data/lib/fog/aws/requests/cloud_watch/put_metric_alarm.rb +2 -2
- data/lib/fog/aws/requests/compute/allocate_address.rb +6 -5
- data/lib/fog/aws/requests/compute/assign_private_ip_addresses.rb +5 -5
- data/lib/fog/aws/requests/compute/associate_address.rb +16 -8
- data/lib/fog/aws/requests/compute/associate_dhcp_options.rb +4 -4
- data/lib/fog/aws/requests/compute/associate_route_table.rb +5 -5
- data/lib/fog/aws/requests/compute/attach_classic_link_vpc.rb +10 -10
- data/lib/fog/aws/requests/compute/attach_internet_gateway.rb +4 -4
- data/lib/fog/aws/requests/compute/attach_network_interface.rb +6 -6
- data/lib/fog/aws/requests/compute/attach_volume.rb +7 -7
- data/lib/fog/aws/requests/compute/authorize_security_group_egress.rb +114 -0
- data/lib/fog/aws/requests/compute/authorize_security_group_ingress.rb +49 -30
- data/lib/fog/aws/requests/compute/cancel_spot_instance_requests.rb +20 -3
- data/lib/fog/aws/requests/compute/copy_image.rb +3 -3
- data/lib/fog/aws/requests/compute/copy_snapshot.rb +24 -11
- data/lib/fog/aws/requests/compute/create_dhcp_options.rb +3 -3
- data/lib/fog/aws/requests/compute/create_image.rb +3 -3
- data/lib/fog/aws/requests/compute/create_internet_gateway.rb +3 -3
- data/lib/fog/aws/requests/compute/create_key_pair.rb +4 -4
- data/lib/fog/aws/requests/compute/create_network_acl.rb +4 -4
- data/lib/fog/aws/requests/compute/create_network_acl_entry.rb +5 -5
- data/lib/fog/aws/requests/compute/create_network_interface.rb +15 -12
- data/lib/fog/aws/requests/compute/create_placement_group.rb +3 -3
- data/lib/fog/aws/requests/compute/create_route.rb +10 -10
- data/lib/fog/aws/requests/compute/create_route_table.rb +5 -5
- data/lib/fog/aws/requests/compute/create_security_group.rb +27 -22
- data/lib/fog/aws/requests/compute/create_snapshot.rb +3 -3
- data/lib/fog/aws/requests/compute/create_spot_datafeed_subscription.rb +3 -3
- data/lib/fog/aws/requests/compute/create_subnet.rb +23 -19
- data/lib/fog/aws/requests/compute/create_tags.rb +3 -3
- data/lib/fog/aws/requests/compute/create_volume.rb +11 -11
- data/lib/fog/aws/requests/compute/create_vpc.rb +42 -13
- data/lib/fog/aws/requests/compute/delete_dhcp_options.rb +4 -4
- data/lib/fog/aws/requests/compute/delete_internet_gateway.rb +4 -4
- data/lib/fog/aws/requests/compute/delete_key_pair.rb +3 -3
- data/lib/fog/aws/requests/compute/delete_network_acl.rb +5 -5
- data/lib/fog/aws/requests/compute/delete_network_acl_entry.rb +5 -5
- data/lib/fog/aws/requests/compute/delete_network_interface.rb +5 -5
- data/lib/fog/aws/requests/compute/delete_placement_group.rb +3 -3
- data/lib/fog/aws/requests/compute/delete_route.rb +6 -6
- data/lib/fog/aws/requests/compute/delete_route_table.rb +5 -5
- data/lib/fog/aws/requests/compute/delete_security_group.rb +17 -17
- data/lib/fog/aws/requests/compute/delete_snapshot.rb +4 -4
- data/lib/fog/aws/requests/compute/delete_spot_datafeed_subscription.rb +3 -3
- data/lib/fog/aws/requests/compute/delete_subnet.rb +4 -4
- data/lib/fog/aws/requests/compute/delete_tags.rb +3 -3
- data/lib/fog/aws/requests/compute/delete_volume.rb +5 -5
- data/lib/fog/aws/requests/compute/delete_vpc.rb +4 -4
- data/lib/fog/aws/requests/compute/deregister_image.rb +4 -4
- data/lib/fog/aws/requests/compute/describe_account_attributes.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_addresses.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_availability_zones.rb +16 -3
- data/lib/fog/aws/requests/compute/describe_classic_link_instances.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_dhcp_options.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_image_attribute.rb +74 -0
- data/lib/fog/aws/requests/compute/describe_images.rb +5 -3
- data/lib/fog/aws/requests/compute/describe_instance_attribute.rb +4 -4
- data/lib/fog/aws/requests/compute/describe_instance_status.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_instances.rb +5 -5
- data/lib/fog/aws/requests/compute/describe_internet_gateways.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_key_pairs.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_network_acls.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_network_interface_attribute.rb +19 -17
- data/lib/fog/aws/requests/compute/describe_network_interfaces.rb +7 -3
- data/lib/fog/aws/requests/compute/describe_placement_groups.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_regions.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_reserved_instances.rb +8 -4
- data/lib/fog/aws/requests/compute/describe_reserved_instances_offerings.rb +9 -5
- data/lib/fog/aws/requests/compute/describe_route_tables.rb +9 -3
- data/lib/fog/aws/requests/compute/describe_security_groups.rb +47 -10
- data/lib/fog/aws/requests/compute/describe_snapshots.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_spot_datafeed_subscription.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_spot_instance_requests.rb +36 -3
- data/lib/fog/aws/requests/compute/describe_spot_price_history.rb +5 -5
- data/lib/fog/aws/requests/compute/describe_subnets.rb +15 -14
- data/lib/fog/aws/requests/compute/describe_tags.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_volume_status.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_volumes.rb +3 -3
- data/lib/fog/aws/requests/compute/describe_volumes_modifications.rb +93 -0
- data/lib/fog/aws/requests/compute/describe_vpc_attribute.rb +5 -5
- data/lib/fog/aws/requests/compute/describe_vpc_classic_link.rb +6 -5
- data/lib/fog/aws/requests/compute/describe_vpc_classic_link_dns_support.rb +53 -0
- data/lib/fog/aws/requests/compute/describe_vpcs.rb +3 -3
- data/lib/fog/aws/requests/compute/detach_classic_link_vpc.rb +6 -8
- data/lib/fog/aws/requests/compute/detach_internet_gateway.rb +4 -4
- data/lib/fog/aws/requests/compute/detach_network_interface.rb +4 -4
- data/lib/fog/aws/requests/compute/detach_volume.rb +5 -5
- data/lib/fog/aws/requests/compute/disable_vpc_classic_link.rb +4 -4
- data/lib/fog/aws/requests/compute/disable_vpc_classic_link_dns_support.rb +45 -0
- data/lib/fog/aws/requests/compute/disassociate_address.rb +8 -5
- data/lib/fog/aws/requests/compute/disassociate_route_table.rb +5 -5
- data/lib/fog/aws/requests/compute/enable_vpc_classic_link.rb +4 -4
- data/lib/fog/aws/requests/compute/enable_vpc_classic_link_dns_support.rb +45 -0
- data/lib/fog/aws/requests/compute/get_console_output.rb +4 -4
- data/lib/fog/aws/requests/compute/get_password_data.rb +4 -4
- data/lib/fog/aws/requests/compute/import_key_pair.rb +4 -4
- data/lib/fog/aws/requests/compute/modify_image_attribute.rb +4 -4
- data/lib/fog/aws/requests/compute/modify_instance_attribute.rb +3 -3
- data/lib/fog/aws/requests/compute/modify_instance_placement.rb +33 -0
- data/lib/fog/aws/requests/compute/modify_network_interface_attribute.rb +11 -11
- data/lib/fog/aws/requests/compute/modify_snapshot_attribute.rb +3 -3
- data/lib/fog/aws/requests/compute/modify_subnet_attribute.rb +3 -3
- data/lib/fog/aws/requests/compute/modify_volume.rb +88 -0
- data/lib/fog/aws/requests/compute/modify_volume_attribute.rb +4 -4
- data/lib/fog/aws/requests/compute/modify_vpc_attribute.rb +7 -7
- data/lib/fog/aws/requests/compute/monitor_instances.rb +4 -4
- data/lib/fog/aws/requests/compute/move_address_to_vpc.rb +52 -0
- data/lib/fog/aws/requests/compute/purchase_reserved_instances_offering.rb +3 -3
- data/lib/fog/aws/requests/compute/reboot_instances.rb +4 -4
- data/lib/fog/aws/requests/compute/register_image.rb +4 -4
- data/lib/fog/aws/requests/compute/release_address.rb +5 -5
- data/lib/fog/aws/requests/compute/replace_network_acl_association.rb +5 -5
- data/lib/fog/aws/requests/compute/replace_network_acl_entry.rb +5 -5
- data/lib/fog/aws/requests/compute/replace_route.rb +10 -10
- data/lib/fog/aws/requests/compute/request_spot_instances.rb +41 -30
- data/lib/fog/aws/requests/compute/reset_network_interface_attribute.rb +6 -6
- data/lib/fog/aws/requests/compute/restore_address_to_classic.rb +55 -0
- data/lib/fog/aws/requests/compute/revoke_security_group_egress.rb +92 -0
- data/lib/fog/aws/requests/compute/revoke_security_group_ingress.rb +21 -28
- data/lib/fog/aws/requests/compute/run_instances.rb +95 -29
- data/lib/fog/aws/requests/compute/start_instances.rb +4 -4
- data/lib/fog/aws/requests/compute/stop_instances.rb +15 -7
- data/lib/fog/aws/requests/compute/terminate_instances.rb +5 -5
- data/lib/fog/aws/requests/compute/unmonitor_instances.rb +4 -4
- data/lib/fog/aws/requests/data_pipeline/activate_pipeline.rb +8 -4
- data/lib/fog/aws/requests/data_pipeline/create_pipeline.rb +24 -3
- data/lib/fog/aws/requests/data_pipeline/deactivate_pipeline.rb +36 -0
- data/lib/fog/aws/requests/data_pipeline/delete_pipeline.rb +6 -1
- data/lib/fog/aws/requests/data_pipeline/describe_objects.rb +17 -3
- data/lib/fog/aws/requests/data_pipeline/describe_pipelines.rb +3 -3
- data/lib/fog/aws/requests/data_pipeline/get_pipeline_definition.rb +7 -4
- data/lib/fog/aws/requests/data_pipeline/list_pipelines.rb +3 -3
- data/lib/fog/aws/requests/data_pipeline/put_pipeline_definition.rb +53 -32
- data/lib/fog/aws/requests/data_pipeline/query_objects.rb +6 -3
- data/lib/fog/aws/requests/dns/change_resource_record_sets.rb +6 -131
- data/lib/fog/aws/requests/dns/create_health_check.rb +3 -3
- data/lib/fog/aws/requests/dns/create_hosted_zone.rb +4 -4
- data/lib/fog/aws/requests/dns/delete_health_check.rb +2 -2
- data/lib/fog/aws/requests/dns/delete_hosted_zone.rb +4 -4
- data/lib/fog/aws/requests/dns/get_change.rb +4 -4
- data/lib/fog/aws/requests/dns/get_health_check.rb +3 -3
- data/lib/fog/aws/requests/dns/get_hosted_zone.rb +4 -4
- data/lib/fog/aws/requests/dns/list_health_checks.rb +3 -3
- data/lib/fog/aws/requests/dns/list_hosted_zones.rb +3 -3
- data/lib/fog/aws/requests/dns/list_resource_record_sets.rb +5 -5
- data/lib/fog/aws/requests/dynamodb/update_item.rb +6 -5
- data/lib/fog/aws/requests/efs/create_file_system.rb +63 -0
- data/lib/fog/aws/requests/efs/create_mount_target.rb +73 -0
- data/lib/fog/aws/requests/efs/delete_file_system.rb +41 -0
- data/lib/fog/aws/requests/efs/delete_mount_target.rb +38 -0
- data/lib/fog/aws/requests/efs/describe_file_systems.rb +62 -0
- data/lib/fog/aws/requests/efs/describe_mount_target_security_groups.rb +34 -0
- data/lib/fog/aws/requests/efs/describe_mount_targets.rb +61 -0
- data/lib/fog/aws/requests/efs/modify_mount_target_security_groups.rb +39 -0
- data/lib/fog/aws/requests/elb/create_load_balancer.rb +11 -42
- data/lib/fog/aws/requests/elb/create_load_balancer_listeners.rb +24 -21
- data/lib/fog/aws/requests/elb/deregister_instances_from_load_balancer.rb +1 -1
- data/lib/fog/aws/requests/elb/describe_instance_health.rb +1 -1
- data/lib/fog/aws/requests/elb/describe_tags.rb +1 -1
- data/lib/fog/aws/requests/elb/register_instances_with_load_balancer.rb +1 -1
- data/lib/fog/aws/requests/elbv2/add_tags.rb +45 -0
- data/lib/fog/aws/requests/elbv2/create_load_balancer.rb +160 -0
- data/lib/fog/aws/requests/elbv2/describe_listeners.rb +38 -0
- data/lib/fog/aws/requests/elbv2/describe_load_balancers.rb +100 -0
- data/lib/fog/aws/requests/elbv2/describe_tags.rb +50 -0
- data/lib/fog/aws/requests/elbv2/remove_tags.rb +45 -0
- data/lib/fog/aws/requests/iam/add_role_to_instance_profile.rb +19 -0
- data/lib/fog/aws/requests/iam/attach_group_policy.rb +1 -0
- data/lib/fog/aws/requests/iam/attach_role_policy.rb +30 -4
- data/lib/fog/aws/requests/iam/attach_user_policy.rb +1 -0
- data/lib/fog/aws/requests/iam/create_instance_profile.rb +20 -0
- data/lib/fog/aws/requests/iam/create_policy.rb +26 -2
- data/lib/fog/aws/requests/iam/delete_instance_profile.rb +15 -0
- data/lib/fog/aws/requests/iam/delete_policy.rb +15 -0
- data/lib/fog/aws/requests/iam/detach_group_policy.rb +1 -0
- data/lib/fog/aws/requests/iam/detach_role_policy.rb +27 -0
- data/lib/fog/aws/requests/iam/detach_user_policy.rb +1 -0
- data/lib/fog/aws/requests/iam/get_instance_profile.rb +17 -0
- data/lib/fog/aws/requests/iam/list_attached_user_policies.rb +2 -1
- data/lib/fog/aws/requests/iam/list_instance_profiles.rb +9 -0
- data/lib/fog/aws/requests/iam/list_instance_profiles_for_role.rb +10 -0
- data/lib/fog/aws/requests/iam/list_policies.rb +4 -0
- data/lib/fog/aws/requests/iam/remove_role_from_instance_profile.rb +19 -0
- data/lib/fog/aws/requests/kinesis/put_record.rb +1 -2
- data/lib/fog/aws/requests/kinesis/put_records.rb +1 -2
- data/lib/fog/aws/requests/lambda/invoke.rb +8 -8
- data/lib/fog/aws/requests/rds/add_tags_to_resource.rb +12 -10
- data/lib/fog/aws/requests/rds/authorize_db_security_group_ingress.rb +10 -5
- data/lib/fog/aws/requests/rds/create_db_instance.rb +1 -1
- data/lib/fog/aws/requests/rds/create_db_subnet_group.rb +4 -5
- data/lib/fog/aws/requests/rds/delete_db_subnet_group.rb +2 -0
- data/lib/fog/aws/requests/rds/describe_orderable_db_instance_options.rb +12 -6
- data/lib/fog/aws/requests/rds/list_tags_for_resource.rb +10 -7
- data/lib/fog/aws/requests/rds/modify_db_instance.rb +1 -1
- data/lib/fog/aws/requests/rds/modify_db_subnet_group.rb +27 -0
- data/lib/fog/aws/requests/rds/remove_tags_from_resource.rb +9 -8
- data/lib/fog/aws/requests/rds/revoke_db_security_group_ingress.rb +9 -4
- data/lib/fog/aws/requests/storage/abort_multipart_upload.rb +3 -3
- data/lib/fog/aws/requests/storage/acl_utils.rb +3 -3
- data/lib/fog/aws/requests/storage/complete_multipart_upload.rb +4 -4
- data/lib/fog/aws/requests/storage/copy_object.rb +3 -3
- data/lib/fog/aws/requests/storage/cors_utils.rb +3 -3
- data/lib/fog/aws/requests/storage/delete_bucket.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_bucket_cors.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_bucket_lifecycle.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_bucket_policy.rb +3 -3
- data/lib/fog/aws/requests/storage/delete_bucket_tagging.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_bucket_website.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +22 -12
- data/lib/fog/aws/requests/storage/delete_object.rb +2 -2
- data/lib/fog/aws/requests/storage/delete_object_url.rb +40 -0
- data/lib/fog/aws/requests/storage/get_bucket.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_acl.rb +4 -4
- data/lib/fog/aws/requests/storage/get_bucket_cors.rb +4 -4
- data/lib/fog/aws/requests/storage/get_bucket_lifecycle.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_location.rb +5 -6
- data/lib/fog/aws/requests/storage/get_bucket_logging.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_notification.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_object_versions.rb +4 -3
- data/lib/fog/aws/requests/storage/get_bucket_policy.rb +2 -2
- data/lib/fog/aws/requests/storage/get_bucket_tagging.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_versioning.rb +3 -3
- data/lib/fog/aws/requests/storage/get_bucket_website.rb +3 -3
- data/lib/fog/aws/requests/storage/get_object.rb +7 -3
- data/lib/fog/aws/requests/storage/get_object_acl.rb +4 -4
- data/lib/fog/aws/requests/storage/get_object_http_url.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_https_url.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_tagging.rb +41 -0
- data/lib/fog/aws/requests/storage/get_object_torrent.rb +2 -2
- data/lib/fog/aws/requests/storage/get_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/get_request_payment.rb +3 -3
- data/lib/fog/aws/requests/storage/get_service.rb +5 -5
- data/lib/fog/aws/requests/storage/head_bucket.rb +2 -2
- data/lib/fog/aws/requests/storage/head_object.rb +2 -2
- data/lib/fog/aws/requests/storage/head_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/initiate_multipart_upload.rb +4 -4
- data/lib/fog/aws/requests/storage/list_multipart_uploads.rb +3 -3
- data/lib/fog/aws/requests/storage/list_parts.rb +3 -3
- data/lib/fog/aws/requests/storage/post_object_hidden_fields.rb +2 -2
- data/lib/fog/aws/requests/storage/post_object_restore.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_acl.rb +4 -4
- data/lib/fog/aws/requests/storage/put_bucket_cors.rb +4 -4
- data/lib/fog/aws/requests/storage/put_bucket_lifecycle.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_logging.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_notification.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_policy.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_tagging.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_versioning.rb +2 -2
- data/lib/fog/aws/requests/storage/put_bucket_website.rb +2 -2
- data/lib/fog/aws/requests/storage/put_object.rb +9 -8
- data/lib/fog/aws/requests/storage/put_object_acl.rb +4 -4
- data/lib/fog/aws/requests/storage/put_object_tagging.rb +42 -0
- data/lib/fog/aws/requests/storage/put_object_url.rb +2 -2
- data/lib/fog/aws/requests/storage/put_request_payment.rb +2 -2
- data/lib/fog/aws/requests/storage/shared_mock_methods.rb +4 -3
- data/lib/fog/aws/requests/storage/sync_clock.rb +3 -3
- data/lib/fog/aws/requests/storage/upload_part.rb +3 -3
- data/lib/fog/aws/requests/storage/upload_part_copy.rb +119 -0
- data/lib/fog/aws/requests/sts/assume_role.rb +25 -0
- data/lib/fog/aws/requests/sts/assume_role_with_web_identity.rb +7 -6
- data/lib/fog/aws/requests/support/describe_trusted_advisor_check_result.rb +31 -0
- data/lib/fog/aws/requests/support/describe_trusted_advisor_checks.rb +29 -0
- data/lib/fog/aws/service_mapper.rb +129 -0
- data/lib/fog/aws/sqs.rb +1 -1
- data/lib/fog/aws/storage.rb +98 -19
- data/lib/fog/aws/support.rb +170 -0
- data/lib/fog/aws/version.rb +1 -1
- data/lib/fog/aws.rb +32 -19
- data/lib/fog-aws.rb +1 -0
- metadata +118 -285
- data/.gitignore +0 -16
- data/.travis.yml +0 -52
- data/Gemfile +0 -10
- data/Rakefile +0 -8
- data/gemfiles/Gemfile-edge +0 -14
- data/gemfiles/Gemfile-ruby-1.8.7 +0 -6
- data/gemfiles/Gemfile-ruby-1.9 +0 -6
- data/tests/credentials_tests.rb +0 -75
- data/tests/helper.rb +0 -28
- data/tests/helpers/collection_helper.rb +0 -97
- data/tests/helpers/compute/flavors_helper.rb +0 -32
- data/tests/helpers/compute/server_helper.rb +0 -25
- data/tests/helpers/compute/servers_helper.rb +0 -10
- data/tests/helpers/dns_helper.rb +0 -55
- data/tests/helpers/formats_helper.rb +0 -98
- data/tests/helpers/formats_helper_tests.rb +0 -110
- data/tests/helpers/mock_helper.rb +0 -109
- data/tests/helpers/model_helper.rb +0 -31
- data/tests/helpers/responds_to_helper.rb +0 -11
- data/tests/helpers/schema_validator_tests.rb +0 -107
- data/tests/helpers/succeeds_helper.rb +0 -9
- data/tests/lorem.txt +0 -1
- data/tests/models/auto_scaling/activities_tests.rb +0 -6
- data/tests/models/auto_scaling/configuration_test.rb +0 -13
- data/tests/models/auto_scaling/configurations_tests.rb +0 -11
- data/tests/models/auto_scaling/groups_test.rb +0 -27
- data/tests/models/auto_scaling/helper.rb +0 -0
- data/tests/models/auto_scaling/instance_tests.rb +0 -15
- data/tests/models/auto_scaling/instances_tests.rb +0 -6
- data/tests/models/beanstalk/application_tests.rb +0 -69
- data/tests/models/beanstalk/applications_tests.rb +0 -7
- data/tests/models/beanstalk/environment_tests.rb +0 -131
- data/tests/models/beanstalk/environments_tests.rb +0 -34
- data/tests/models/beanstalk/template_tests.rb +0 -47
- data/tests/models/beanstalk/templates_tests.rb +0 -62
- data/tests/models/beanstalk/version_tests.rb +0 -66
- data/tests/models/beanstalk/versions_tests.rb +0 -60
- data/tests/models/cdn/distribution_tests.rb +0 -15
- data/tests/models/cdn/distributions_tests.rb +0 -15
- data/tests/models/cdn/invalidation_tests.rb +0 -31
- data/tests/models/cdn/invalidations_tests.rb +0 -14
- data/tests/models/cdn/streaming_distribution_tests.rb +0 -15
- data/tests/models/cdn/streaming_distributions_tests.rb +0 -15
- data/tests/models/cloud_watch/alarm_data_tests.rb +0 -42
- data/tests/models/cloud_watch/alarm_history_tests.rb +0 -22
- data/tests/models/cloud_watch/metric_statistics_tests.rb +0 -51
- data/tests/models/cloud_watch/metrics_tests.rb +0 -32
- data/tests/models/compute/address_tests.rb +0 -24
- data/tests/models/compute/addresses_tests.rb +0 -5
- data/tests/models/compute/dhcp_option_tests.rb +0 -3
- data/tests/models/compute/dhcp_options_tests.rb +0 -3
- data/tests/models/compute/internet_gateway_tests.rb +0 -3
- data/tests/models/compute/internet_gateways_tests.rb +0 -3
- data/tests/models/compute/key_pair_tests.rb +0 -26
- data/tests/models/compute/key_pairs_tests.rb +0 -5
- data/tests/models/compute/network_acl_tests.rb +0 -109
- data/tests/models/compute/network_acls_tests.rb +0 -20
- data/tests/models/compute/network_interfaces_test.rb +0 -12
- data/tests/models/compute/security_group_tests.rb +0 -74
- data/tests/models/compute/security_groups_tests.rb +0 -5
- data/tests/models/compute/server_tests.rb +0 -94
- data/tests/models/compute/snapshot_tests.rb +0 -10
- data/tests/models/compute/snapshots_tests.rb +0 -10
- data/tests/models/compute/subnet_tests.rb +0 -5
- data/tests/models/compute/subnets_tests.rb +0 -5
- data/tests/models/compute/volume_tests.rb +0 -43
- data/tests/models/compute/volumes_tests.rb +0 -5
- data/tests/models/compute/vpc_tests.rb +0 -4
- data/tests/models/compute/vpcs_tests.rb +0 -19
- data/tests/models/data_pipeline/pipeline_tests.rb +0 -8
- data/tests/models/data_pipeline/pipelines_tests.rb +0 -8
- data/tests/models/dns/record_tests.rb +0 -33
- data/tests/models/dns/records_tests.rb +0 -41
- data/tests/models/dns/zone_tests.rb +0 -4
- data/tests/models/dns/zones_tests.rb +0 -4
- data/tests/models/elasticache/cluster_tests.rb +0 -30
- data/tests/models/elasticache/parameter_groups_tests.rb +0 -15
- data/tests/models/elasticache/security_groups_tests.rb +0 -52
- data/tests/models/elasticache/subnet_groups_tests.rb +0 -44
- data/tests/models/elb/model_tests.rb +0 -360
- data/tests/models/elb/tagging_tests.rb +0 -15
- data/tests/models/glacier/model_tests.rb +0 -47
- data/tests/models/iam/access_keys_tests.rb +0 -53
- data/tests/models/iam/groups_tests.rb +0 -59
- data/tests/models/iam/managed_policies_tests.rb +0 -67
- data/tests/models/iam/policies_tests.rb +0 -57
- data/tests/models/iam/roles_tests.rb +0 -71
- data/tests/models/iam/users_tests.rb +0 -119
- data/tests/models/rds/cluster_tests.rb +0 -54
- data/tests/models/rds/clusters_tests.rb +0 -5
- data/tests/models/rds/event_subscription_tests.rb +0 -9
- data/tests/models/rds/event_subscriptions_tests.rb +0 -6
- data/tests/models/rds/helper.rb +0 -25
- data/tests/models/rds/instance_option_tests.rb +0 -14
- data/tests/models/rds/parameter_group_tests.rb +0 -24
- data/tests/models/rds/parameter_groups_tests.rb +0 -8
- data/tests/models/rds/security_group_tests.rb +0 -53
- data/tests/models/rds/security_groups_tests.rb +0 -5
- data/tests/models/rds/server_tests.rb +0 -131
- data/tests/models/rds/servers_tests.rb +0 -24
- data/tests/models/rds/snapshot_tests.rb +0 -12
- data/tests/models/rds/snapshots_tests.rb +0 -12
- data/tests/models/rds/tagging_tests.rb +0 -20
- data/tests/models/sns/topic_tests.rb +0 -15
- data/tests/models/sns/topics_tests.rb +0 -6
- data/tests/models/storage/directory_tests.rb +0 -91
- data/tests/models/storage/file_tests.rb +0 -121
- data/tests/models/storage/files_tests.rb +0 -58
- data/tests/models/storage/url_tests.rb +0 -44
- data/tests/models/storage/version_tests.rb +0 -52
- data/tests/models/storage/versions_tests.rb +0 -56
- data/tests/parsers/elb/describe_load_balancers.rb +0 -65
- data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -93
- data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
- data/tests/requests/auto_scaling/helper.rb +0 -228
- data/tests/requests/auto_scaling/model_tests.rb +0 -233
- data/tests/requests/auto_scaling/notification_configuration_tests.rb +0 -124
- data/tests/requests/auto_scaling/tag_tests.rb +0 -63
- data/tests/requests/beanstalk/application_tests.rb +0 -140
- data/tests/requests/beanstalk/solution_stack_tests.rb +0 -22
- data/tests/requests/cdn/cdn_tests.rb +0 -252
- data/tests/requests/cloud_formation/stack_tests.rb +0 -167
- data/tests/requests/cloud_watch/get_metric_statistics_tests.rb +0 -28
- data/tests/requests/cloud_watch/list_metrics_test.rb +0 -64
- data/tests/requests/cloud_watch/put_metric_data_tests.rb +0 -36
- data/tests/requests/compute/address_tests.rb +0 -121
- data/tests/requests/compute/assign_private_ip_tests.rb +0 -55
- data/tests/requests/compute/availability_zone_tests.rb +0 -25
- data/tests/requests/compute/client_tests.rb +0 -25
- data/tests/requests/compute/dhcp_options_tests.rb +0 -39
- data/tests/requests/compute/helper.rb +0 -10
- data/tests/requests/compute/image_tests.rb +0 -158
- data/tests/requests/compute/instance_attrib_tests.rb +0 -168
- data/tests/requests/compute/instance_tests.rb +0 -338
- data/tests/requests/compute/internet_gateway_tests.rb +0 -49
- data/tests/requests/compute/key_pair_tests.rb +0 -67
- data/tests/requests/compute/network_acl_tests.rb +0 -112
- data/tests/requests/compute/network_interface_tests.rb +0 -250
- data/tests/requests/compute/placement_group_tests.rb +0 -48
- data/tests/requests/compute/region_tests.rb +0 -52
- data/tests/requests/compute/route_tests.rb +0 -340
- data/tests/requests/compute/security_group_tests.rb +0 -446
- data/tests/requests/compute/snapshot_tests.rb +0 -77
- data/tests/requests/compute/spot_datafeed_subscription_tests.rb +0 -47
- data/tests/requests/compute/spot_instance_tests.rb +0 -57
- data/tests/requests/compute/spot_price_history_tests.rb +0 -23
- data/tests/requests/compute/subnet_tests.rb +0 -85
- data/tests/requests/compute/tag_tests.rb +0 -101
- data/tests/requests/compute/volume_tests.rb +0 -223
- data/tests/requests/compute/vpc_tests.rb +0 -178
- data/tests/requests/data_pipeline/helper.rb +0 -72
- data/tests/requests/data_pipeline/pipeline_tests.rb +0 -78
- data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
- data/tests/requests/dns/dns_tests.rb +0 -244
- data/tests/requests/dns/health_check_tests.rb +0 -159
- data/tests/requests/dns/helper.rb +0 -21
- data/tests/requests/dynamodb/item_tests.rb +0 -137
- data/tests/requests/dynamodb/table_tests.rb +0 -99
- data/tests/requests/ecs/cluster_tests.rb +0 -112
- data/tests/requests/ecs/container_instance_tests.rb +0 -119
- data/tests/requests/ecs/helper.rb +0 -276
- data/tests/requests/ecs/sample_task_definition1.json +0 -56
- data/tests/requests/ecs/service_tests.rb +0 -132
- data/tests/requests/ecs/task_definitions_tests.rb +0 -97
- data/tests/requests/ecs/task_tests.rb +0 -145
- data/tests/requests/elasticache/cache_cluster_tests.rb +0 -137
- data/tests/requests/elasticache/describe_events.rb +0 -17
- data/tests/requests/elasticache/describe_reserved_cache_nodes.rb +0 -17
- data/tests/requests/elasticache/helper.rb +0 -103
- data/tests/requests/elasticache/parameter_group_tests.rb +0 -105
- data/tests/requests/elasticache/security_group_tests.rb +0 -108
- data/tests/requests/elasticache/subnet_group_tests.rb +0 -52
- data/tests/requests/elb/helper.rb +0 -91
- data/tests/requests/elb/listener_tests.rb +0 -68
- data/tests/requests/elb/load_balancer_tests.rb +0 -89
- data/tests/requests/elb/policy_tests.rb +0 -132
- data/tests/requests/emr/helper.rb +0 -167
- data/tests/requests/emr/instance_group_tests.rb +0 -106
- data/tests/requests/emr/job_flow_tests.rb +0 -88
- data/tests/requests/federation/get_signin_token_tests.rb +0 -11
- data/tests/requests/glacier/archive_tests.rb +0 -13
- data/tests/requests/glacier/multipart_upload_tests.rb +0 -29
- data/tests/requests/glacier/tree_hash_tests.rb +0 -62
- data/tests/requests/glacier/vault_tests.rb +0 -35
- data/tests/requests/iam/access_key_tests.rb +0 -53
- data/tests/requests/iam/account_policy_tests.rb +0 -20
- data/tests/requests/iam/account_tests.rb +0 -34
- data/tests/requests/iam/group_policy_tests.rb +0 -48
- data/tests/requests/iam/group_tests.rb +0 -44
- data/tests/requests/iam/helper.rb +0 -136
- data/tests/requests/iam/login_profile_tests.rb +0 -62
- data/tests/requests/iam/managed_policy_tests.rb +0 -112
- data/tests/requests/iam/mfa_tests.rb +0 -23
- data/tests/requests/iam/role_tests.rb +0 -156
- data/tests/requests/iam/server_certificate_tests.rb +0 -130
- data/tests/requests/iam/user_policy_tests.rb +0 -45
- data/tests/requests/iam/user_tests.rb +0 -78
- data/tests/requests/iam/versioned_managed_policy_tests.rb +0 -114
- data/tests/requests/kinesis/helper.rb +0 -111
- data/tests/requests/kinesis/stream_tests.rb +0 -169
- data/tests/requests/kms/helper.rb +0 -27
- data/tests/requests/kms/key_tests.rb +0 -23
- data/tests/requests/lambda/function_sample_1.js +0 -9
- data/tests/requests/lambda/function_sample_2.js +0 -9
- data/tests/requests/lambda/function_tests.rb +0 -460
- data/tests/requests/lambda/helper.rb +0 -81
- data/tests/requests/rds/cluster_snapshot_tests.rb +0 -43
- data/tests/requests/rds/cluster_tests.rb +0 -37
- data/tests/requests/rds/db_engine_versions.rb +0 -7
- data/tests/requests/rds/db_snapshot_tests.rb +0 -62
- data/tests/requests/rds/describe_events.rb +0 -16
- data/tests/requests/rds/event_subscription_tests.rb +0 -30
- data/tests/requests/rds/helper.rb +0 -401
- data/tests/requests/rds/instance_option_tests.rb +0 -21
- data/tests/requests/rds/instance_tests.rb +0 -149
- data/tests/requests/rds/log_file_tests.rb +0 -19
- data/tests/requests/rds/parameter_group_tests.rb +0 -62
- data/tests/requests/rds/parameter_request_tests.rb +0 -32
- data/tests/requests/rds/security_group_tests.rb +0 -101
- data/tests/requests/rds/subnet_groups_tests.rb +0 -52
- data/tests/requests/rds/tagging_tests.rb +0 -78
- data/tests/requests/redshift/cluster_parameter_group_tests.rb +0 -76
- data/tests/requests/redshift/cluster_security_group_tests.rb +0 -42
- data/tests/requests/redshift/cluster_snapshot_tests.rb +0 -73
- data/tests/requests/redshift/cluster_tests.rb +0 -80
- data/tests/requests/ses/helper.rb +0 -9
- data/tests/requests/ses/verified_domain_identity_tests.rb +0 -16
- data/tests/requests/ses/verified_email_address_tests.rb +0 -27
- data/tests/requests/simpledb/attributes_tests.rb +0 -86
- data/tests/requests/simpledb/domain_tests.rb +0 -51
- data/tests/requests/simpledb/helper.rb +0 -10
- data/tests/requests/sns/helper.rb +0 -9
- data/tests/requests/sns/subscription_tests.rb +0 -86
- data/tests/requests/sns/topic_tests.rb +0 -53
- data/tests/requests/sqs/helper.rb +0 -9
- data/tests/requests/sqs/message_tests.rb +0 -51
- data/tests/requests/sqs/queue_tests.rb +0 -50
- data/tests/requests/storage/acl_utils_tests.rb +0 -209
- data/tests/requests/storage/bucket_tests.rb +0 -416
- data/tests/requests/storage/cors_utils_tests.rb +0 -108
- data/tests/requests/storage/delete_multiple_objects_tests.rb +0 -12
- data/tests/requests/storage/multipart_upload_tests.rb +0 -121
- data/tests/requests/storage/object_tests.rb +0 -195
- data/tests/requests/storage/versioning_tests.rb +0 -258
- data/tests/requests/sts/assume_role_tests.rb +0 -19
- data/tests/requests/sts/assume_role_with_saml_tests.rb +0 -18
- data/tests/requests/sts/assume_role_with_web_identity_tests.rb +0 -26
- data/tests/requests/sts/get_federation_token_tests.rb +0 -20
- data/tests/requests/sts/session_token_tests.rb +0 -16
- data/tests/signaturev4_tests.rb +0 -107
- data/tests/signed_params_tests.rb +0 -17
- data/tests/storage_tests.rb +0 -7
@@ -0,0 +1,114 @@
|
|
1
|
+
module Fog
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
|
+
class Real
|
5
|
+
require 'fog/aws/parsers/compute/basic'
|
6
|
+
|
7
|
+
# Add permissions to a security group
|
8
|
+
#
|
9
|
+
# ==== Parameters
|
10
|
+
# * group_name<~String> - Name of group, optional (can also be specifed as GroupName in options)
|
11
|
+
# * options<~Hash>:
|
12
|
+
# * 'GroupName'<~String> - Name of security group to modify
|
13
|
+
# * 'GroupId'<~String> - Id of security group to modify
|
14
|
+
# * 'SourceSecurityGroupName'<~String> - Name of security group to authorize
|
15
|
+
# * 'SourceSecurityGroupOwnerId'<~String> - Name of owner to authorize
|
16
|
+
# or
|
17
|
+
# * 'CidrIp'<~String> - CIDR range
|
18
|
+
# * 'FromPort'<~Integer> - Start of port range (or -1 for ICMP wildcard)
|
19
|
+
# * 'IpProtocol'<~String> - Ip protocol, must be in ['tcp', 'udp', 'icmp']
|
20
|
+
# * 'ToPort'<~Integer> - End of port range (or -1 for ICMP wildcard)
|
21
|
+
# or
|
22
|
+
# * 'IpPermissions'<~Array>:
|
23
|
+
# * permission<~Hash>:
|
24
|
+
# * 'FromPort'<~Integer> - Start of port range (or -1 for ICMP wildcard)
|
25
|
+
# * 'Groups'<~Array>:
|
26
|
+
# * group<~Hash>:
|
27
|
+
# * 'GroupName'<~String> - Name of security group to authorize
|
28
|
+
# * 'UserId'<~String> - Name of owner to authorize
|
29
|
+
# * 'IpProtocol'<~String> - Ip protocol, must be in ['tcp', 'udp', 'icmp']
|
30
|
+
# * 'IpRanges'<~Array>:
|
31
|
+
# * ip_range<~Hash>:
|
32
|
+
# * 'CidrIp'<~String> - CIDR range
|
33
|
+
# * 'ToPort'<~Integer> - End of port range (or -1 for ICMP wildcard)
|
34
|
+
#
|
35
|
+
# === Returns
|
36
|
+
# * response<~Excon::Response>:
|
37
|
+
# * body<~Hash>:
|
38
|
+
# * 'requestId'<~String> - Id of request
|
39
|
+
# * 'return'<~Boolean> - success?
|
40
|
+
#
|
41
|
+
# {Amazon API Reference}[http://docs.amazonwebservices.com/AWSEC2/latest/APIReference/ApiReference-query-AuthorizeSecurityGroupEgress.html]
|
42
|
+
def authorize_security_group_egress(group_name, options = {})
|
43
|
+
options = Fog::AWS.parse_security_group_options(group_name, options)
|
44
|
+
|
45
|
+
if ip_permissions = options.delete('IpPermissions')
|
46
|
+
options.merge!(indexed_ip_permissions_params(ip_permissions))
|
47
|
+
end
|
48
|
+
|
49
|
+
request({
|
50
|
+
'Action' => 'AuthorizeSecurityGroupEgress',
|
51
|
+
:idempotent => true,
|
52
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
53
|
+
}.merge!(options))
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
class Mock
|
58
|
+
def authorize_security_group_egress(group_name, options = {})
|
59
|
+
options = Fog::AWS.parse_security_group_options(group_name, options)
|
60
|
+
|
61
|
+
group = if options.key?('GroupName')
|
62
|
+
self.data[:security_groups].values.find { |v| v['groupName'] == options['GroupName'] }
|
63
|
+
else
|
64
|
+
self.data[:security_groups][options.fetch('GroupId')]
|
65
|
+
end
|
66
|
+
|
67
|
+
response = Excon::Response.new
|
68
|
+
group ||
|
69
|
+
raise(Fog::AWS::Compute::NotFound.new("The security group '#{group_name}' does not exist"))
|
70
|
+
|
71
|
+
verify_permission_options(options, group['vpcId'] != nil)
|
72
|
+
|
73
|
+
normalized_permissions = normalize_permissions(options)
|
74
|
+
|
75
|
+
normalized_permissions.each do |permission|
|
76
|
+
if matching_group_permission = find_matching_permission_egress(group, permission)
|
77
|
+
if permission['groups'].any? {|pg| matching_group_permission['groups'].include?(pg) }
|
78
|
+
raise Fog::AWS::Compute::Error, "InvalidPermission.Duplicate => The permission '123' has already been authorized in the specified group"
|
79
|
+
end
|
80
|
+
|
81
|
+
if permission['ipRanges'].any? {|pr| matching_group_permission['ipRanges'].include?(pr) }
|
82
|
+
raise Fog::AWS::Compute::Error, "InvalidPermission.Duplicate => The permission '123' has already been authorized in the specified group"
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
|
87
|
+
normalized_permissions.each do |permission|
|
88
|
+
if matching_group_permission = find_matching_permission_egress(group, permission)
|
89
|
+
matching_group_permission['groups'] += permission['groups']
|
90
|
+
matching_group_permission['ipRanges'] += permission['ipRanges']
|
91
|
+
else
|
92
|
+
group['ipPermissionsEgress'] << permission
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
response.status = 200
|
97
|
+
response.body = {
|
98
|
+
'requestId' => Fog::AWS::Mock.request_id,
|
99
|
+
'return' => true
|
100
|
+
}
|
101
|
+
response
|
102
|
+
end
|
103
|
+
|
104
|
+
def find_matching_permission_egress(group, permission)
|
105
|
+
group['ipPermissionsEgress'].find do |group_permission|
|
106
|
+
permission['ipProtocol'] == group_permission['ipProtocol'] &&
|
107
|
+
permission['fromPort'] == group_permission['fromPort'] &&
|
108
|
+
permission['toPort'] == group_permission['toPort']
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/basic'
|
6
6
|
|
@@ -30,6 +30,9 @@ module Fog
|
|
30
30
|
# * 'IpRanges'<~Array>:
|
31
31
|
# * ip_range<~Hash>:
|
32
32
|
# * 'CidrIp'<~String> - CIDR range
|
33
|
+
# * 'Ipv6Ranges'<~Array>:
|
34
|
+
# * ip_range<~Hash>:
|
35
|
+
# * 'CidrIpv6'<~String> - CIDR range
|
33
36
|
# * 'ToPort'<~Integer> - End of port range (or -1 for ICMP wildcard)
|
34
37
|
#
|
35
38
|
# === Returns
|
@@ -49,7 +52,7 @@ module Fog
|
|
49
52
|
request({
|
50
53
|
'Action' => 'AuthorizeSecurityGroupIngress',
|
51
54
|
:idempotent => true,
|
52
|
-
:parser => Fog::Parsers::Compute::
|
55
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
53
56
|
}.merge!(options))
|
54
57
|
end
|
55
58
|
|
@@ -72,6 +75,10 @@ module Fog
|
|
72
75
|
range_index += 1
|
73
76
|
params[format('IpPermissions.%d.IpRanges.%d.CidrIp', key_index, range_index)] = ip_range['CidrIp']
|
74
77
|
end
|
78
|
+
(permission['Ipv6Ranges'] || []).each_with_index do |ip_range, range_index|
|
79
|
+
range_index += 1
|
80
|
+
params[format('IpPermissions.%d.Ipv6Ranges.%d.CidrIpv6', key_index, range_index)] = ip_range['CidrIpv6']
|
81
|
+
end
|
75
82
|
end
|
76
83
|
params.reject {|k, v| v.nil? }
|
77
84
|
end
|
@@ -80,14 +87,16 @@ module Fog
|
|
80
87
|
class Mock
|
81
88
|
def authorize_security_group_ingress(group_name, options = {})
|
82
89
|
options = Fog::AWS.parse_security_group_options(group_name, options)
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
90
|
+
|
91
|
+
group = if options.key?('GroupName')
|
92
|
+
self.data[:security_groups].values.find { |v| v['groupName'] == options['GroupName'] }
|
93
|
+
else
|
94
|
+
self.data[:security_groups][options.fetch('GroupId')]
|
95
|
+
end
|
88
96
|
|
89
97
|
response = Excon::Response.new
|
90
|
-
group
|
98
|
+
group ||
|
99
|
+
raise(Fog::AWS::Compute::NotFound.new("The security group '#{group_name}' does not exist"))
|
91
100
|
|
92
101
|
verify_permission_options(options, group['vpcId'] != nil)
|
93
102
|
|
@@ -96,11 +105,11 @@ module Fog
|
|
96
105
|
normalized_permissions.each do |permission|
|
97
106
|
if matching_group_permission = find_matching_permission(group, permission)
|
98
107
|
if permission['groups'].any? {|pg| matching_group_permission['groups'].include?(pg) }
|
99
|
-
raise Fog::Compute::
|
108
|
+
raise Fog::AWS::Compute::Error, "InvalidPermission.Duplicate => The permission '123' has already been authorized in the specified group"
|
100
109
|
end
|
101
110
|
|
102
111
|
if permission['ipRanges'].any? {|pr| matching_group_permission['ipRanges'].include?(pr) }
|
103
|
-
raise Fog::Compute::
|
112
|
+
raise Fog::AWS::Compute::Error, "InvalidPermission.Duplicate => The permission '123' has already been authorized in the specified group"
|
104
113
|
end
|
105
114
|
end
|
106
115
|
end
|
@@ -126,17 +135,17 @@ module Fog
|
|
126
135
|
|
127
136
|
def verify_permission_options(options, is_vpc)
|
128
137
|
if options.size <= 1
|
129
|
-
raise Fog::Compute::
|
138
|
+
raise Fog::AWS::Compute::Error.new("InvalidRequest => The request received was invalid.")
|
130
139
|
end
|
131
140
|
if !is_vpc && options['IpProtocol'] && !['tcp', 'udp', 'icmp'].include?(options['IpProtocol'])
|
132
|
-
raise Fog::Compute::
|
141
|
+
raise Fog::AWS::Compute::Error.new("InvalidPermission.Malformed => Unsupported IP protocol \"#{options['IpProtocol']}\" - supported: [tcp, udp, icmp]")
|
133
142
|
end
|
134
143
|
if !is_vpc && (options['IpProtocol'] && (!options['FromPort'] || !options['ToPort']))
|
135
|
-
raise Fog::Compute::
|
144
|
+
raise Fog::AWS::Compute::Error.new("InvalidPermission.Malformed => TCP/UDP port (-1) out of range")
|
136
145
|
end
|
137
146
|
if options.key?('IpPermissions')
|
138
147
|
if !options['IpPermissions'].is_a?(Array) || options['IpPermissions'].empty?
|
139
|
-
raise Fog::Compute::
|
148
|
+
raise Fog::AWS::Compute::Error.new("InvalidRequest => The request received was invalid.")
|
140
149
|
end
|
141
150
|
options['IpPermissions'].each {|p| verify_permission_options(p, is_vpc) }
|
142
151
|
end
|
@@ -150,14 +159,15 @@ module Fog
|
|
150
159
|
else
|
151
160
|
options['SourceSecurityGroupName']
|
152
161
|
end
|
153
|
-
source_group_id=self.data[:security_groups][
|
162
|
+
source_group_id, _ = self.data[:security_groups].find { |_,v| v['groupName'] == group_name }
|
163
|
+
|
154
164
|
['tcp', 'udp'].each do |protocol|
|
155
165
|
normalized_permissions << {
|
156
166
|
'ipProtocol' => protocol,
|
157
167
|
'fromPort' => 1,
|
158
168
|
'toPort' => 65535,
|
159
169
|
'groups' => [{
|
160
|
-
'groupName' =>
|
170
|
+
'groupName' => group_name,
|
161
171
|
'userId' => options['SourceSecurityGroupOwnerId'] || self.data[:owner_id],
|
162
172
|
'groupId' => source_group_id
|
163
173
|
}],
|
@@ -169,7 +179,7 @@ module Fog
|
|
169
179
|
'fromPort' => -1,
|
170
180
|
'toPort' => -1,
|
171
181
|
'groups' => [{
|
172
|
-
'groupName' =>
|
182
|
+
'groupName' => group_name,
|
173
183
|
'userId' => options['SourceSecurityGroupOwnerId'] || self.data[:owner_id],
|
174
184
|
'groupId' => source_group_id
|
175
185
|
}],
|
@@ -183,23 +193,32 @@ module Fog
|
|
183
193
|
'groups' => [],
|
184
194
|
'ipRanges' => [{'cidrIp' => options['CidrIp']}]
|
185
195
|
}
|
196
|
+
elsif options['CidrIpv6']
|
197
|
+
normalized_permissions << {
|
198
|
+
'ipProtocol' => options['IpProtocol'],
|
199
|
+
'fromPort' => Integer(options['FromPort']),
|
200
|
+
'toPort' => Integer(options['ToPort']),
|
201
|
+
'groups' => [],
|
202
|
+
'ipv6Ranges' => [{'cidrIpv6' => options['CidrIpv6']}]
|
203
|
+
}
|
186
204
|
elsif options['IpPermissions']
|
187
205
|
options['IpPermissions'].each do |permission|
|
188
206
|
|
189
207
|
groups = (permission['Groups'] || []).map do |authorized_group|
|
190
208
|
security_group = if group_name = authorized_group['GroupName']
|
191
|
-
self.data[:security_groups][group_name
|
209
|
+
self.data[:security_groups].values.find { |sg| sg['groupName'] == group_name }
|
192
210
|
elsif group_id = authorized_group['GroupId']
|
193
|
-
self.data[:security_groups]
|
194
|
-
end
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
211
|
+
self.data[:security_groups][group_id]
|
212
|
+
end
|
213
|
+
security_group ||
|
214
|
+
raise(Fog::AWS::Compute::NotFound.new("The security group '#{group_name || group_id}' does not exist"))
|
215
|
+
|
216
|
+
{
|
217
|
+
'groupName' => authorized_group['GroupName'] || security_group['groupName'],
|
218
|
+
'userId' => authorized_group['UserId'] || self.data[:owner_id],
|
219
|
+
'groupId' => authorized_group["GroupId"] || security_group['groupId']
|
220
|
+
}
|
221
|
+
end
|
203
222
|
|
204
223
|
|
205
224
|
if ['tcp', 'udp', 'icmp'].include?(permission['IpProtocol'])
|
@@ -208,7 +227,7 @@ module Fog
|
|
208
227
|
'fromPort' => Integer(permission['FromPort']),
|
209
228
|
'toPort' => Integer(permission['ToPort']),
|
210
229
|
'groups' => groups,
|
211
|
-
'ipRanges'
|
230
|
+
'ipRanges' => (permission['IpRanges'] || []).map {|r| { 'cidrIp' => r['CidrIp'] } }
|
212
231
|
}
|
213
232
|
else
|
214
233
|
normalized_permissions << {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/cancel_spot_instance_requests'
|
6
6
|
|
@@ -23,10 +23,27 @@ module Fog
|
|
23
23
|
request({
|
24
24
|
'Action' => 'CancelSpotInstanceRequests',
|
25
25
|
:idempotent => true,
|
26
|
-
:parser => Fog::Parsers::Compute::
|
26
|
+
:parser => Fog::Parsers::AWS::Compute::CancelSpotInstanceRequests.new
|
27
27
|
}.merge!(params))
|
28
28
|
end
|
29
29
|
end
|
30
|
+
|
31
|
+
class Mock
|
32
|
+
def cancel_spot_instance_requests(spot_instance_request_id)
|
33
|
+
response = Excon::Response.new
|
34
|
+
spot_request = self.data[:spot_requests][spot_instance_request_id]
|
35
|
+
|
36
|
+
unless spot_request
|
37
|
+
raise Fog::AWS::Compute::NotFound.new("The spot instance request ID '#{spot_instance_request_id}' does not exist")
|
38
|
+
end
|
39
|
+
|
40
|
+
spot_request['fault']['code'] = 'request-cancelled'
|
41
|
+
spot_request['state'] = 'cancelled'
|
42
|
+
|
43
|
+
response.body = {'spotInstanceRequestSet' => [{'spotInstanceRequestId' => spot_instance_request_id, 'state' => 'cancelled'}], 'requestId' => Fog::AWS::Mock.request_id}
|
44
|
+
response
|
45
|
+
end
|
46
|
+
end
|
30
47
|
end
|
31
48
|
end
|
32
49
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/copy_image'
|
6
6
|
|
@@ -28,7 +28,7 @@ module Fog
|
|
28
28
|
'Name' => name,
|
29
29
|
'Description' => description,
|
30
30
|
'ClientToken' => client_token,
|
31
|
-
:parser => Fog::Parsers::Compute::
|
31
|
+
:parser => Fog::Parsers::AWS::Compute::CopyImage.new
|
32
32
|
)
|
33
33
|
end
|
34
34
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/copy_snapshot'
|
6
6
|
|
@@ -9,6 +9,11 @@ module Fog
|
|
9
9
|
# ==== Parameters
|
10
10
|
# * source_snapshot_id<~String> - Id of snapshot
|
11
11
|
# * source_region<~String> - Region to move it from
|
12
|
+
# * options<~Hash>:
|
13
|
+
# * 'Description'<~String> - A description for the EBS snapshot
|
14
|
+
# * 'Encrypted'<~Boolean> - Specifies whether the destination snapshot should be encrypted
|
15
|
+
# * 'KmsKeyId'<~String> - The full ARN of the AWS Key Management Service (AWS KMS) CMK
|
16
|
+
# to use when creating the snapshot copy.
|
12
17
|
#
|
13
18
|
# ==== Returns
|
14
19
|
# * response<~Excon::Response>:
|
@@ -17,14 +22,22 @@ module Fog
|
|
17
22
|
# * 'snapshotId'<~String> - id of snapshot
|
18
23
|
#
|
19
24
|
# {Amazon API Reference}[http://docs.amazonwebservices.com/AWSEC2/latest/APIReference/ApiReference-query-CopySnapshot.html]
|
20
|
-
def copy_snapshot(source_snapshot_id, source_region,
|
21
|
-
|
22
|
-
|
23
|
-
'
|
24
|
-
'
|
25
|
-
|
26
|
-
|
27
|
-
|
25
|
+
def copy_snapshot(source_snapshot_id, source_region, options = {})
|
26
|
+
# For backward compatibility. In previous versions third param was a description
|
27
|
+
if options.is_a?(String)
|
28
|
+
Fog::Logger.warning("copy_snapshot with description as a string in third param is deprecated, use hash instead: copy_snapshot('source-id', 'source-region', { 'Description' => 'some description' })")
|
29
|
+
options = { 'Description' => options }
|
30
|
+
end
|
31
|
+
params = {
|
32
|
+
'Action' => 'CopySnapshot',
|
33
|
+
'SourceSnapshotId' => source_snapshot_id,
|
34
|
+
'SourceRegion' => source_region,
|
35
|
+
'Description' => options['Description'],
|
36
|
+
:parser => Fog::Parsers::AWS::Compute::CopySnapshot.new
|
37
|
+
}
|
38
|
+
params['Encrypted'] = true if options['Encrypted']
|
39
|
+
params['KmsKeyId'] = options['KmsKeyId'] if options['Encrypted'] && options['KmsKeyId']
|
40
|
+
request(params)
|
28
41
|
end
|
29
42
|
end
|
30
43
|
|
@@ -35,7 +48,7 @@ module Fog
|
|
35
48
|
# Fog::AWS[:compute].copy_snapshot("snap-1db0a957", 'us-east-1')
|
36
49
|
#
|
37
50
|
|
38
|
-
def copy_snapshot(source_snapshot_id, source_region,
|
51
|
+
def copy_snapshot(source_snapshot_id, source_region, options = {})
|
39
52
|
response = Excon::Response.new
|
40
53
|
response.status = 200
|
41
54
|
snapshot_id = Fog::AWS::Mock.snapshot_id
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/create_dhcp_options'
|
6
6
|
|
@@ -21,7 +21,7 @@ module Fog
|
|
21
21
|
request({
|
22
22
|
'Action' => 'CreateDhcpOptions',
|
23
23
|
:idempotent => true,
|
24
|
-
:parser => Fog::Parsers::Compute::
|
24
|
+
:parser => Fog::Parsers::AWS::Compute::CreateDhcpOptions.new
|
25
25
|
}.merge!(params))
|
26
26
|
end
|
27
27
|
private
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/create_image'
|
6
6
|
|
@@ -39,7 +39,7 @@ module Fog
|
|
39
39
|
'Name' => name,
|
40
40
|
'Description' => description,
|
41
41
|
'NoReboot' => no_reboot.to_s,
|
42
|
-
:parser => Fog::Parsers::Compute::
|
42
|
+
:parser => Fog::Parsers::AWS::Compute::CreateImage.new
|
43
43
|
}.merge!(params))
|
44
44
|
end
|
45
45
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/create_internet_gateway'
|
6
6
|
|
@@ -25,7 +25,7 @@ module Fog
|
|
25
25
|
def create_internet_gateway()
|
26
26
|
request({
|
27
27
|
'Action' => 'CreateInternetGateway',
|
28
|
-
:parser => Fog::Parsers::Compute::
|
28
|
+
:parser => Fog::Parsers::AWS::Compute::CreateInternetGateway.new
|
29
29
|
})
|
30
30
|
end
|
31
31
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/create_key_pair'
|
6
6
|
|
@@ -22,7 +22,7 @@ module Fog
|
|
22
22
|
request(
|
23
23
|
'Action' => 'CreateKeyPair',
|
24
24
|
'KeyName' => key_name,
|
25
|
-
:parser => Fog::Parsers::Compute::
|
25
|
+
:parser => Fog::Parsers::AWS::Compute::CreateKeyPair.new
|
26
26
|
)
|
27
27
|
end
|
28
28
|
end
|
@@ -43,7 +43,7 @@ module Fog
|
|
43
43
|
}.merge!(data)
|
44
44
|
response
|
45
45
|
else
|
46
|
-
raise Fog::Compute::
|
46
|
+
raise Fog::AWS::Compute::Error.new("InvalidKeyPair.Duplicate => The keypair '#{key_name}' already exists.")
|
47
47
|
end
|
48
48
|
end
|
49
49
|
end
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/create_network_acl'
|
6
6
|
|
@@ -42,7 +42,7 @@ module Fog
|
|
42
42
|
request({
|
43
43
|
'Action' => 'CreateNetworkAcl',
|
44
44
|
'VpcId' => vpcId,
|
45
|
-
:parser => Fog::Parsers::Compute::
|
45
|
+
:parser => Fog::Parsers::AWS::Compute::CreateNetworkAcl.new
|
46
46
|
}.merge!(options))
|
47
47
|
end
|
48
48
|
end
|
@@ -54,7 +54,7 @@ module Fog
|
|
54
54
|
id = Fog::AWS::Mock.network_acl_id
|
55
55
|
|
56
56
|
unless self.data[:vpcs].find { |s| s['vpcId'] == vpcId }
|
57
|
-
raise Fog::Compute::
|
57
|
+
raise Fog::AWS::Compute::Error.new("Unknown VPC '#{vpcId}' specified")
|
58
58
|
end
|
59
59
|
|
60
60
|
data = {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/basic'
|
6
6
|
|
@@ -35,7 +35,7 @@ module Fog
|
|
35
35
|
'RuleAction' => rule_action,
|
36
36
|
'Egress' => egress,
|
37
37
|
'CidrBlock' => cidr_block,
|
38
|
-
:parser => Fog::Parsers::Compute::
|
38
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
39
39
|
}.merge!(options))
|
40
40
|
end
|
41
41
|
end
|
@@ -46,7 +46,7 @@ module Fog
|
|
46
46
|
if self.data[:network_acls][network_acl_id]
|
47
47
|
|
48
48
|
if self.data[:network_acls][network_acl_id]['entrySet'].find { |r| r['ruleNumber'] == rule_number && r['egress'] == egress }
|
49
|
-
raise Fog::Compute::
|
49
|
+
raise Fog::AWS::Compute::Error.new("Already a rule with that number")
|
50
50
|
end
|
51
51
|
|
52
52
|
data = {
|
@@ -71,7 +71,7 @@ module Fog
|
|
71
71
|
}
|
72
72
|
response
|
73
73
|
else
|
74
|
-
raise Fog::Compute::
|
74
|
+
raise Fog::AWS::Compute::NotFound.new("The network ACL '#{network_acl_id}' does not exist")
|
75
75
|
end
|
76
76
|
end
|
77
77
|
end
|
@@ -1,7 +1,8 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
|
+
require 'ipaddr'
|
5
6
|
require 'fog/aws/parsers/compute/create_network_interface'
|
6
7
|
|
7
8
|
# Creates a network interface
|
@@ -54,7 +55,7 @@ module Fog
|
|
54
55
|
request({
|
55
56
|
'Action' => 'CreateNetworkInterface',
|
56
57
|
'SubnetId' => subnetId,
|
57
|
-
:parser => Fog::Parsers::Compute::
|
58
|
+
:parser => Fog::Parsers::AWS::Compute::CreateNetworkInterface.new
|
58
59
|
}.merge!(options))
|
59
60
|
end
|
60
61
|
end
|
@@ -65,35 +66,37 @@ module Fog
|
|
65
66
|
if subnetId
|
66
67
|
subnet = self.data[:subnets].find{ |s| s['subnetId'] == subnetId }
|
67
68
|
if subnet.nil?
|
68
|
-
raise Fog::Compute::
|
69
|
+
raise Fog::AWS::Compute::Error.new("Unknown subnet '#{subnetId}' specified")
|
69
70
|
else
|
70
71
|
id = Fog::AWS::Mock.network_interface_id
|
71
|
-
cidr_block =
|
72
|
+
cidr_block = IPAddr.new(subnet['cidrBlock'])
|
72
73
|
|
73
74
|
groups = {}
|
74
75
|
if options['GroupSet']
|
75
76
|
options['GroupSet'].each do |group_id|
|
76
|
-
group_obj = self.data[:security_groups]
|
77
|
+
group_obj = self.data[:security_groups][group_id]
|
77
78
|
if group_obj.nil?
|
78
|
-
raise Fog::Compute::
|
79
|
+
raise Fog::AWS::Compute::Error.new("Unknown security group '#{group_id}' specified")
|
79
80
|
end
|
80
|
-
groups[group_id] = group_obj
|
81
|
+
groups[group_id] = group_obj['groupName']
|
81
82
|
end
|
82
83
|
end
|
83
84
|
|
84
85
|
if options['PrivateIpAddress'].nil?
|
86
|
+
range = cidr_block.to_range
|
85
87
|
# Here we try to act like a DHCP server and pick the first
|
86
88
|
# available IP (not including the first in the cidr block,
|
87
89
|
# which is typically reserved for the gateway).
|
88
|
-
|
89
|
-
|
90
|
-
|
90
|
+
range = range.drop(2)[0..-2] if cidr_block.ipv4?
|
91
|
+
|
92
|
+
range.each do |p_ip|
|
93
|
+
unless self.data[:network_interfaces].map{ |ni, ni_conf| ni_conf['privateIpAddress'] }.include?p_ip.to_s
|
91
94
|
options['PrivateIpAddress'] = p_ip.to_s
|
92
95
|
break
|
93
96
|
end
|
94
97
|
end
|
95
98
|
elsif self.data[:network_interfaces].map{ |ni,ni_conf| ni_conf['privateIpAddress'] }.include?options['PrivateIpAddress']
|
96
|
-
raise Fog::Compute::
|
99
|
+
raise Fog::AWS::Compute::Error.new('InUse => The specified address is already in use.')
|
97
100
|
end
|
98
101
|
|
99
102
|
data = {
|
@@ -1,6 +1,6 @@
|
|
1
1
|
module Fog
|
2
|
-
module
|
3
|
-
class
|
2
|
+
module AWS
|
3
|
+
class Compute
|
4
4
|
class Real
|
5
5
|
require 'fog/aws/parsers/compute/basic'
|
6
6
|
|
@@ -22,7 +22,7 @@ module Fog
|
|
22
22
|
'Action' => 'CreatePlacementGroup',
|
23
23
|
'GroupName' => name,
|
24
24
|
'Strategy' => strategy,
|
25
|
-
:parser => Fog::Parsers::Compute::
|
25
|
+
:parser => Fog::Parsers::AWS::Compute::Basic.new
|
26
26
|
)
|
27
27
|
end
|
28
28
|
end
|