fog-aws 3.5.2 → 3.19.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +485 -22
- data/LICENSE.md +1 -1
- data/README.md +117 -7
- data/fog-aws.gemspec +8 -8
- data/lib/fog/aws/compute.rb +6 -3
- data/lib/fog/aws/credential_fetcher.rb +75 -7
- data/lib/fog/aws/elasticache.rb +4 -2
- data/lib/fog/aws/elb.rb +1 -1
- data/lib/fog/aws/elbv2.rb +72 -0
- data/lib/fog/aws/kinesis.rb +23 -15
- data/lib/fog/aws/models/compute/flavors.rb +2563 -521
- data/lib/fog/aws/models/compute/security_group.rb +13 -5
- data/lib/fog/aws/models/compute/server.rb +6 -2
- data/lib/fog/aws/models/compute/servers.rb +2 -0
- data/lib/fog/aws/models/compute/snapshot.rb +7 -6
- data/lib/fog/aws/models/compute/vpc.rb +8 -2
- data/lib/fog/aws/models/storage/directories.rb +1 -0
- data/lib/fog/aws/models/storage/directory.rb +0 -1
- data/lib/fog/aws/models/storage/file.rb +164 -20
- data/lib/fog/aws/models/storage/files.rb +32 -2
- data/lib/fog/aws/parsers/compute/create_snapshot.rb +1 -1
- data/lib/fog/aws/parsers/compute/create_subnet.rb +33 -6
- data/lib/fog/aws/parsers/compute/describe_security_groups.rb +18 -4
- data/lib/fog/aws/parsers/compute/describe_subnets.rb +33 -6
- data/lib/fog/aws/parsers/dns/create_hosted_zone.rb +1 -1
- data/lib/fog/aws/parsers/dns/get_hosted_zone.rb +3 -3
- data/lib/fog/aws/parsers/dns/list_hosted_zones.rb +3 -1
- 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/policy_version.rb +1 -1
- data/lib/fog/aws/parsers/storage/get_object_tagging.rb +33 -0
- 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/requests/compute/authorize_security_group_ingress.rb +15 -0
- data/lib/fog/aws/requests/compute/create_network_interface.rb +7 -4
- data/lib/fog/aws/requests/compute/create_subnet.rb +3 -3
- data/lib/fog/aws/requests/compute/create_vpc.rb +2 -2
- data/lib/fog/aws/requests/compute/describe_security_groups.rb +2 -0
- data/lib/fog/aws/requests/compute/request_spot_instances.rb +1 -1
- data/lib/fog/aws/requests/compute/run_instances.rb +64 -0
- data/lib/fog/aws/requests/compute/stop_instances.rb +11 -3
- 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/rds/add_tags_to_resource.rb +12 -10
- data/lib/fog/aws/requests/rds/list_tags_for_resource.rb +10 -7
- data/lib/fog/aws/requests/rds/remove_tags_from_resource.rb +9 -8
- data/lib/fog/aws/requests/storage/delete_multiple_objects.rb +18 -8
- data/lib/fog/aws/requests/storage/get_object.rb +1 -1
- data/lib/fog/aws/requests/storage/get_object_tagging.rb +41 -0
- data/lib/fog/aws/requests/storage/get_service.rb +1 -1
- data/lib/fog/aws/requests/storage/put_object_tagging.rb +42 -0
- data/lib/fog/aws/requests/storage/shared_mock_methods.rb +1 -0
- data/lib/fog/aws/requests/storage/sync_clock.rb +9 -1
- data/lib/fog/aws/requests/storage/upload_part_copy.rb +119 -0
- data/lib/fog/aws/requests/sts/assume_role_with_web_identity.rb +7 -6
- data/lib/fog/aws/storage.rb +56 -5
- data/lib/fog/aws/version.rb +1 -1
- data/lib/fog/aws.rb +7 -2
- metadata +35 -295
- data/.gitignore +0 -16
- data/.travis.yml +0 -53
- data/Gemfile +0 -14
- data/Rakefile +0 -14
- data/gemfiles/Gemfile-edge +0 -14
- data/gemfiles/Gemfile-ruby-2.0 +0 -7
- data/stale.yml +0 -17
- data/tests/credentials_tests.rb +0 -87
- data/tests/helper.rb +0 -29
- data/tests/helpers/collection_helper.rb +0 -90
- data/tests/helpers/compute/flavors_helper.rb +0 -28
- data/tests/helpers/compute/server_helper.rb +0 -23
- data/tests/helpers/compute/servers_helper.rb +0 -8
- data/tests/helpers/dns_helper.rb +0 -56
- data/tests/helpers/formats_helper.rb +0 -100
- data/tests/helpers/formats_helper_tests.rb +0 -107
- data/tests/helpers/mock_helper.rb +0 -109
- data/tests/helpers/model_helper.rb +0 -30
- data/tests/helpers/responds_to_helper.rb +0 -11
- data/tests/helpers/schema_validator_tests.rb +0 -104
- 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 -43
- 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 -98
- 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 -13
- data/tests/models/compute/subnets_tests.rb +0 -5
- data/tests/models/compute/volume_tests.rb +0 -65
- data/tests/models/compute/volumes_tests.rb +0 -5
- data/tests/models/compute/vpc_tests.rb +0 -26
- 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/efs/file_system_tests.rb +0 -12
- data/tests/models/efs/mount_target_tests.rb +0 -45
- data/tests/models/efs/mount_targets_tests.rb +0 -30
- 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 -43
- 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/instance_profile_tests.rb +0 -18
- data/tests/models/iam/managed_policies_tests.rb +0 -89
- 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 -77
- 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 -129
- data/tests/models/storage/files_tests.rb +0 -58
- data/tests/models/storage/url_tests.rb +0 -25
- data/tests/models/storage/version_tests.rb +0 -52
- data/tests/models/storage/versions_tests.rb +0 -51
- data/tests/models/support/trusted_advisor_tests.rb +0 -25
- data/tests/parsers/compute/describe_images_tests.rb +0 -33
- data/tests/parsers/elb/describe_load_balancers.rb +0 -65
- data/tests/requests/auto_scaling/auto_scaling_tests.rb +0 -111
- data/tests/requests/auto_scaling/describe_types_tests.rb +0 -102
- data/tests/requests/auto_scaling/helper.rb +0 -229
- data/tests/requests/auto_scaling/model_tests.rb +0 -235
- 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 -144
- 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 -27
- data/tests/requests/compute/image_tests.rb +0 -169
- 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 -239
- 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 -341
- 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 -55
- data/tests/requests/compute/spot_price_history_tests.rb +0 -23
- data/tests/requests/compute/subnet_tests.rb +0 -87
- data/tests/requests/compute/tag_tests.rb +0 -101
- data/tests/requests/compute/volume_tests.rb +0 -263
- data/tests/requests/compute/vpc_tests.rb +0 -216
- data/tests/requests/data_pipeline/helper.rb +0 -78
- data/tests/requests/data_pipeline/pipeline_tests.rb +0 -80
- data/tests/requests/dns/change_resource_record_sets_tests.rb +0 -34
- data/tests/requests/dns/dns_tests.rb +0 -240
- 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/efs/file_system_tests.rb +0 -152
- data/tests/requests/efs/helper.rb +0 -44
- 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 -91
- 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 -154
- data/tests/requests/iam/instance_profile_tests.rb +0 -44
- data/tests/requests/iam/login_profile_tests.rb +0 -62
- data/tests/requests/iam/managed_policy_tests.rb +0 -110
- 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 -105
- 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 -406
- data/tests/requests/rds/instance_option_tests.rb +0 -27
- 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 -262
- data/tests/requests/storage/versioning_tests.rb +0 -262
- 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 -28
- data/tests/requests/sts/get_federation_token_tests.rb +0 -20
- data/tests/requests/sts/session_token_tests.rb +0 -16
- data/tests/requests/support/helper.rb +0 -43
- data/tests/requests/support/trusted_advisor_check_tests.rb +0 -16
- data/tests/signaturev4_tests.rb +0 -106
- data/tests/signed_params_tests.rb +0 -17
- data/tests/storage_tests.rb +0 -7
@@ -16,7 +16,7 @@ module Fog
|
|
16
16
|
case name
|
17
17
|
when 'Id'
|
18
18
|
@hosted_zone[name] = value.sub('/hostedzone/', '')
|
19
|
-
when 'Name', 'CallerReference', 'Comment'
|
19
|
+
when 'Name', 'CallerReference', 'Comment', 'PrivateZone'
|
20
20
|
@hosted_zone[name]= value
|
21
21
|
when 'HostedZone'
|
22
22
|
@response['HostedZone'] = @hosted_zone
|
@@ -17,14 +17,14 @@ module Fog
|
|
17
17
|
case name
|
18
18
|
when 'Id'
|
19
19
|
@hosted_zone[name]= value.sub('/hostedzone/', '')
|
20
|
-
when 'Name', 'CallerReference', 'Comment', 'PrivateZone', 'Config'
|
20
|
+
when 'Name', 'CallerReference', 'Comment', 'PrivateZone', 'Config'
|
21
21
|
@hosted_zone[name]= value
|
22
|
+
when 'ResourceRecordSetCount'
|
23
|
+
@hosted_zone['ResourceRecordSetCount'] = value.to_i
|
22
24
|
when 'HostedZone'
|
23
25
|
@response['HostedZone'] = @hosted_zone
|
24
26
|
@hosted_zone = {}
|
25
27
|
@section = :name_servers
|
26
|
-
when 'ResourceRecordSetCount'
|
27
|
-
@response['ResourceRecordSetCount'] = value.to_i
|
28
28
|
end
|
29
29
|
elsif @section == :name_servers
|
30
30
|
case name
|
@@ -13,8 +13,10 @@ module Fog
|
|
13
13
|
case name
|
14
14
|
when 'Id'
|
15
15
|
@zone[name] = value.sub('/hostedzone/', '')
|
16
|
-
when 'Name', 'CallerReference', 'Comment'
|
16
|
+
when 'Name', 'CallerReference', 'Comment', 'PrivateZone'
|
17
17
|
@zone[name] = value
|
18
|
+
when 'ResourceRecordSetCount'
|
19
|
+
@zone['ResourceRecordSetCount'] = value.to_i
|
18
20
|
when 'HostedZone'
|
19
21
|
@hosted_zones << @zone
|
20
22
|
@zone = {}
|
@@ -0,0 +1,88 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module ELBV2
|
5
|
+
class CreateLoadBalancer < Fog::Parsers::Base
|
6
|
+
def reset
|
7
|
+
reset_load_balancer
|
8
|
+
reset_availability_zone
|
9
|
+
@load_balancer_addresses = {}
|
10
|
+
@state = {}
|
11
|
+
@results = { 'LoadBalancers' => [] }
|
12
|
+
@response = { 'CreateLoadBalancerResult' => {}, 'ResponseMetadata' => {} }
|
13
|
+
end
|
14
|
+
|
15
|
+
def reset_load_balancer
|
16
|
+
@load_balancer = { 'SecurityGroups' => [], 'AvailabilityZones' => [] }
|
17
|
+
end
|
18
|
+
|
19
|
+
def reset_availability_zone
|
20
|
+
@availability_zone = { 'LoadBalancerAddresses' => [] }
|
21
|
+
end
|
22
|
+
|
23
|
+
def start_element(name, attrs = [])
|
24
|
+
super
|
25
|
+
case name
|
26
|
+
when 'AvailabilityZones'
|
27
|
+
@in_availability_zones = true
|
28
|
+
when 'LoadBalancerAddresses'
|
29
|
+
@in_load_balancer_addresses = true
|
30
|
+
when 'SecurityGroups'
|
31
|
+
@in_security_groups = true
|
32
|
+
when 'State'
|
33
|
+
@in_state = true
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
def end_element(name)
|
38
|
+
case name
|
39
|
+
when 'member'
|
40
|
+
if @in_availability_zones && @in_load_balancer_addresses
|
41
|
+
@availability_zone['LoadBalancerAddresses'] << @load_balancer_addresses
|
42
|
+
elsif @in_availability_zones
|
43
|
+
@load_balancer['AvailabilityZones'] << @availability_zone
|
44
|
+
reset_availability_zone
|
45
|
+
elsif @in_security_groups
|
46
|
+
@load_balancer['SecurityGroups'] << value
|
47
|
+
else
|
48
|
+
@results['LoadBalancers'] << @load_balancer
|
49
|
+
reset_load_balancer
|
50
|
+
end
|
51
|
+
when 'SubnetId', 'ZoneName'
|
52
|
+
@availability_zone[name] = value
|
53
|
+
when 'IpAddress', 'AllocationId'
|
54
|
+
@load_balancer_addresses[name] = value
|
55
|
+
|
56
|
+
when 'CanonicalHostedZoneName', 'CanonicalHostedZoneNameID', 'LoadBalancerName', 'DNSName', 'Scheme', 'Type',
|
57
|
+
'LoadBalancerArn', 'IpAddressType', 'CanonicalHostedZoneId', 'VpcId'
|
58
|
+
@load_balancer[name] = value
|
59
|
+
when 'CreatedTime'
|
60
|
+
@load_balancer[name] = Time.parse(value)
|
61
|
+
|
62
|
+
when 'LoadBalancerAddresses'
|
63
|
+
@in_load_balancer_addresses = false
|
64
|
+
when 'AvailabilityZones'
|
65
|
+
@in_availability_zones = false
|
66
|
+
when 'SecurityGroups'
|
67
|
+
@in_security_groups = false
|
68
|
+
when 'State'
|
69
|
+
@in_state = false
|
70
|
+
@load_balancer[name] = @state
|
71
|
+
@state = {}
|
72
|
+
when 'Code'
|
73
|
+
@state[name] = value
|
74
|
+
|
75
|
+
when 'RequestId'
|
76
|
+
@response['ResponseMetadata'][name] = value
|
77
|
+
|
78
|
+
when 'NextMarker'
|
79
|
+
@results['NextMarker'] = value
|
80
|
+
when 'CreateLoadBalancerResponse'
|
81
|
+
@response['CreateLoadBalancerResult'] = @results
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
@@ -0,0 +1,110 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module ELBV2
|
5
|
+
class DescribeListeners < Fog::Parsers::Base
|
6
|
+
def reset
|
7
|
+
reset_listener
|
8
|
+
@default_action = {}
|
9
|
+
@certificate = {}
|
10
|
+
@config = {}
|
11
|
+
@target_groups = []
|
12
|
+
@target_group = {}
|
13
|
+
@target_group_stickiness_config = {}
|
14
|
+
@results = { 'Listeners' => [] }
|
15
|
+
@response = { 'DescribeListenersResult' => {}, 'ResponseMetadata' => {} }
|
16
|
+
end
|
17
|
+
|
18
|
+
def reset_listener
|
19
|
+
@listener= { 'DefaultActions' => [], 'Certificates' => [] }
|
20
|
+
end
|
21
|
+
|
22
|
+
def start_element(name, attrs = [])
|
23
|
+
super
|
24
|
+
case name
|
25
|
+
when 'DefaultActions'
|
26
|
+
@in_default_actions = true
|
27
|
+
when 'Certificates'
|
28
|
+
@in_certificates = true
|
29
|
+
when 'TargetGroups'
|
30
|
+
@in_target_groups = true
|
31
|
+
when 'TargetGroupStickinessConfig'
|
32
|
+
@in_target_group_stickiness_config = true
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def end_element(name)
|
37
|
+
if @in_default_actions
|
38
|
+
case name
|
39
|
+
when 'member'
|
40
|
+
if @in_target_groups
|
41
|
+
@target_groups << @target_group
|
42
|
+
@target_group = {}
|
43
|
+
else
|
44
|
+
@listener['DefaultActions'] << @default_action
|
45
|
+
@default_action = {}
|
46
|
+
end
|
47
|
+
when 'TargetGroupArn'
|
48
|
+
if @in_target_groups
|
49
|
+
@target_group[name] = value
|
50
|
+
else
|
51
|
+
@default_action[name] = value
|
52
|
+
end
|
53
|
+
when 'Weight'
|
54
|
+
@target_group[name] = value
|
55
|
+
when 'Type', 'Order'
|
56
|
+
@default_action[name] = value
|
57
|
+
when 'Path', 'Protocol', 'Port', 'Query', 'Host', 'StatusCode', 'ContentType',
|
58
|
+
'MessageBody', 'StatusCode'
|
59
|
+
@config[name] = value
|
60
|
+
when 'RedirectConfig', 'ForwardConfig', 'FixedResponseConfig'
|
61
|
+
@default_action[name] = @config
|
62
|
+
@config = {}
|
63
|
+
when 'DurationSeconds', 'Enabled'
|
64
|
+
@target_group_stickiness_config[name] = value
|
65
|
+
when 'DefaultActions'
|
66
|
+
@in_default_actions = false
|
67
|
+
when 'TargetGroupStickinessConfig'
|
68
|
+
if @in_target_group_stickiness_config
|
69
|
+
@config['TargetGroupStickinessConfig'] = @target_group_stickiness_config
|
70
|
+
@in_target_group_stickiness_config = false
|
71
|
+
@target_group_stickiness_config = {}
|
72
|
+
end
|
73
|
+
when 'TargetGroups'
|
74
|
+
@config['TargetGroups'] = @target_groups
|
75
|
+
@in_target_groups = false
|
76
|
+
@target_groups = []
|
77
|
+
end
|
78
|
+
else
|
79
|
+
case name
|
80
|
+
when 'member'
|
81
|
+
if @in_certificates
|
82
|
+
@listener['Certificates'] << @certificate
|
83
|
+
@certificate = {}
|
84
|
+
else
|
85
|
+
@results['Listeners'] << @listener
|
86
|
+
reset_listener
|
87
|
+
end
|
88
|
+
when 'LoadBalancerArn', 'Protocol', 'Port', 'ListenerArn', 'SslPolicy'
|
89
|
+
@listener[name] = value
|
90
|
+
when 'CertificateArn'
|
91
|
+
@certificate[name] = value
|
92
|
+
when 'Certificates'
|
93
|
+
@in_certificates = false
|
94
|
+
|
95
|
+
when 'RequestId'
|
96
|
+
@response['ResponseMetadata'][name] = value
|
97
|
+
|
98
|
+
when 'NextMarker'
|
99
|
+
@results['NextMarker'] = value
|
100
|
+
|
101
|
+
when 'DescribeListenersResponse'
|
102
|
+
@response['DescribeListenersResult'] = @results
|
103
|
+
end
|
104
|
+
end
|
105
|
+
end
|
106
|
+
end
|
107
|
+
end
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
@@ -0,0 +1,88 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module ELBV2
|
5
|
+
class DescribeLoadBalancers < Fog::Parsers::Base
|
6
|
+
def reset
|
7
|
+
reset_load_balancer
|
8
|
+
reset_availability_zone
|
9
|
+
@load_balancer_addresses = {}
|
10
|
+
@state = {}
|
11
|
+
@results = { 'LoadBalancers' => [] }
|
12
|
+
@response = { 'DescribeLoadBalancersResult' => {}, 'ResponseMetadata' => {} }
|
13
|
+
end
|
14
|
+
|
15
|
+
def reset_load_balancer
|
16
|
+
@load_balancer = { 'SecurityGroups' => [], 'AvailabilityZones' => [] }
|
17
|
+
end
|
18
|
+
|
19
|
+
def reset_availability_zone
|
20
|
+
@availability_zone = { 'LoadBalancerAddresses' => [] }
|
21
|
+
end
|
22
|
+
|
23
|
+
def start_element(name, attrs = [])
|
24
|
+
super
|
25
|
+
case name
|
26
|
+
when 'AvailabilityZones'
|
27
|
+
@in_availability_zones = true
|
28
|
+
when 'LoadBalancerAddresses'
|
29
|
+
@in_load_balancer_addresses = true
|
30
|
+
when 'SecurityGroups'
|
31
|
+
@in_security_groups = true
|
32
|
+
when 'State'
|
33
|
+
@in_state = true
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
def end_element(name)
|
38
|
+
case name
|
39
|
+
when 'member'
|
40
|
+
if @in_availability_zones && @in_load_balancer_addresses
|
41
|
+
@availability_zone['LoadBalancerAddresses'] << @load_balancer_addresses
|
42
|
+
elsif @in_availability_zones
|
43
|
+
@load_balancer['AvailabilityZones'] << @availability_zone
|
44
|
+
reset_availability_zone
|
45
|
+
elsif @in_security_groups
|
46
|
+
@load_balancer['SecurityGroups'] << value
|
47
|
+
else
|
48
|
+
@results['LoadBalancers'] << @load_balancer
|
49
|
+
reset_load_balancer
|
50
|
+
end
|
51
|
+
when 'SubnetId', 'ZoneName'
|
52
|
+
@availability_zone[name] = value
|
53
|
+
when 'IpAddress', 'AllocationId'
|
54
|
+
@load_balancer_addresses[name] = value
|
55
|
+
|
56
|
+
when 'CanonicalHostedZoneName', 'CanonicalHostedZoneNameID', 'LoadBalancerName', 'DNSName', 'Scheme', 'Type',
|
57
|
+
'LoadBalancerArn', 'IpAddressType', 'CanonicalHostedZoneId', 'VpcId'
|
58
|
+
@load_balancer[name] = value
|
59
|
+
when 'CreatedTime'
|
60
|
+
@load_balancer[name] = Time.parse(value)
|
61
|
+
|
62
|
+
when 'LoadBalancerAddresses'
|
63
|
+
@in_load_balancer_addresses = false
|
64
|
+
when 'AvailabilityZones'
|
65
|
+
@in_availability_zones = false
|
66
|
+
when 'SecurityGroups'
|
67
|
+
@in_security_groups = false
|
68
|
+
when 'State'
|
69
|
+
@in_state = false
|
70
|
+
@load_balancer[name] = @state
|
71
|
+
@state = {}
|
72
|
+
when 'Code'
|
73
|
+
@state[name] = value
|
74
|
+
|
75
|
+
when 'RequestId'
|
76
|
+
@response['ResponseMetadata'][name] = value
|
77
|
+
|
78
|
+
when 'NextMarker'
|
79
|
+
@results['NextMarker'] = value
|
80
|
+
when 'DescribeLoadBalancersResponse'
|
81
|
+
@response['DescribeLoadBalancersResult'] = @results
|
82
|
+
end
|
83
|
+
end
|
84
|
+
end
|
85
|
+
end
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module ELBV2
|
5
|
+
class DescribeTags < Fog::Parsers::Base
|
6
|
+
def reset
|
7
|
+
@this_key = nil
|
8
|
+
@this_value = nil
|
9
|
+
@tags = Hash.new
|
10
|
+
@response = { 'DescribeTagsResult' => { 'TagDescriptions' => [] }, 'ResponseMetadata' => {} }
|
11
|
+
@in_tags = false
|
12
|
+
end
|
13
|
+
|
14
|
+
def start_element(name, attrs = [])
|
15
|
+
super
|
16
|
+
case name
|
17
|
+
when 'member'
|
18
|
+
unless @in_tags
|
19
|
+
@resource_arn = nil
|
20
|
+
@tags = {}
|
21
|
+
end
|
22
|
+
when 'Tags'
|
23
|
+
@in_tags = true
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def end_element(name)
|
28
|
+
super
|
29
|
+
case name
|
30
|
+
when 'member'
|
31
|
+
if @in_tags
|
32
|
+
@tags[@this_key] = @this_value
|
33
|
+
@this_key, @this_value = nil, nil
|
34
|
+
else
|
35
|
+
@response['DescribeTagsResult']['TagDescriptions'] << { 'Tags' => @tags, 'ResourceArn' => @resource_arn }
|
36
|
+
end
|
37
|
+
when 'Key'
|
38
|
+
@this_key = value
|
39
|
+
when 'Value'
|
40
|
+
@this_value = value
|
41
|
+
when 'ResourceArn'
|
42
|
+
@resource_arn = value
|
43
|
+
when 'RequestId'
|
44
|
+
@response['ResponseMetadata'][name] = value
|
45
|
+
when 'Tags'
|
46
|
+
@in_tags = false
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
53
|
+
end
|
@@ -14,7 +14,7 @@ module Fog
|
|
14
14
|
when 'GroupName', 'PolicyName'
|
15
15
|
@response[name] = value
|
16
16
|
when 'PolicyDocument'
|
17
|
-
@response['Policy'][name] = if decoded_string = URI.
|
17
|
+
@response['Policy'][name] = if decoded_string = URI.decode_www_form_component(value)
|
18
18
|
Fog::JSON.decode(decoded_string) rescue value
|
19
19
|
else
|
20
20
|
value
|
@@ -12,7 +12,7 @@ module Fog
|
|
12
12
|
when 'RoleName', 'PolicyName'
|
13
13
|
@response['Policy'][name] = value
|
14
14
|
when 'PolicyDocument'
|
15
|
-
@response['Policy'][name] = if decoded_string = URI.
|
15
|
+
@response['Policy'][name] = if decoded_string = URI.decode_www_form_component(value)
|
16
16
|
Fog::JSON.decode(decoded_string) rescue value
|
17
17
|
else
|
18
18
|
value
|
@@ -14,7 +14,7 @@ module Fog
|
|
14
14
|
when 'UserName', 'PolicyName'
|
15
15
|
@response['Policy'][name] = value
|
16
16
|
when 'PolicyDocument'
|
17
|
-
@response['Policy'][name] = if decoded_string = URI.
|
17
|
+
@response['Policy'][name] = if decoded_string = URI.decode_www_form_component(value)
|
18
18
|
Fog::JSON.decode(decoded_string) rescue value
|
19
19
|
else
|
20
20
|
value
|
@@ -18,7 +18,7 @@ module Fog
|
|
18
18
|
when 'IsDefaultVersion'
|
19
19
|
@version[name] = (value == 'true')
|
20
20
|
when 'Document'
|
21
|
-
@version[name] = if decoded_string = URI.
|
21
|
+
@version[name] = if decoded_string = URI.decode_www_form_component(value)
|
22
22
|
Fog::JSON.decode(decoded_string) rescue value
|
23
23
|
else
|
24
24
|
value
|
@@ -0,0 +1,33 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module Storage
|
5
|
+
class GetObjectTagging < Fog::Parsers::Base
|
6
|
+
def reset
|
7
|
+
@in_tag = {}
|
8
|
+
@response = {'ObjectTagging' => {}}
|
9
|
+
end
|
10
|
+
|
11
|
+
def start_element(name, *args)
|
12
|
+
super
|
13
|
+
if name == 'Tag'
|
14
|
+
@in_tag = {}
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
def end_element(name)
|
19
|
+
case name
|
20
|
+
when 'Tag'
|
21
|
+
@response['ObjectTagging'].merge!(@in_tag)
|
22
|
+
@in_tag = {}
|
23
|
+
when 'Key'
|
24
|
+
@in_tag[value] = nil
|
25
|
+
when 'Value'
|
26
|
+
@in_tag = {@in_tag.keys.first => value}
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
module Fog
|
2
|
+
module Parsers
|
3
|
+
module AWS
|
4
|
+
module Storage
|
5
|
+
class UploadPartCopyObject < Fog::Parsers::Base
|
6
|
+
def end_element(name)
|
7
|
+
case name
|
8
|
+
when 'ETag'
|
9
|
+
@response[name] = value.gsub('"', '')
|
10
|
+
when 'LastModified'
|
11
|
+
@response[name] = Time.parse(value)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
@@ -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
|
@@ -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
|
@@ -186,6 +193,14 @@ module Fog
|
|
186
193
|
'groups' => [],
|
187
194
|
'ipRanges' => [{'cidrIp' => options['CidrIp']}]
|
188
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
|
+
}
|
189
204
|
elsif options['IpPermissions']
|
190
205
|
options['IpPermissions'].each do |permission|
|
191
206
|
|
@@ -2,6 +2,7 @@ module Fog
|
|
2
2
|
module AWS
|
3
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
|
@@ -68,7 +69,7 @@ module Fog
|
|
68
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']
|
@@ -82,12 +83,14 @@ module Fog
|
|
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
|
@@ -2,7 +2,7 @@ module Fog
|
|
2
2
|
module AWS
|
3
3
|
class Compute
|
4
4
|
class Real
|
5
|
-
require '
|
5
|
+
require 'ipaddr'
|
6
6
|
require 'fog/aws/parsers/compute/create_subnet'
|
7
7
|
|
8
8
|
# Creates a Subnet with the CIDR block you specify.
|
@@ -50,11 +50,11 @@ module Fog
|
|
50
50
|
if vpc.nil?
|
51
51
|
raise Fog::AWS::Compute::NotFound.new("The vpc ID '#{vpcId}' does not exist")
|
52
52
|
end
|
53
|
-
if ! ::
|
53
|
+
if ! ::IPAddr.new(vpc['cidrBlock']).include?(::IPAddr.new(cidrBlock))
|
54
54
|
raise Fog::AWS::Compute::Error.new("Range => The CIDR '#{cidrBlock}' is invalid.")
|
55
55
|
end
|
56
56
|
self.data[:subnets].select{ |s| s['vpcId'] == vpcId }.each do |subnet|
|
57
|
-
if ::
|
57
|
+
if ::IPAddr.new(subnet['cidrBlock']).include?(::IPAddr.new(cidrBlock))
|
58
58
|
raise Fog::AWS::Compute::Error.new("Conflict => The CIDR '#{cidrBlock}' conflicts with another subnet")
|
59
59
|
end
|
60
60
|
end
|
@@ -11,7 +11,6 @@ module Fog
|
|
11
11
|
# * options<~Hash>:
|
12
12
|
# * InstanceTenancy<~String> - The allowed tenancy of instances launched into the VPC. A value of default
|
13
13
|
# means instances can be launched with any tenancy; a value of dedicated means instances must be launched with tenancy as dedicated.
|
14
|
-
# please not that the documentation is incorrect instanceTenancy will not work while InstanceTenancy will
|
15
14
|
#
|
16
15
|
# === Returns
|
17
16
|
# * response<~Excon::Response>:
|
@@ -54,7 +53,8 @@ module Fog
|
|
54
53
|
'classicLinkEnabled' => false,
|
55
54
|
'classicLinkDnsSupport' => false,
|
56
55
|
'cidrBlockAssociationSet' => [{ 'cidrBlock' => cidrBlock, 'state' => 'associated', 'associationId' => "vpc-cidr-assoc-#{vpc_id}" }],
|
57
|
-
'ipv6CidrBlockAssociationSet' => []
|
56
|
+
'ipv6CidrBlockAssociationSet' => [],
|
57
|
+
'instanceTenancy' => options['InstanceTenancy'] || 'default'
|
58
58
|
}
|
59
59
|
self.data[:vpcs].push(vpc)
|
60
60
|
|
@@ -27,6 +27,8 @@ module Fog
|
|
27
27
|
# * 'ipProtocol'<~String> - Ip protocol, must be in ['tcp', 'udp', 'icmp']
|
28
28
|
# * 'ipRanges'<~Array>:
|
29
29
|
# * 'cidrIp'<~String> - CIDR range
|
30
|
+
# * 'ipv6Ranges'<~Array>:
|
31
|
+
# * 'cidrIpv6'<~String> - CIDR ipv6 range
|
30
32
|
# * 'toPort'<~Integer> - End of port range (or -1 for ICMP wildcard)
|
31
33
|
# * 'ownerId'<~String> - AWS Access Key Id of the owner of the security group
|
32
34
|
# * 'NextToken'<~String> - The token to retrieve the next page of results
|
@@ -113,7 +113,7 @@ module Fog
|
|
113
113
|
raise Fog::AWS::Compute::Error.new(message)
|
114
114
|
end
|
115
115
|
|
116
|
-
if !image_id.match(/^ami-[a-f0-9]{8}$/)
|
116
|
+
if !image_id.match(/^ami-[a-f0-9]{8,17}$/)
|
117
117
|
message = "The image id '[#{image_id}]' does not exist"
|
118
118
|
raise Fog::AWS::Compute::NotFound.new(message)
|
119
119
|
end
|