aws-sdk-ec2 1.0.0.rc1 → 1.0.0.rc2

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: ee68b7ea375882c54d66df836c9383dc89763183
4
- data.tar.gz: fd72a214171c3ef6982778b20320bbb99f39e9e3
3
+ metadata.gz: 3268390c4ed00ae3574651c937b3e3780752f78c
4
+ data.tar.gz: ec5f48bfb8362b1edc94989e67ed44b167223811
5
5
  SHA512:
6
- metadata.gz: dbd0f9429f174c52e5b2a470b48c8529bb2cb63ad518b83166f021e64b5585549292de9fd13b6db0bc8b37c06d8fd7512eb71d1eb7966a55dae39ff5eb5e01a0
7
- data.tar.gz: b769b3e5947f032ebf973aed4039f52a052a2ac086bb746375290e30df9deb4338ddf1e4e01671b10d493a012dd9d41e83c6ea64478b52ca967d7cb329b8518f
6
+ metadata.gz: d60d3f7dc9d83e632cb697e2d1e18e7c2be1b0107207ecf64fabf4eca2642dc41366c489904c4674577d328cef4be45015612e2b88e61f8613d424f8aa5aaf2f
7
+ data.tar.gz: 0a6c1e1e54635078f35484a1f2b54553890e29f7cf34cf9b4f20e163cf00a0eb864db0e895affa7fe0f8a299ed8d66d20dd762f6ecfecff6ca212d1694e5e46c
@@ -65,6 +65,6 @@ require_relative 'aws-sdk-ec2/customizations'
65
65
  # @service
66
66
  module Aws::EC2
67
67
 
68
- GEM_VERSION = '1.0.0.rc1'
68
+ GEM_VERSION = '1.0.0.rc2'
69
69
 
70
70
  end
@@ -134,20 +134,19 @@ module Aws
134
134
 
135
135
  # @!group API Operations
136
136
 
137
- # Purchases Convertible Reserved Instance offerings described in the
138
- # GetReservedInstancesExchangeQuote call.
137
+ # Accepts the Convertible Reserved Instance exchange quote described in
138
+ # the GetReservedInstancesExchangeQuote call.
139
139
  # @option params [Boolean] :dry_run
140
140
  # Checks whether you have the required permissions for the action,
141
141
  # without actually making the request, and provides an error response.
142
142
  # If you have the required permissions, the error response is
143
143
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
144
144
  # @option params [required, Array<String>] :reserved_instance_ids
145
- # The IDs of the Convertible Reserved Instances that you want to
146
- # exchange for other Convertible Reserved Instances of the same or
147
- # higher value.
145
+ # The IDs of the Convertible Reserved Instances to exchange for other
146
+ # Convertible Reserved Instances of the same or higher value.
148
147
  # @option params [Array<Types::TargetConfigurationRequest>] :target_configurations
149
- # The configurations of the Convertible Reserved Instance offerings you
150
- # are purchasing in this exchange.
148
+ # The configurations of the Convertible Reserved Instance offerings that
149
+ # you are purchasing in this exchange.
151
150
  # @return [Types::AcceptReservedInstancesExchangeQuoteResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
152
151
  #
153
152
  # * {Types::AcceptReservedInstancesExchangeQuoteResult#exchange_id #ExchangeId} => String
@@ -199,6 +198,8 @@ module Aws
199
198
  # resp.vpc_peering_connection.accepter_vpc_info.cidr_block #=> String
200
199
  # resp.vpc_peering_connection.accepter_vpc_info.owner_id #=> String
201
200
  # resp.vpc_peering_connection.accepter_vpc_info.vpc_id #=> String
201
+ # resp.vpc_peering_connection.accepter_vpc_info.ipv_6_cidr_block_set #=> Array
202
+ # resp.vpc_peering_connection.accepter_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
202
203
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
203
204
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
204
205
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -206,6 +207,8 @@ module Aws
206
207
  # resp.vpc_peering_connection.requester_vpc_info.cidr_block #=> String
207
208
  # resp.vpc_peering_connection.requester_vpc_info.owner_id #=> String
208
209
  # resp.vpc_peering_connection.requester_vpc_info.vpc_id #=> String
210
+ # resp.vpc_peering_connection.requester_vpc_info.ipv_6_cidr_block_set #=> Array
211
+ # resp.vpc_peering_connection.requester_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
209
212
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
210
213
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
211
214
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -312,6 +315,52 @@ module Aws
312
315
  req.send_request(options)
313
316
  end
314
317
 
318
+ # Assigns one or more IPv6 addresses to the specified network interface.
319
+ # You can specify one or more specific IPv6 addresses, or you can
320
+ # specify the number of IPv6 addresses to be automatically assigned from
321
+ # within the subnet's IPv6 CIDR block range. You can assign as many
322
+ # IPv6 addresses to a network interface as you can assign private IPv4
323
+ # addresses, and the limit varies per instance type. For information,
324
+ # see [IP Addresses Per Network Interface Per Instance Type][1] in the
325
+ # *Amazon Elastic Compute Cloud User Guide*.
326
+ #
327
+ #
328
+ #
329
+ # [1]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-eni.html#AvailableIpPerENI
330
+ # @option params [required, String] :network_interface_id
331
+ # The ID of the network interface.
332
+ # @option params [Array<String>] :ipv_6_addresses
333
+ # One or more specific IPv6 addresses to be assigned to the network
334
+ # interface. You can't use this option if you're specifying a number
335
+ # of IPv6 addresses.
336
+ # @option params [Integer] :ipv_6_address_count
337
+ # The number of IPv6 addresses to assign to the network interface.
338
+ # Amazon EC2 automatically selects the IPv6 addresses from the subnet
339
+ # range. You can't use this option if specifying specific IPv6
340
+ # addresses.
341
+ # @return [Types::AssignIpv6AddressesResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
342
+ #
343
+ # * {Types::AssignIpv6AddressesResult#network_interface_id #NetworkInterfaceId} => String
344
+ # * {Types::AssignIpv6AddressesResult#assigned_ipv_6_addresses #AssignedIpv6Addresses} => Array&lt;String&gt;
345
+ #
346
+ # @example Request syntax with placeholder values
347
+ # resp = client.assign_ipv_6_addresses({
348
+ # network_interface_id: "String", # required
349
+ # ipv_6_addresses: ["String"],
350
+ # ipv_6_address_count: 1,
351
+ # })
352
+ #
353
+ # @example Response structure
354
+ # resp.network_interface_id #=> String
355
+ # resp.assigned_ipv_6_addresses #=> Array
356
+ # resp.assigned_ipv_6_addresses[0] #=> String
357
+ # @overload assign_ipv_6_addresses(params = {})
358
+ # @param [Hash] params ({})
359
+ def assign_ipv_6_addresses(params = {}, options = {})
360
+ req = build_request(:assign_ipv_6_addresses, params)
361
+ req.send_request(options)
362
+ end
363
+
315
364
  # Assigns one or more secondary private IP addresses to the specified
316
365
  # network interface. You can specify one or more specific secondary IP
317
366
  # addresses, or you can specify the number of secondary IP addresses to
@@ -526,6 +575,71 @@ module Aws
526
575
  req.send_request(options)
527
576
  end
528
577
 
578
+ # Associates a CIDR block with your subnet. You can only associate a
579
+ # single IPv6 CIDR block with your subnet. An IPv6 CIDR block must have
580
+ # a prefix length of /64.
581
+ # @option params [required, String] :subnet_id
582
+ # The ID of your subnet.
583
+ # @option params [required, String] :ipv_6_cidr_block
584
+ # The IPv6 CIDR block for your subnet. The subnet must have a /64 prefix
585
+ # length.
586
+ # @return [Types::AssociateSubnetCidrBlockResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
587
+ #
588
+ # * {Types::AssociateSubnetCidrBlockResult#subnet_id #SubnetId} => String
589
+ # * {Types::AssociateSubnetCidrBlockResult#ipv_6_cidr_block_association #Ipv6CidrBlockAssociation} => Types::SubnetIpv6CidrBlockAssociation
590
+ #
591
+ # @example Request syntax with placeholder values
592
+ # resp = client.associate_subnet_cidr_block({
593
+ # subnet_id: "String", # required
594
+ # ipv_6_cidr_block: "String", # required
595
+ # })
596
+ #
597
+ # @example Response structure
598
+ # resp.subnet_id #=> String
599
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block #=> String
600
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
601
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.status_message #=> String
602
+ # resp.ipv_6_cidr_block_association.association_id #=> String
603
+ # @overload associate_subnet_cidr_block(params = {})
604
+ # @param [Hash] params ({})
605
+ def associate_subnet_cidr_block(params = {}, options = {})
606
+ req = build_request(:associate_subnet_cidr_block, params)
607
+ req.send_request(options)
608
+ end
609
+
610
+ # Associates a CIDR block with your VPC. You can only associate a single
611
+ # Amazon-provided IPv6 CIDR block with your VPC. The IPv6 CIDR block
612
+ # size is fixed at /56.
613
+ # @option params [required, String] :vpc_id
614
+ # The ID of the VPC.
615
+ # @option params [Boolean] :amazon_provided_ipv_6_cidr_block
616
+ # Requests an Amazon-provided IPv6 CIDR block with a /56 prefix length
617
+ # for the VPC. You cannot specify the range of IPv6 addresses, or the
618
+ # size of the CIDR block.
619
+ # @return [Types::AssociateVpcCidrBlockResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
620
+ #
621
+ # * {Types::AssociateVpcCidrBlockResult#vpc_id #VpcId} => String
622
+ # * {Types::AssociateVpcCidrBlockResult#ipv_6_cidr_block_association #Ipv6CidrBlockAssociation} => Types::VpcIpv6CidrBlockAssociation
623
+ #
624
+ # @example Request syntax with placeholder values
625
+ # resp = client.associate_vpc_cidr_block({
626
+ # vpc_id: "String", # required
627
+ # amazon_provided_ipv_6_cidr_block: false,
628
+ # })
629
+ #
630
+ # @example Response structure
631
+ # resp.vpc_id #=> String
632
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block #=> String
633
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
634
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.status_message #=> String
635
+ # resp.ipv_6_cidr_block_association.association_id #=> String
636
+ # @overload associate_vpc_cidr_block(params = {})
637
+ # @param [Hash] params ({})
638
+ def associate_vpc_cidr_block(params = {}, options = {})
639
+ req = build_request(:associate_vpc_cidr_block, params)
640
+ req.send_request(options)
641
+ end
642
+
529
643
  # Links an EC2-Classic instance to a ClassicLink-enabled VPC through one
530
644
  # or more of the VPC's security groups. You cannot link an EC2-Classic
531
645
  # instance to more than one VPC at a time. You can only link an instance
@@ -759,14 +873,12 @@ module Aws
759
873
 
760
874
  # \[EC2-VPC only\] Adds one or more egress rules to a security group for
761
875
  # use with a VPC. Specifically, this action permits instances to send
762
- # traffic to one or more destination CIDR IP address ranges, or to one
763
- # or more destination security groups for the same VPC. This action
764
- # doesn't apply to security groups for use in EC2-Classic. For more
765
- # information, see [Security Groups for Your VPC][1] in the *Amazon
766
- # Virtual Private Cloud User Guide*.
767
- #
768
- # You can have up to 50 rules per security group (covering both ingress
769
- # and egress rules).
876
+ # traffic to one or more destination IPv4 or IPv6 CIDR address ranges,
877
+ # or to one or more destination security groups for the same VPC. This
878
+ # action doesn't apply to security groups for use in EC2-Classic. For
879
+ # more information, see [Security Groups for Your VPC][1] in the *Amazon
880
+ # Virtual Private Cloud User Guide*. For more information about security
881
+ # group limits, see [Amazon VPC Limits][2].
770
882
  #
771
883
  # Each rule consists of the protocol (for example, TCP), plus either a
772
884
  # CIDR range or a source group. For the TCP and UDP protocols, you must
@@ -780,6 +892,7 @@ module Aws
780
892
  #
781
893
  #
782
894
  # [1]: http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_SecurityGroups.html
895
+ # [2]: http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Appendix_Limits.html
783
896
  # @option params [Boolean] :dry_run
784
897
  # Checks whether you have the required permissions for the action,
785
898
  # without actually making the request, and provides an error response.
@@ -807,7 +920,7 @@ module Aws
807
920
  # number. We recommend that you specify the port range in a set of IP
808
921
  # permissions instead.
809
922
  # @option params [String] :cidr_ip
810
- # The CIDR IP address range. We recommend that you specify the CIDR
923
+ # The CIDR IPv4 address range. We recommend that you specify the CIDR
811
924
  # range in a set of IP permissions instead.
812
925
  # @option params [Array<Types::IpPermission>] :ip_permissions
813
926
  # A set of IP permissions. You can't specify a destination security
@@ -844,6 +957,11 @@ module Aws
844
957
  # cidr_ip: "String",
845
958
  # },
846
959
  # ],
960
+ # ipv_6_ranges: [
961
+ # {
962
+ # cidr_ipv_6: "String",
963
+ # },
964
+ # ],
847
965
  # prefix_list_ids: [
848
966
  # {
849
967
  # prefix_list_id: "String",
@@ -861,25 +979,26 @@ module Aws
861
979
 
862
980
  # Adds one or more ingress rules to a security group.
863
981
  #
864
- # EC2-Classic: You can have up to 100 rules per group.
865
- #
866
- # EC2-VPC: You can have up to 50 rules per group (covering both ingress
867
- # and egress rules).
868
- #
869
982
  # Rule changes are propagated to instances within the security group as
870
983
  # quickly as possible. However, a small delay might occur.
871
984
  #
872
- # \[EC2-Classic\] This action gives one or more CIDR IP address ranges
985
+ # \[EC2-Classic\] This action gives one or more IPv4 CIDR address ranges
873
986
  # permission to access a security group in your account, or gives one or
874
987
  # more security groups (called the *source groups*) permission to access
875
988
  # a security group for your account. A source group can be for your own
876
- # AWS account, or another.
989
+ # AWS account, or another. You can have up to 100 rules per group.
877
990
  #
878
- # \[EC2-VPC\] This action gives one or more CIDR IP address ranges
879
- # permission to access a security group in your VPC, or gives one or
880
- # more other security groups (called the *source groups*) permission to
881
- # access a security group for your VPC. The security groups must all be
882
- # for the same VPC.
991
+ # \[EC2-VPC\] This action gives one or more IPv4 or IPv6 CIDR address
992
+ # ranges permission to access a security group in your VPC, or gives one
993
+ # or more other security groups (called the *source groups*) permission
994
+ # to access a security group for your VPC. The security groups must all
995
+ # be for the same VPC or a peer VPC in a VPC peering connection. For
996
+ # more information about VPC security group limits, see [Amazon VPC
997
+ # Limits][1].
998
+ #
999
+ #
1000
+ #
1001
+ # [1]: http://docs.aws.amazon.com/AmazonVPC/latest/UserGuide/VPC_Appendix_Limits.html
883
1002
  # @option params [Boolean] :dry_run
884
1003
  # Checks whether you have the required permissions for the action,
885
1004
  # without actually making the request, and provides an error response.
@@ -907,22 +1026,26 @@ module Aws
907
1026
  # protocol and port range, use a set of IP permissions instead.
908
1027
  # @option params [String] :ip_protocol
909
1028
  # The IP protocol name (`tcp`, `udp`, `icmp`) or number (see [Protocol
910
- # Numbers][1]). (VPC only) Use `-1` to specify all traffic. If you
911
- # specify `-1`, traffic on all ports is allowed, regardless of any ports
912
- # you specify.
1029
+ # Numbers][1]). (VPC only) Use `-1` to specify all protocols. If you
1030
+ # specify `-1`, or a protocol number other than `tcp`, `udp`, `icmp`, or
1031
+ # `58` (ICMPv6), traffic on all ports is allowed, regardless of any
1032
+ # ports you specify. For `tcp`, `udp`, and `icmp`, you must specify a
1033
+ # port range. For protocol `58` (ICMPv6), you can optionally specify a
1034
+ # port range; if you don't, traffic for all types and codes is allowed.
913
1035
  #
914
1036
  #
915
1037
  #
916
1038
  # [1]: http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xhtml
917
1039
  # @option params [Integer] :from_port
918
- # The start of port range for the TCP and UDP protocols, or an ICMP type
919
- # number. For the ICMP type number, use `-1` to specify all ICMP types.
1040
+ # The start of port range for the TCP and UDP protocols, or an
1041
+ # ICMP/ICMPv6 type number. For the ICMP/ICMPv6 type number, use `-1` to
1042
+ # specify all types.
920
1043
  # @option params [Integer] :to_port
921
- # The end of port range for the TCP and UDP protocols, or an ICMP code
922
- # number. For the ICMP code number, use `-1` to specify all ICMP codes
923
- # for the ICMP type.
1044
+ # The end of port range for the TCP and UDP protocols, or an ICMP/ICMPv6
1045
+ # code number. For the ICMP/ICMPv6 code number, use `-1` to specify all
1046
+ # codes.
924
1047
  # @option params [String] :cidr_ip
925
- # The CIDR IP address range. You can't specify this parameter when
1048
+ # The CIDR IPv4 address range. You can't specify this parameter when
926
1049
  # specifying a source security group.
927
1050
  # @option params [Array<Types::IpPermission>] :ip_permissions
928
1051
  # A set of IP permissions. Can be used to specify multiple rules in a
@@ -960,6 +1083,11 @@ module Aws
960
1083
  # cidr_ip: "String",
961
1084
  # },
962
1085
  # ],
1086
+ # ipv_6_ranges: [
1087
+ # {
1088
+ # cidr_ipv_6: "String",
1089
+ # },
1090
+ # ],
963
1091
  # prefix_list_ids: [
964
1092
  # {
965
1093
  # prefix_list_id: "String",
@@ -1736,6 +1864,52 @@ module Aws
1736
1864
  req.send_request(options)
1737
1865
  end
1738
1866
 
1867
+ # \[IPv6 only\] Creates an egress-only Internet gateway for your VPC. An
1868
+ # egress-only Internet gateway is used to enable outbound communication
1869
+ # over IPv6 from instances in your VPC to the Internet, and prevents
1870
+ # hosts outside of your VPC from initiating an IPv6 connection with your
1871
+ # instance.
1872
+ # @option params [Boolean] :dry_run
1873
+ # Checks whether you have the required permissions for the action,
1874
+ # without actually making the request, and provides an error response.
1875
+ # If you have the required permissions, the error response is
1876
+ # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
1877
+ # @option params [required, String] :vpc_id
1878
+ # The ID of the VPC for which to create the egress-only Internet
1879
+ # gateway.
1880
+ # @option params [String] :client_token
1881
+ # Unique, case-sensitive identifier you provide to ensure the
1882
+ # idempotency of the request. For more information, see [How to Ensure
1883
+ # Idempotency][1].
1884
+ #
1885
+ #
1886
+ #
1887
+ # [1]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Run_Instance_Idempotency.html
1888
+ # @return [Types::CreateEgressOnlyInternetGatewayResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
1889
+ #
1890
+ # * {Types::CreateEgressOnlyInternetGatewayResult#egress_only_internet_gateway #EgressOnlyInternetGateway} => Types::EgressOnlyInternetGateway
1891
+ # * {Types::CreateEgressOnlyInternetGatewayResult#client_token #ClientToken} => String
1892
+ #
1893
+ # @example Request syntax with placeholder values
1894
+ # resp = client.create_egress_only_internet_gateway({
1895
+ # dry_run: false,
1896
+ # vpc_id: "String", # required
1897
+ # client_token: "String",
1898
+ # })
1899
+ #
1900
+ # @example Response structure
1901
+ # resp.egress_only_internet_gateway.egress_only_internet_gateway_id #=> String
1902
+ # resp.egress_only_internet_gateway.attachments #=> Array
1903
+ # resp.egress_only_internet_gateway.attachments[0].vpc_id #=> String
1904
+ # resp.egress_only_internet_gateway.attachments[0].state #=> String, one of "attaching", "attached", "detaching", "detached"
1905
+ # resp.client_token #=> String
1906
+ # @overload create_egress_only_internet_gateway(params = {})
1907
+ # @param [Hash] params ({})
1908
+ def create_egress_only_internet_gateway(params = {}, options = {})
1909
+ req = build_request(:create_egress_only_internet_gateway, params)
1910
+ req.send_request(options)
1911
+ end
1912
+
1739
1913
  # Creates one or more flow logs to capture IP traffic for a specific
1740
1914
  # network interface, subnet, or VPC. Flow logs are delivered to a
1741
1915
  # specified log group in Amazon CloudWatch Logs. If you specify a VPC or
@@ -1789,9 +1963,9 @@ module Aws
1789
1963
  # resp.flow_log_ids[0] #=> String
1790
1964
  # resp.client_token #=> String
1791
1965
  # resp.unsuccessful #=> Array
1966
+ # resp.unsuccessful[0].resource_id #=> String
1792
1967
  # resp.unsuccessful[0].error.code #=> String
1793
1968
  # resp.unsuccessful[0].error.message #=> String
1794
- # resp.unsuccessful[0].resource_id #=> String
1795
1969
  # @overload create_flow_logs(params = {})
1796
1970
  # @param [Hash] params ({})
1797
1971
  def create_flow_logs(params = {}, options = {})
@@ -2118,6 +2292,7 @@ module Aws
2118
2292
  # resp.network_acl.entries[0].rule_action #=> String, one of "allow", "deny"
2119
2293
  # resp.network_acl.entries[0].egress #=> Boolean
2120
2294
  # resp.network_acl.entries[0].cidr_block #=> String
2295
+ # resp.network_acl.entries[0].ipv_6_cidr_block #=> String
2121
2296
  # resp.network_acl.entries[0].icmp_type_code.type #=> Integer
2122
2297
  # resp.network_acl.entries[0].icmp_type_code.code #=> Integer
2123
2298
  # resp.network_acl.entries[0].port_range.from #=> Integer
@@ -2172,18 +2347,29 @@ module Aws
2172
2347
  # Constraints: Positive integer from 1 to 32766. The range 32767 to
2173
2348
  # 65535 is reserved for internal use.
2174
2349
  # @option params [required, String] :protocol
2175
- # The protocol. A value of -1 means all protocols.
2350
+ # The protocol. A value of `-1` or `all` means all protocols. If you
2351
+ # specify `all`, `-1`, or a protocol number other than `tcp`, `udp`, or
2352
+ # `icmp`, traffic on all ports is allowed, regardless of any ports or
2353
+ # ICMP types or codes you specify. If you specify protocol `58` (ICMPv6)
2354
+ # and specify an IPv4 CIDR block, traffic for all ICMP types and codes
2355
+ # allowed, regardless of any that you specify. If you specify protocol
2356
+ # `58` (ICMPv6) and specify an IPv6 CIDR block, you must specify an ICMP
2357
+ # type and code.
2176
2358
  # @option params [required, String] :rule_action
2177
2359
  # Indicates whether to allow or deny the traffic that matches the rule.
2178
2360
  # @option params [required, Boolean] :egress
2179
2361
  # Indicates whether this is an egress rule (rule is applied to traffic
2180
2362
  # leaving the subnet).
2181
- # @option params [required, String] :cidr_block
2182
- # The network range to allow or deny, in CIDR notation (for example
2363
+ # @option params [String] :cidr_block
2364
+ # The IPv4 network range to allow or deny, in CIDR notation (for example
2183
2365
  # `172.16.0.0/24`).
2366
+ # @option params [String] :ipv_6_cidr_block
2367
+ # The IPv6 network range to allow or deny, in CIDR notation (for example
2368
+ # `2001:db8:1234:1a00::/64`).
2184
2369
  # @option params [Types::IcmpTypeCode] :icmp_type_code
2185
- # ICMP protocol: The ICMP type and code. Required if specifying ICMP for
2186
- # the protocol.
2370
+ # ICMP protocol: The ICMP or ICMPv6 type and code. Required if
2371
+ # specifying the ICMP protocol, or protocol 58 (ICMPv6) with an IPv6
2372
+ # CIDR block.
2187
2373
  # @option params [Types::PortRange] :port_range
2188
2374
  # TCP or UDP protocols: The range of ports the rule applies to.
2189
2375
  # @return [Struct] Returns an empty {Seahorse::Client::Response response}.
@@ -2196,7 +2382,8 @@ module Aws
2196
2382
  # protocol: "String", # required
2197
2383
  # rule_action: "allow", # required, accepts allow, deny
2198
2384
  # egress: false, # required
2199
- # cidr_block: "String", # required
2385
+ # cidr_block: "String",
2386
+ # ipv_6_cidr_block: "String",
2200
2387
  # icmp_type_code: {
2201
2388
  # type: 1,
2202
2389
  # code: 1,
@@ -2216,7 +2403,7 @@ module Aws
2216
2403
  # Creates a network interface in the specified subnet.
2217
2404
  #
2218
2405
  # For more information about network interfaces, see [Elastic Network
2219
- # Interfaces][1] in the *Amazon Elastic Compute Cloud User Guide*.
2406
+ # Interfaces][1] in the *Amazon Virtual Private Cloud User Guide*.
2220
2407
  #
2221
2408
  #
2222
2409
  #
@@ -2226,30 +2413,40 @@ module Aws
2226
2413
  # @option params [String] :description
2227
2414
  # A description for the network interface.
2228
2415
  # @option params [String] :private_ip_address
2229
- # The primary private IP address of the network interface. If you don't
2230
- # specify an IP address, Amazon EC2 selects one for you from the subnet
2231
- # range. If you specify an IP address, you cannot indicate any IP
2232
- # addresses specified in `privateIpAddresses` as primary (only one IP
2233
- # address can be designated as primary).
2416
+ # The primary private IPv4 address of the network interface. If you
2417
+ # don't specify an IPv4 address, Amazon EC2 selects one for you from
2418
+ # the subnet's IPv4 CIDR range. If you specify an IP address, you
2419
+ # cannot indicate any IP addresses specified in `privateIpAddresses` as
2420
+ # primary (only one IP address can be designated as primary).
2234
2421
  # @option params [Array<String>] :groups
2235
2422
  # The IDs of one or more security groups.
2236
2423
  # @option params [Array<Types::PrivateIpAddressSpecification>] :private_ip_addresses
2237
- # One or more private IP addresses.
2424
+ # One or more private IPv4 addresses.
2238
2425
  # @option params [Integer] :secondary_private_ip_address_count
2239
- # The number of secondary private IP addresses to assign to a network
2240
- # interface. When you specify a number of secondary IP addresses, Amazon
2241
- # EC2 selects these IP addresses within the subnet range. You can't
2242
- # specify this option and specify more than one private IP address using
2243
- # `privateIpAddresses`.
2426
+ # The number of secondary private IPv4 addresses to assign to a network
2427
+ # interface. When you specify a number of secondary IPv4 addresses,
2428
+ # Amazon EC2 selects these IP addresses within the subnet's IPv4 CIDR
2429
+ # range. You can't specify this option and specify more than one
2430
+ # private IP address using `privateIpAddresses`.
2244
2431
  #
2245
2432
  # The number of IP addresses you can assign to a network interface
2246
- # varies by instance type. For more information, see [Private IP
2247
- # Addresses Per ENI Per Instance Type][1] in the *Amazon Elastic Compute
2248
- # Cloud User Guide*.
2433
+ # varies by instance type. For more information, see [IP Addresses Per
2434
+ # ENI Per Instance Type][1] in the *Amazon Virtual Private Cloud User
2435
+ # Guide*.
2249
2436
  #
2250
2437
  #
2251
2438
  #
2252
2439
  # [1]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-eni.html#AvailableIpPerENI
2440
+ # @option params [Array<Types::InstanceIpv6Address>] :ipv_6_addresses
2441
+ # One or more specific IPv6 addresses from the IPv6 CIDR block range of
2442
+ # your subnet. You can't use this option if you're specifying a number
2443
+ # of IPv6 addresses.
2444
+ # @option params [Integer] :ipv_6_address_count
2445
+ # The number of IPv6 addresses to assign to a network interface. Amazon
2446
+ # EC2 automatically selects the IPv6 addresses from the subnet range.
2447
+ # You can't use this option if specifying specific IPv6 addresses. If
2448
+ # your subnet has the `AssignIpv6AddressOnCreation` attribute set to
2449
+ # `true`, you can specify `0` to override this setting.
2253
2450
  # @option params [Boolean] :dry_run
2254
2451
  # Checks whether you have the required permissions for the action,
2255
2452
  # without actually making the request, and provides an error response.
@@ -2272,6 +2469,12 @@ module Aws
2272
2469
  # },
2273
2470
  # ],
2274
2471
  # secondary_private_ip_address_count: 1,
2472
+ # ipv_6_addresses: [
2473
+ # {
2474
+ # ipv_6_address: "String",
2475
+ # },
2476
+ # ],
2477
+ # ipv_6_address_count: 1,
2275
2478
  # dry_run: false,
2276
2479
  # })
2277
2480
  #
@@ -2316,6 +2519,8 @@ module Aws
2316
2519
  # resp.network_interface.private_ip_addresses[0].association.ip_owner_id #=> String
2317
2520
  # resp.network_interface.private_ip_addresses[0].association.allocation_id #=> String
2318
2521
  # resp.network_interface.private_ip_addresses[0].association.association_id #=> String
2522
+ # resp.network_interface.ipv_6_addresses #=> Array
2523
+ # resp.network_interface.ipv_6_addresses[0].ipv_6_address #=> String
2319
2524
  # resp.network_interface.interface_type #=> String, one of "interface", "natGateway"
2320
2525
  # @overload create_network_interface(params = {})
2321
2526
  # @param [Hash] params ({})
@@ -2455,11 +2660,12 @@ module Aws
2455
2660
  #
2456
2661
  # You must specify one of the following targets: Internet gateway or
2457
2662
  # virtual private gateway, NAT instance, NAT gateway, VPC peering
2458
- # connection, or network interface.
2663
+ # connection, network interface, or egress-only Internet gateway.
2459
2664
  #
2460
2665
  # When determining how to route traffic, we use the route with the most
2461
- # specific match. For example, let's say the traffic is destined for
2462
- # `192.0.2.3`, and the route table includes the following two routes:
2666
+ # specific match. For example, traffic is destined for the IPv4 address
2667
+ # `192.0.2.3`, and the route table includes the following two IPv4
2668
+ # routes:
2463
2669
  #
2464
2670
  # * `192.0.2.0/24` (goes to some target A)
2465
2671
  #
@@ -2483,12 +2689,17 @@ module Aws
2483
2689
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
2484
2690
  # @option params [required, String] :route_table_id
2485
2691
  # The ID of the route table for the route.
2486
- # @option params [required, String] :destination_cidr_block
2487
- # The CIDR address block used for the destination match. Routing
2692
+ # @option params [String] :destination_cidr_block
2693
+ # The IPv4 CIDR address block used for the destination match. Routing
2488
2694
  # decisions are based on the most specific match.
2489
2695
  # @option params [String] :gateway_id
2490
2696
  # The ID of an Internet gateway or virtual private gateway attached to
2491
2697
  # your VPC.
2698
+ # @option params [String] :destination_ipv_6_cidr_block
2699
+ # The IPv6 CIDR block used for the destination match. Routing decisions
2700
+ # are based on the most specific match.
2701
+ # @option params [String] :egress_only_internet_gateway_id
2702
+ # \[IPv6 traffic only\] The ID of an egress-only Internet gateway.
2492
2703
  # @option params [String] :instance_id
2493
2704
  # The ID of a NAT instance in your VPC. The operation fails if you
2494
2705
  # specify an instance ID unless exactly one network interface is
@@ -2498,7 +2709,7 @@ module Aws
2498
2709
  # @option params [String] :vpc_peering_connection_id
2499
2710
  # The ID of a VPC peering connection.
2500
2711
  # @option params [String] :nat_gateway_id
2501
- # The ID of a NAT gateway.
2712
+ # \[IPv4 traffic only\] The ID of a NAT gateway.
2502
2713
  # @return [Types::CreateRouteResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
2503
2714
  #
2504
2715
  # * {Types::CreateRouteResult#return #Return} => Boolean
@@ -2507,8 +2718,10 @@ module Aws
2507
2718
  # resp = client.create_route({
2508
2719
  # dry_run: false,
2509
2720
  # route_table_id: "String", # required
2510
- # destination_cidr_block: "String", # required
2721
+ # destination_cidr_block: "String",
2511
2722
  # gateway_id: "String",
2723
+ # destination_ipv_6_cidr_block: "String",
2724
+ # egress_only_internet_gateway_id: "String",
2512
2725
  # instance_id: "String",
2513
2726
  # network_interface_id: "String",
2514
2727
  # vpc_peering_connection_id: "String",
@@ -2564,6 +2777,8 @@ module Aws
2564
2777
  # resp.route_table.routes[0].nat_gateway_id #=> String
2565
2778
  # resp.route_table.routes[0].state #=> String, one of "active", "blackhole"
2566
2779
  # resp.route_table.routes[0].origin #=> String, one of "CreateRouteTable", "CreateRoute", "EnableVgwRoutePropagation"
2780
+ # resp.route_table.routes[0].destination_ipv_6_cidr_block #=> String
2781
+ # resp.route_table.routes[0].egress_only_internet_gateway_id #=> String
2567
2782
  # resp.route_table.associations #=> Array
2568
2783
  # resp.route_table.associations[0].route_table_association_id #=> String
2569
2784
  # resp.route_table.associations[0].route_table_id #=> String
@@ -2796,12 +3011,16 @@ module Aws
2796
3011
  #
2797
3012
  # When you create each subnet, you provide the VPC ID and the CIDR block
2798
3013
  # you want for the subnet. After you create a subnet, you can't change
2799
- # its CIDR block. The subnet's CIDR block can be the same as the VPC's
2800
- # CIDR block (assuming you want only a single subnet in the VPC), or a
2801
- # subset of the VPC's CIDR block. If you create more than one subnet in
2802
- # a VPC, the subnets' CIDR blocks must not overlap. The smallest subnet
2803
- # (and VPC) you can create uses a /28 netmask (16 IP addresses), and the
2804
- # largest uses a /16 netmask (65,536 IP addresses).
3014
+ # its CIDR block. The subnet's IPv4 CIDR block can be the same as the
3015
+ # VPC's IPv4 CIDR block (assuming you want only a single subnet in the
3016
+ # VPC), or a subset of the VPC's IPv4 CIDR block. If you create more
3017
+ # than one subnet in a VPC, the subnets' CIDR blocks must not overlap.
3018
+ # The smallest IPv4 subnet (and VPC) you can create uses a /28 netmask
3019
+ # (16 IPv4 addresses), and the largest uses a /16 netmask (65,536 IPv4
3020
+ # addresses).
3021
+ #
3022
+ # If you've associated an IPv6 CIDR block with your VPC, you can create
3023
+ # a subnet with an IPv6 CIDR block that uses a /64 prefix length.
2805
3024
  #
2806
3025
  # AWS reserves both the first four and the last IP address in each
2807
3026
  # subnet's CIDR block. They're not available for use.
@@ -2830,8 +3049,11 @@ module Aws
2830
3049
  # @option params [required, String] :vpc_id
2831
3050
  # The ID of the VPC.
2832
3051
  # @option params [required, String] :cidr_block
2833
- # The network range for the subnet, in CIDR notation. For example,
3052
+ # The IPv4 network range for the subnet, in CIDR notation. For example,
2834
3053
  # `10.0.0.0/24`.
3054
+ # @option params [String] :ipv_6_cidr_block
3055
+ # The IPv6 network range for the subnet, in CIDR notation. The subnet
3056
+ # size must use a /64 prefix length.
2835
3057
  # @option params [String] :availability_zone
2836
3058
  # The Availability Zone for the subnet.
2837
3059
  #
@@ -2847,6 +3069,7 @@ module Aws
2847
3069
  # dry_run: false,
2848
3070
  # vpc_id: "String", # required
2849
3071
  # cidr_block: "String", # required
3072
+ # ipv_6_cidr_block: "String",
2850
3073
  # availability_zone: "String",
2851
3074
  # })
2852
3075
  #
@@ -2855,6 +3078,12 @@ module Aws
2855
3078
  # resp.subnet.state #=> String, one of "pending", "available"
2856
3079
  # resp.subnet.vpc_id #=> String
2857
3080
  # resp.subnet.cidr_block #=> String
3081
+ # resp.subnet.ipv_6_cidr_block_association_set #=> Array
3082
+ # resp.subnet.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block #=> String
3083
+ # resp.subnet.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
3084
+ # resp.subnet.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.status_message #=> String
3085
+ # resp.subnet.ipv_6_cidr_block_association_set[0].association_id #=> String
3086
+ # resp.subnet.assign_ipv_6_address_on_creation #=> Boolean
2858
3087
  # resp.subnet.available_ip_address_count #=> Integer
2859
3088
  # resp.subnet.availability_zone #=> String
2860
3089
  # resp.subnet.default_for_az #=> Boolean
@@ -2969,7 +3198,7 @@ module Aws
2969
3198
  # @option params [Integer] :iops
2970
3199
  # Only valid for Provisioned IOPS SSD volumes. The number of I/O
2971
3200
  # operations per second (IOPS) to provision for the volume, with a
2972
- # maximum ratio of 30 IOPS/GiB.
3201
+ # maximum ratio of 50 IOPS/GiB.
2973
3202
  #
2974
3203
  # Constraint: Range is 100 to 20000 for Provisioned IOPS SSD volumes
2975
3204
  # @option params [Boolean] :encrypted
@@ -3050,12 +3279,16 @@ module Aws
3050
3279
  req.send_request(options)
3051
3280
  end
3052
3281
 
3053
- # Creates a VPC with the specified CIDR block.
3282
+ # Creates a VPC with the specified IPv4 CIDR block. The smallest VPC you
3283
+ # can create uses a /28 netmask (16 IPv4 addresses), and the largest
3284
+ # uses a /16 netmask (65,536 IPv4 addresses). To help you decide how big
3285
+ # to make your VPC, see [Your VPC and Subnets][1] in the *Amazon Virtual
3286
+ # Private Cloud User Guide*.
3054
3287
  #
3055
- # The smallest VPC you can create uses a /28 netmask (16 IP addresses),
3056
- # and the largest uses a /16 netmask (65,536 IP addresses). To help you
3057
- # decide how big to make your VPC, see [Your VPC and Subnets][1] in the
3058
- # *Amazon Virtual Private Cloud User Guide*.
3288
+ # You can optionally request an Amazon-provided IPv6 CIDR block for the
3289
+ # VPC. The IPv6 CIDR block uses a /56 prefix length, and is allocated
3290
+ # from Amazon's pool of IPv6 addresses. You cannot choose the IPv6
3291
+ # range for your VPC.
3059
3292
  #
3060
3293
  # By default, each instance you launch in the VPC has the default DHCP
3061
3294
  # options, which includes only a default DNS server that we provide
@@ -3079,7 +3312,7 @@ module Aws
3079
3312
  # If you have the required permissions, the error response is
3080
3313
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
3081
3314
  # @option params [required, String] :cidr_block
3082
- # The network range for the VPC, in CIDR notation. For example,
3315
+ # The IPv4 network range for the VPC, in CIDR notation. For example,
3083
3316
  # `10.0.0.0/16`.
3084
3317
  # @option params [String] :instance_tenancy
3085
3318
  # The tenancy options for instances launched into the VPC. For
@@ -3093,6 +3326,10 @@ module Aws
3093
3326
  # Use the `default` or `dedicated` values only.
3094
3327
  #
3095
3328
  # Default: `default`
3329
+ # @option params [Boolean] :amazon_provided_ipv_6_cidr_block
3330
+ # Requests an Amazon-provided IPv6 CIDR block with a /56 prefix length
3331
+ # for the VPC. You cannot specify the range of IP addresses, or the size
3332
+ # of the CIDR block.
3096
3333
  # @return [Types::CreateVpcResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
3097
3334
  #
3098
3335
  # * {Types::CreateVpcResult#vpc #Vpc} => Types::Vpc
@@ -3102,6 +3339,7 @@ module Aws
3102
3339
  # dry_run: false,
3103
3340
  # cidr_block: "String", # required
3104
3341
  # instance_tenancy: "default", # accepts default, dedicated, host
3342
+ # amazon_provided_ipv_6_cidr_block: false,
3105
3343
  # })
3106
3344
  #
3107
3345
  # @example Response structure
@@ -3114,6 +3352,11 @@ module Aws
3114
3352
  # resp.vpc.tags[0].value #=> String
3115
3353
  # resp.vpc.instance_tenancy #=> String, one of "default", "dedicated", "host"
3116
3354
  # resp.vpc.is_default #=> Boolean
3355
+ # resp.vpc.ipv_6_cidr_block_association_set #=> Array
3356
+ # resp.vpc.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block #=> String
3357
+ # resp.vpc.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
3358
+ # resp.vpc.ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.status_message #=> String
3359
+ # resp.vpc.ipv_6_cidr_block_association_set[0].association_id #=> String
3117
3360
  # @overload create_vpc(params = {})
3118
3361
  # @param [Hash] params ({})
3119
3362
  def create_vpc(params = {}, options = {})
@@ -3229,6 +3472,8 @@ module Aws
3229
3472
  # resp.vpc_peering_connection.accepter_vpc_info.cidr_block #=> String
3230
3473
  # resp.vpc_peering_connection.accepter_vpc_info.owner_id #=> String
3231
3474
  # resp.vpc_peering_connection.accepter_vpc_info.vpc_id #=> String
3475
+ # resp.vpc_peering_connection.accepter_vpc_info.ipv_6_cidr_block_set #=> Array
3476
+ # resp.vpc_peering_connection.accepter_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
3232
3477
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
3233
3478
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
3234
3479
  # resp.vpc_peering_connection.accepter_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -3236,6 +3481,8 @@ module Aws
3236
3481
  # resp.vpc_peering_connection.requester_vpc_info.cidr_block #=> String
3237
3482
  # resp.vpc_peering_connection.requester_vpc_info.owner_id #=> String
3238
3483
  # resp.vpc_peering_connection.requester_vpc_info.vpc_id #=> String
3484
+ # resp.vpc_peering_connection.requester_vpc_info.ipv_6_cidr_block_set #=> Array
3485
+ # resp.vpc_peering_connection.requester_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
3239
3486
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
3240
3487
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
3241
3488
  # resp.vpc_peering_connection.requester_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -3465,6 +3712,33 @@ module Aws
3465
3712
  req.send_request(options)
3466
3713
  end
3467
3714
 
3715
+ # Deletes an egress-only Internet gateway.
3716
+ # @option params [Boolean] :dry_run
3717
+ # Checks whether you have the required permissions for the action,
3718
+ # without actually making the request, and provides an error response.
3719
+ # If you have the required permissions, the error response is
3720
+ # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
3721
+ # @option params [required, String] :egress_only_internet_gateway_id
3722
+ # The ID of the egress-only Internet gateway.
3723
+ # @return [Types::DeleteEgressOnlyInternetGatewayResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
3724
+ #
3725
+ # * {Types::DeleteEgressOnlyInternetGatewayResult#return_code #ReturnCode} => Boolean
3726
+ #
3727
+ # @example Request syntax with placeholder values
3728
+ # resp = client.delete_egress_only_internet_gateway({
3729
+ # dry_run: false,
3730
+ # egress_only_internet_gateway_id: "EgressOnlyInternetGatewayId", # required
3731
+ # })
3732
+ #
3733
+ # @example Response structure
3734
+ # resp.return_code #=> Boolean
3735
+ # @overload delete_egress_only_internet_gateway(params = {})
3736
+ # @param [Hash] params ({})
3737
+ def delete_egress_only_internet_gateway(params = {}, options = {})
3738
+ req = build_request(:delete_egress_only_internet_gateway, params)
3739
+ req.send_request(options)
3740
+ end
3741
+
3468
3742
  # Deletes one or more flow logs.
3469
3743
  # @option params [required, Array<String>] :flow_log_ids
3470
3744
  # One or more flow log IDs.
@@ -3479,9 +3753,9 @@ module Aws
3479
3753
  #
3480
3754
  # @example Response structure
3481
3755
  # resp.unsuccessful #=> Array
3756
+ # resp.unsuccessful[0].resource_id #=> String
3482
3757
  # resp.unsuccessful[0].error.code #=> String
3483
3758
  # resp.unsuccessful[0].error.message #=> String
3484
- # resp.unsuccessful[0].resource_id #=> String
3485
3759
  # @overload delete_flow_logs(params = {})
3486
3760
  # @param [Hash] params ({})
3487
3761
  def delete_flow_logs(params = {}, options = {})
@@ -3673,16 +3947,20 @@ module Aws
3673
3947
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
3674
3948
  # @option params [required, String] :route_table_id
3675
3949
  # The ID of the route table.
3676
- # @option params [required, String] :destination_cidr_block
3677
- # The CIDR range for the route. The value you specify must match the
3678
- # CIDR for the route exactly.
3950
+ # @option params [String] :destination_cidr_block
3951
+ # The IPv4 CIDR range for the route. The value you specify must match
3952
+ # the CIDR for the route exactly.
3953
+ # @option params [String] :destination_ipv_6_cidr_block
3954
+ # The IPv6 CIDR range for the route. The value you specify must match
3955
+ # the CIDR for the route exactly.
3679
3956
  # @return [Struct] Returns an empty {Seahorse::Client::Response response}.
3680
3957
  #
3681
3958
  # @example Request syntax with placeholder values
3682
3959
  # resp = client.delete_route({
3683
3960
  # dry_run: false,
3684
3961
  # route_table_id: "String", # required
3685
- # destination_cidr_block: "String", # required
3962
+ # destination_cidr_block: "String",
3963
+ # destination_ipv_6_cidr_block: "String",
3686
3964
  # })
3687
3965
  # @overload delete_route(params = {})
3688
3966
  # @param [Hash] params ({})
@@ -3954,9 +4232,9 @@ module Aws
3954
4232
  #
3955
4233
  # @example Response structure
3956
4234
  # resp.unsuccessful #=> Array
4235
+ # resp.unsuccessful[0].resource_id #=> String
3957
4236
  # resp.unsuccessful[0].error.code #=> String
3958
4237
  # resp.unsuccessful[0].error.message #=> String
3959
- # resp.unsuccessful[0].resource_id #=> String
3960
4238
  # @overload delete_vpc_endpoints(params = {})
3961
4239
  # @param [Hash] params ({})
3962
4240
  def delete_vpc_endpoints(params = {}, options = {})
@@ -4674,6 +4952,49 @@ module Aws
4674
4952
  req.send_request(options)
4675
4953
  end
4676
4954
 
4955
+ # Describes one or more of your egress-only Internet gateways.
4956
+ # @option params [Boolean] :dry_run
4957
+ # Checks whether you have the required permissions for the action,
4958
+ # without actually making the request, and provides an error response.
4959
+ # If you have the required permissions, the error response is
4960
+ # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
4961
+ # @option params [Array<String>] :egress_only_internet_gateway_ids
4962
+ # One or more egress-only Internet gateway IDs.
4963
+ # @option params [Integer] :max_results
4964
+ # The maximum number of results to return for the request in a single
4965
+ # page. The remaining results can be seen by sending another request
4966
+ # with the returned `NextToken` value. This value can be between 5 and
4967
+ # 1000; if `MaxResults` is given a value larger than 1000, only 1000
4968
+ # results are returned.
4969
+ # @option params [String] :next_token
4970
+ # The token to retrieve the next page of results.
4971
+ # @return [Types::DescribeEgressOnlyInternetGatewaysResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
4972
+ #
4973
+ # * {Types::DescribeEgressOnlyInternetGatewaysResult#egress_only_internet_gateways #EgressOnlyInternetGateways} => Array&lt;Types::EgressOnlyInternetGateway&gt;
4974
+ # * {Types::DescribeEgressOnlyInternetGatewaysResult#next_token #NextToken} => String
4975
+ #
4976
+ # @example Request syntax with placeholder values
4977
+ # resp = client.describe_egress_only_internet_gateways({
4978
+ # dry_run: false,
4979
+ # egress_only_internet_gateway_ids: ["EgressOnlyInternetGatewayId"],
4980
+ # max_results: 1,
4981
+ # next_token: "String",
4982
+ # })
4983
+ #
4984
+ # @example Response structure
4985
+ # resp.egress_only_internet_gateways #=> Array
4986
+ # resp.egress_only_internet_gateways[0].egress_only_internet_gateway_id #=> String
4987
+ # resp.egress_only_internet_gateways[0].attachments #=> Array
4988
+ # resp.egress_only_internet_gateways[0].attachments[0].vpc_id #=> String
4989
+ # resp.egress_only_internet_gateways[0].attachments[0].state #=> String, one of "attaching", "attached", "detaching", "detached"
4990
+ # resp.next_token #=> String
4991
+ # @overload describe_egress_only_internet_gateways(params = {})
4992
+ # @param [Hash] params ({})
4993
+ def describe_egress_only_internet_gateways(params = {}, options = {})
4994
+ req = build_request(:describe_egress_only_internet_gateways, params)
4995
+ req.send_request(options)
4996
+ end
4997
+
4677
4998
  # Describes one or more of your export tasks.
4678
4999
  # @option params [Array<String>] :export_task_ids
4679
5000
  # One or more export task IDs.
@@ -5198,6 +5519,9 @@ module Aws
5198
5519
  # * `description` - The description of the image (provided during image
5199
5520
  # creation).
5200
5521
  #
5522
+ # * `ena-support` - A Boolean that indicates whether enhanced networking
5523
+ # with ENA is enabled.
5524
+ #
5201
5525
  # * `hypervisor` - The hypervisor type (`ovm` \| `xen`).
5202
5526
  #
5203
5527
  # * `image-id` - The ID of the image.
@@ -5699,6 +6023,18 @@ module Aws
5699
6023
  #
5700
6024
  # * `architecture` - The instance architecture (`i386` \| `x86_64`).
5701
6025
  #
6026
+ # * `association.public-ip` - The address of the Elastic IP address
6027
+ # (IPv4) bound to the network interface.
6028
+ #
6029
+ # * `association.ip-owner-id` - The owner of the Elastic IP address
6030
+ # (IPv4) associated with the network interface.
6031
+ #
6032
+ # * `association.allocation-id` - The allocation ID returned when you
6033
+ # allocated the Elastic IP address (IPv4) for your network interface.
6034
+ #
6035
+ # * `association.association-id` - The association ID returned when the
6036
+ # network interface was associated with an IPv4 address.
6037
+ #
5702
6038
  # * `availability-zone` - The Availability Zone of the instance.
5703
6039
  #
5704
6040
  # * `block-device-mapping.attach-time` - The attach time for an EBS
@@ -5759,7 +6095,7 @@ module Aws
5759
6095
  # * `instance.group-name` - The name of the security group for the
5760
6096
  # instance.
5761
6097
  #
5762
- # * `ip-address` - The public IP address of the instance.
6098
+ # * `ip-address` - The public IPv4 address of the instance.
5763
6099
  #
5764
6100
  # * `kernel-id` - The kernel ID.
5765
6101
  #
@@ -5772,8 +6108,91 @@ module Aws
5772
6108
  #
5773
6109
  # * `launch-time` - The time when the instance was launched.
5774
6110
  #
5775
- # * `monitoring-state` - Indicates whether monitoring is enabled for the
5776
- # instance (`disabled` \| `enabled`).
6111
+ # * `monitoring-state` - Indicates whether detailed monitoring is
6112
+ # enabled (`disabled` \| `enabled`).
6113
+ #
6114
+ # * `network-interface.addresses.private-ip-address` - The private IPv4
6115
+ # address associated with the network interface.
6116
+ #
6117
+ # * `network-interface.addresses.primary` - Specifies whether the IPv4
6118
+ # address of the network interface is the primary private IPv4
6119
+ # address.
6120
+ #
6121
+ # * `network-interface.addresses.association.public-ip` - The ID of the
6122
+ # association of an Elastic IP address (IPv4) with a network
6123
+ # interface.
6124
+ #
6125
+ # * `network-interface.addresses.association.ip-owner-id` - The owner ID
6126
+ # of the private IPv4 address associated with the network interface.
6127
+ #
6128
+ # * `network-interface.attachment.attachment-id` - The ID of the
6129
+ # interface attachment.
6130
+ #
6131
+ # * `network-interface.attachment.instance-id` - The ID of the instance
6132
+ # to which the network interface is attached.
6133
+ #
6134
+ # * `network-interface.attachment.instance-owner-id` - The owner ID of
6135
+ # the instance to which the network interface is attached.
6136
+ #
6137
+ # * `network-interface.attachment.device-index` - The device index to
6138
+ # which the network interface is attached.
6139
+ #
6140
+ # * `network-interface.attachment.status` - The status of the attachment
6141
+ # (`attaching` \| `attached` \| `detaching` \| `detached`).
6142
+ #
6143
+ # * `network-interface.attachment.attach-time` - The time that the
6144
+ # network interface was attached to an instance.
6145
+ #
6146
+ # * `network-interface.attachment.delete-on-termination` - Specifies
6147
+ # whether the attachment is deleted when an instance is terminated.
6148
+ #
6149
+ # * `network-interface.availability-zone` - The Availability Zone for
6150
+ # the network interface.
6151
+ #
6152
+ # * `network-interface.description` - The description of the network
6153
+ # interface.
6154
+ #
6155
+ # * `network-interface.group-id` - The ID of a security group associated
6156
+ # with the network interface.
6157
+ #
6158
+ # * `network-interface.group-name` - The name of a security group
6159
+ # associated with the network interface.
6160
+ #
6161
+ # * `network-interface.ipv6-addresses.ipv6-address` - The IPv6 address
6162
+ # associated with the network interface.
6163
+ #
6164
+ # * `network-interface.mac-address` - The MAC address of the network
6165
+ # interface.
6166
+ #
6167
+ # * `network-interface.network-interface-id` - The ID of the network
6168
+ # interface.
6169
+ #
6170
+ # * `network-interface.owner-id` - The ID of the owner of the network
6171
+ # interface.
6172
+ #
6173
+ # * `network-interface.private-dns-name` - The private DNS name of the
6174
+ # network interface.
6175
+ #
6176
+ # * `network-interface.requester-id` - The requester ID for the network
6177
+ # interface.
6178
+ #
6179
+ # * `network-interface.requester-managed` - Indicates whether the
6180
+ # network interface is being managed by AWS.
6181
+ #
6182
+ # * `network-interface.status` - The status of the network interface
6183
+ # (`available`) \| `in-use`).
6184
+ #
6185
+ # * `network-interface.source-dest-check` - Whether the network
6186
+ # interface performs source/destination checking. A value of `true`
6187
+ # means checking is enabled, and `false` means checking is disabled.
6188
+ # The value must be `false` for the network interface to perform
6189
+ # network address translation (NAT) in your VPC.
6190
+ #
6191
+ # * `network-interface.subnet-id` - The ID of the subnet for the network
6192
+ # interface.
6193
+ #
6194
+ # * `network-interface.vpc-id` - The ID of the VPC for the network
6195
+ # interface.
5777
6196
  #
5778
6197
  # * `owner-id` - The AWS account ID of the instance owner.
5779
6198
  #
@@ -5783,9 +6202,9 @@ module Aws
5783
6202
  # * `platform` - The platform. Use `windows` if you have Windows
5784
6203
  # instances; otherwise, leave blank.
5785
6204
  #
5786
- # * `private-dns-name` - The private DNS name of the instance.
6205
+ # * `private-dns-name` - The private IPv4 DNS name of the instance.
5787
6206
  #
5788
- # * `private-ip-address` - The private IP address of the instance.
6207
+ # * `private-ip-address` - The private IPv4 address of the instance.
5789
6208
  #
5790
6209
  # * `product-code` - The product code associated with the AMI used to
5791
6210
  # launch the instance.
@@ -5853,96 +6272,6 @@ module Aws
5853
6272
  # (`paravirtual` \| `hvm`).
5854
6273
  #
5855
6274
  # * `vpc-id` - The ID of the VPC that the instance is running in.
5856
- #
5857
- # * `network-interface.description` - The description of the network
5858
- # interface.
5859
- #
5860
- # * `network-interface.subnet-id` - The ID of the subnet for the network
5861
- # interface.
5862
- #
5863
- # * `network-interface.vpc-id` - The ID of the VPC for the network
5864
- # interface.
5865
- #
5866
- # * `network-interface.network-interface-id` - The ID of the network
5867
- # interface.
5868
- #
5869
- # * `network-interface.owner-id` - The ID of the owner of the network
5870
- # interface.
5871
- #
5872
- # * `network-interface.availability-zone` - The Availability Zone for
5873
- # the network interface.
5874
- #
5875
- # * `network-interface.requester-id` - The requester ID for the network
5876
- # interface.
5877
- #
5878
- # * `network-interface.requester-managed` - Indicates whether the
5879
- # network interface is being managed by AWS.
5880
- #
5881
- # * `network-interface.status` - The status of the network interface
5882
- # (`available`) \| `in-use`).
5883
- #
5884
- # * `network-interface.mac-address` - The MAC address of the network
5885
- # interface.
5886
- #
5887
- # * `network-interface.private-dns-name` - The private DNS name of the
5888
- # network interface.
5889
- #
5890
- # * `network-interface.source-dest-check` - Whether the network
5891
- # interface performs source/destination checking. A value of `true`
5892
- # means checking is enabled, and `false` means checking is disabled.
5893
- # The value must be `false` for the network interface to perform
5894
- # network address translation (NAT) in your VPC.
5895
- #
5896
- # * `network-interface.group-id` - The ID of a security group associated
5897
- # with the network interface.
5898
- #
5899
- # * `network-interface.group-name` - The name of a security group
5900
- # associated with the network interface.
5901
- #
5902
- # * `network-interface.attachment.attachment-id` - The ID of the
5903
- # interface attachment.
5904
- #
5905
- # * `network-interface.attachment.instance-id` - The ID of the instance
5906
- # to which the network interface is attached.
5907
- #
5908
- # * `network-interface.attachment.instance-owner-id` - The owner ID of
5909
- # the instance to which the network interface is attached.
5910
- #
5911
- # * `network-interface.addresses.private-ip-address` - The private IP
5912
- # address associated with the network interface.
5913
- #
5914
- # * `network-interface.attachment.device-index` - The device index to
5915
- # which the network interface is attached.
5916
- #
5917
- # * `network-interface.attachment.status` - The status of the attachment
5918
- # (`attaching` \| `attached` \| `detaching` \| `detached`).
5919
- #
5920
- # * `network-interface.attachment.attach-time` - The time that the
5921
- # network interface was attached to an instance.
5922
- #
5923
- # * `network-interface.attachment.delete-on-termination` - Specifies
5924
- # whether the attachment is deleted when an instance is terminated.
5925
- #
5926
- # * `network-interface.addresses.primary` - Specifies whether the IP
5927
- # address of the network interface is the primary private IP address.
5928
- #
5929
- # * `network-interface.addresses.association.public-ip` - The ID of the
5930
- # association of an Elastic IP address with a network interface.
5931
- #
5932
- # * `network-interface.addresses.association.ip-owner-id` - The owner ID
5933
- # of the private IP address associated with the network interface.
5934
- #
5935
- # * `association.public-ip` - The address of the Elastic IP address
5936
- # bound to the network interface.
5937
- #
5938
- # * `association.ip-owner-id` - The owner of the Elastic IP address
5939
- # associated with the network interface.
5940
- #
5941
- # * `association.allocation-id` - The allocation ID returned when you
5942
- # allocated the Elastic IP address for your network interface.
5943
- #
5944
- # * `association.association-id` - The association ID returned when the
5945
- # network interface was associated with an IP address.
5946
6275
  # @option params [String] :next_token
5947
6276
  # The token to request the next page of results.
5948
6277
  # @option params [Integer] :max_results
@@ -6001,7 +6330,7 @@ module Aws
6001
6330
  # resp.reservations[0].instances[0].product_codes #=> Array
6002
6331
  # resp.reservations[0].instances[0].product_codes[0].product_code_id #=> String
6003
6332
  # resp.reservations[0].instances[0].product_codes[0].product_code_type #=> String, one of "devpay", "marketplace"
6004
- # resp.reservations[0].instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
6333
+ # resp.reservations[0].instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
6005
6334
  # resp.reservations[0].instances[0].launch_time #=> Time
6006
6335
  # resp.reservations[0].instances[0].placement.availability_zone #=> String
6007
6336
  # resp.reservations[0].instances[0].placement.group_name #=> String
@@ -6068,6 +6397,8 @@ module Aws
6068
6397
  # resp.reservations[0].instances[0].network_interfaces[0].private_ip_addresses[0].association.public_ip #=> String
6069
6398
  # resp.reservations[0].instances[0].network_interfaces[0].private_ip_addresses[0].association.public_dns_name #=> String
6070
6399
  # resp.reservations[0].instances[0].network_interfaces[0].private_ip_addresses[0].association.ip_owner_id #=> String
6400
+ # resp.reservations[0].instances[0].network_interfaces[0].ipv_6_addresses #=> Array
6401
+ # resp.reservations[0].instances[0].network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
6071
6402
  # resp.reservations[0].instances[0].iam_instance_profile.arn #=> String
6072
6403
  # resp.reservations[0].instances[0].iam_instance_profile.id #=> String
6073
6404
  # resp.reservations[0].instances[0].ebs_optimized #=> Boolean
@@ -6357,7 +6688,7 @@ module Aws
6357
6688
  # * `default` - Indicates whether the ACL is the default network ACL for
6358
6689
  # the VPC.
6359
6690
  #
6360
- # * `entry.cidr` - The CIDR range specified in the entry.
6691
+ # * `entry.cidr` - The IPv4 CIDR range specified in the entry.
6361
6692
  #
6362
6693
  # * `entry.egress` - Indicates whether the entry applies to egress
6363
6694
  # traffic.
@@ -6366,6 +6697,8 @@ module Aws
6366
6697
  #
6367
6698
  # * `entry.icmp.type` - The ICMP type specified in the entry, if any.
6368
6699
  #
6700
+ # * `entry.ipv6-cidr` - The IPv6 CIDR range specified in the entry.
6701
+ #
6369
6702
  # * `entry.port-range.from` - The start of the port range specified in
6370
6703
  # the entry.
6371
6704
  #
@@ -6425,6 +6758,7 @@ module Aws
6425
6758
  # resp.network_acls[0].entries[0].rule_action #=> String, one of "allow", "deny"
6426
6759
  # resp.network_acls[0].entries[0].egress #=> Boolean
6427
6760
  # resp.network_acls[0].entries[0].cidr_block #=> String
6761
+ # resp.network_acls[0].entries[0].ipv_6_cidr_block #=> String
6428
6762
  # resp.network_acls[0].entries[0].icmp_type_code.type #=> Integer
6429
6763
  # resp.network_acls[0].entries[0].icmp_type_code.code #=> Integer
6430
6764
  # resp.network_acls[0].entries[0].port_range.from #=> Integer
@@ -6503,32 +6837,33 @@ module Aws
6503
6837
  # @option params [Array<Types::Filter>] :filters
6504
6838
  # One or more filters.
6505
6839
  #
6506
- # * `addresses.private-ip-address` - The private IP addresses associated
6507
- # with the network interface.
6840
+ # * `addresses.private-ip-address` - The private IPv4 addresses
6841
+ # associated with the network interface.
6508
6842
  #
6509
- # * `addresses.primary` - Whether the private IP address is the primary
6510
- # IP address associated with the network interface.
6843
+ # * `addresses.primary` - Whether the private IPv4 address is the
6844
+ # primary IP address associated with the network interface.
6511
6845
  #
6512
6846
  # * `addresses.association.public-ip` - The association ID returned when
6513
- # the network interface was associated with the Elastic IP address.
6847
+ # the network interface was associated with the Elastic IP address
6848
+ # (IPv4).
6514
6849
  #
6515
6850
  # * `addresses.association.owner-id` - The owner ID of the addresses
6516
6851
  # associated with the network interface.
6517
6852
  #
6518
6853
  # * `association.association-id` - The association ID returned when the
6519
- # network interface was associated with an IP address.
6854
+ # network interface was associated with an IPv4 address.
6520
6855
  #
6521
6856
  # * `association.allocation-id` - The allocation ID returned when you
6522
- # allocated the Elastic IP address for your network interface.
6857
+ # allocated the Elastic IP address (IPv4) for your network interface.
6523
6858
  #
6524
6859
  # * `association.ip-owner-id` - The owner of the Elastic IP address
6525
- # associated with the network interface.
6860
+ # (IPv4) associated with the network interface.
6526
6861
  #
6527
6862
  # * `association.public-ip` - The address of the Elastic IP address
6528
- # bound to the network interface.
6863
+ # (IPv4) bound to the network interface.
6529
6864
  #
6530
6865
  # * `association.public-dns-name` - The public DNS name for the network
6531
- # interface.
6866
+ # interface (IPv4).
6532
6867
  #
6533
6868
  # * `attachment.attachment-id` - The ID of the interface attachment.
6534
6869
  #
@@ -6564,16 +6899,20 @@ module Aws
6564
6899
  # * `group-name` - The name of a security group associated with the
6565
6900
  # network interface.
6566
6901
  #
6902
+ # * `ipv6-addresses.ipv6-address` - An IPv6 address associated with the
6903
+ # network interface.
6904
+ #
6567
6905
  # * `mac-address` - The MAC address of the network interface.
6568
6906
  #
6569
6907
  # * `network-interface-id` - The ID of the network interface.
6570
6908
  #
6571
6909
  # * `owner-id` - The AWS account ID of the network interface owner.
6572
6910
  #
6573
- # * `private-ip-address` - The private IP address or addresses of the
6911
+ # * `private-ip-address` - The private IPv4 address or addresses of the
6574
6912
  # network interface.
6575
6913
  #
6576
- # * `private-dns-name` - The private DNS name of the network interface.
6914
+ # * `private-dns-name` - The private DNS name of the network interface
6915
+ # (IPv4).
6577
6916
  #
6578
6917
  # * `requester-id` - The ID of the entity that launched the instance on
6579
6918
  # your behalf (for example, AWS Management Console, Auto Scaling, and
@@ -6669,6 +7008,8 @@ module Aws
6669
7008
  # resp.network_interfaces[0].private_ip_addresses[0].association.ip_owner_id #=> String
6670
7009
  # resp.network_interfaces[0].private_ip_addresses[0].association.allocation_id #=> String
6671
7010
  # resp.network_interfaces[0].private_ip_addresses[0].association.association_id #=> String
7011
+ # resp.network_interfaces[0].ipv_6_addresses #=> Array
7012
+ # resp.network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
6672
7013
  # resp.network_interfaces[0].interface_type #=> String, one of "interface", "natGateway"
6673
7014
  # @overload describe_network_interfaces(params = {})
6674
7015
  # @param [Hash] params ({})
@@ -6943,7 +7284,7 @@ module Aws
6943
7284
  # @example Response structure
6944
7285
  # resp.reserved_instances #=> Array
6945
7286
  # resp.reserved_instances[0].reserved_instances_id #=> String
6946
- # resp.reserved_instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
7287
+ # resp.reserved_instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
6947
7288
  # resp.reserved_instances[0].availability_zone #=> String
6948
7289
  # resp.reserved_instances[0].start #=> Time
6949
7290
  # resp.reserved_instances[0].end #=> Time
@@ -7137,7 +7478,7 @@ module Aws
7137
7478
  # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.availability_zone #=> String
7138
7479
  # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.platform #=> String
7139
7480
  # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.instance_count #=> Integer
7140
- # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
7481
+ # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
7141
7482
  # resp.reserved_instances_modifications[0].modification_results[0].target_configuration.scope #=> String, one of "Availability Zone", "Region"
7142
7483
  # resp.reserved_instances_modifications[0].create_date #=> Time
7143
7484
  # resp.reserved_instances_modifications[0].update_date #=> Time
@@ -7278,7 +7619,7 @@ module Aws
7278
7619
  # resp = client.describe_reserved_instances_offerings({
7279
7620
  # dry_run: false,
7280
7621
  # reserved_instances_offering_ids: ["String"],
7281
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
7622
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
7282
7623
  # availability_zone: "String",
7283
7624
  # product_description: "Linux/UNIX", # accepts Linux/UNIX, Linux/UNIX (Amazon VPC), Windows, Windows (Amazon VPC)
7284
7625
  # filters: [
@@ -7301,7 +7642,7 @@ module Aws
7301
7642
  # @example Response structure
7302
7643
  # resp.reserved_instances_offerings #=> Array
7303
7644
  # resp.reserved_instances_offerings[0].reserved_instances_offering_id #=> String
7304
- # resp.reserved_instances_offerings[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
7645
+ # resp.reserved_instances_offerings[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
7305
7646
  # resp.reserved_instances_offerings[0].availability_zone #=> String
7306
7647
  # resp.reserved_instances_offerings[0].duration #=> Integer
7307
7648
  # resp.reserved_instances_offerings[0].usage_price #=> Float
@@ -7366,12 +7707,18 @@ module Aws
7366
7707
  #
7367
7708
  # * `route-table-id` - The ID of the route table.
7368
7709
  #
7369
- # * `route.destination-cidr-block` - The CIDR range specified in a route
7370
- # in the table.
7710
+ # * `route.destination-cidr-block` - The IPv4 CIDR range specified in a
7711
+ # route in the table.
7712
+ #
7713
+ # * `route.destination-ipv6-cidr-block` - The IPv6 CIDR range specified
7714
+ # in a route in the route table.
7371
7715
  #
7372
7716
  # * `route.destination-prefix-list-id` - The ID (prefix) of the AWS
7373
7717
  # service specified in a route in the table.
7374
7718
  #
7719
+ # * `route.egress-only-internet-gateway-id` - The ID of an egress-only
7720
+ # Internet gateway specified in a route in the route table.
7721
+ #
7375
7722
  # * `route.gateway-id` - The ID of a gateway specified in a route in the
7376
7723
  # table.
7377
7724
  #
@@ -7442,6 +7789,8 @@ module Aws
7442
7789
  # resp.route_tables[0].routes[0].nat_gateway_id #=> String
7443
7790
  # resp.route_tables[0].routes[0].state #=> String, one of "active", "blackhole"
7444
7791
  # resp.route_tables[0].routes[0].origin #=> String, one of "CreateRouteTable", "CreateRoute", "EnableVgwRoutePropagation"
7792
+ # resp.route_tables[0].routes[0].destination_ipv_6_cidr_block #=> String
7793
+ # resp.route_tables[0].routes[0].egress_only_internet_gateway_id #=> String
7445
7794
  # resp.route_tables[0].associations #=> Array
7446
7795
  # resp.route_tables[0].associations[0].route_table_association_id #=> String
7447
7796
  # resp.route_tables[0].associations[0].route_table_id #=> String
@@ -7722,8 +8071,8 @@ module Aws
7722
8071
  #
7723
8072
  # * `group-name` - The name of the security group.
7724
8073
  #
7725
- # * `ip-permission.cidr` - A CIDR range that has been granted
7726
- # permission.
8074
+ # * `ip-permission.cidr` - An IPv4 CIDR range that has been granted
8075
+ # permission in a security group rule.
7727
8076
  #
7728
8077
  # * `ip-permission.from-port` - The start of port range for the TCP and
7729
8078
  # UDP protocols, or an ICMP type number.
@@ -7734,6 +8083,9 @@ module Aws
7734
8083
  # * `ip-permission.group-name` - The name of a security group that has
7735
8084
  # been granted permission.
7736
8085
  #
8086
+ # * `ip-permission.ipv6-cidr` - An IPv6 CIDR range that has been granted
8087
+ # permission in a security group rule.
8088
+ #
7737
8089
  # * `ip-permission.protocol` - The IP protocol for the permission (`tcp`
7738
8090
  # \| `udp` \| `icmp` or a protocol number).
7739
8091
  #
@@ -7787,6 +8139,8 @@ module Aws
7787
8139
  # resp.security_groups[0].ip_permissions[0].user_id_group_pairs[0].peering_status #=> String
7788
8140
  # resp.security_groups[0].ip_permissions[0].ip_ranges #=> Array
7789
8141
  # resp.security_groups[0].ip_permissions[0].ip_ranges[0].cidr_ip #=> String
8142
+ # resp.security_groups[0].ip_permissions[0].ipv_6_ranges #=> Array
8143
+ # resp.security_groups[0].ip_permissions[0].ipv_6_ranges[0].cidr_ipv_6 #=> String
7790
8144
  # resp.security_groups[0].ip_permissions[0].prefix_list_ids #=> Array
7791
8145
  # resp.security_groups[0].ip_permissions[0].prefix_list_ids[0].prefix_list_id #=> String
7792
8146
  # resp.security_groups[0].ip_permissions_egress #=> Array
@@ -7802,6 +8156,8 @@ module Aws
7802
8156
  # resp.security_groups[0].ip_permissions_egress[0].user_id_group_pairs[0].peering_status #=> String
7803
8157
  # resp.security_groups[0].ip_permissions_egress[0].ip_ranges #=> Array
7804
8158
  # resp.security_groups[0].ip_permissions_egress[0].ip_ranges[0].cidr_ip #=> String
8159
+ # resp.security_groups[0].ip_permissions_egress[0].ipv_6_ranges #=> Array
8160
+ # resp.security_groups[0].ip_permissions_egress[0].ipv_6_ranges[0].cidr_ipv_6 #=> String
7805
8161
  # resp.security_groups[0].ip_permissions_egress[0].prefix_list_ids #=> Array
7806
8162
  # resp.security_groups[0].ip_permissions_egress[0].prefix_list_ids[0].prefix_list_id #=> String
7807
8163
  # resp.security_groups[0].vpc_id #=> String
@@ -8221,7 +8577,7 @@ module Aws
8221
8577
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].security_groups[0].group_id #=> String
8222
8578
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].user_data #=> String
8223
8579
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].addressing_type #=> String
8224
- # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
8580
+ # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
8225
8581
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].placement.availability_zone #=> String
8226
8582
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].placement.group_name #=> String
8227
8583
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].kernel_id #=> String
@@ -8252,6 +8608,9 @@ module Aws
8252
8608
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].private_ip_addresses[0].primary #=> Boolean
8253
8609
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].secondary_private_ip_address_count #=> Integer
8254
8610
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].associate_public_ip_address #=> Boolean
8611
+ # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].ipv_6_addresses #=> Array
8612
+ # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
8613
+ # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].network_interfaces[0].ipv_6_address_count #=> Integer
8255
8614
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].iam_instance_profile.arn #=> String
8256
8615
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].iam_instance_profile.name #=> String
8257
8616
  # resp.spot_fleet_request_configs[0].spot_fleet_request_config.launch_specifications[0].ebs_optimized #=> Boolean
@@ -8461,7 +8820,7 @@ module Aws
8461
8820
  # resp.spot_instance_requests[0].launch_specification.security_groups[0].group_id #=> String
8462
8821
  # resp.spot_instance_requests[0].launch_specification.user_data #=> String
8463
8822
  # resp.spot_instance_requests[0].launch_specification.addressing_type #=> String
8464
- # resp.spot_instance_requests[0].launch_specification.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
8823
+ # resp.spot_instance_requests[0].launch_specification.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
8465
8824
  # resp.spot_instance_requests[0].launch_specification.placement.availability_zone #=> String
8466
8825
  # resp.spot_instance_requests[0].launch_specification.placement.group_name #=> String
8467
8826
  # resp.spot_instance_requests[0].launch_specification.kernel_id #=> String
@@ -8491,6 +8850,9 @@ module Aws
8491
8850
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].private_ip_addresses[0].primary #=> Boolean
8492
8851
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].secondary_private_ip_address_count #=> Integer
8493
8852
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].associate_public_ip_address #=> Boolean
8853
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_addresses #=> Array
8854
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
8855
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_address_count #=> Integer
8494
8856
  # resp.spot_instance_requests[0].launch_specification.iam_instance_profile.arn #=> String
8495
8857
  # resp.spot_instance_requests[0].launch_specification.iam_instance_profile.name #=> String
8496
8858
  # resp.spot_instance_requests[0].launch_specification.ebs_optimized #=> Boolean
@@ -8511,10 +8873,9 @@ module Aws
8511
8873
  req.send_request(options)
8512
8874
  end
8513
8875
 
8514
- # Describes the Spot price history. The prices returned are listed in
8515
- # chronological order, from the oldest to the most recent, for up to the
8516
- # past 90 days. For more information, see [Spot Instance Pricing
8517
- # History][1] in the *Amazon Elastic Compute Cloud User Guide*.
8876
+ # Describes the Spot price history. For more information, see [Spot
8877
+ # Instance Pricing History][1] in the *Amazon Elastic Compute Cloud User
8878
+ # Guide*.
8518
8879
  #
8519
8880
  # When you specify a start and end time, this operation returns the
8520
8881
  # prices of the instance types within the time range that you specified
@@ -8539,7 +8900,8 @@ module Aws
8539
8900
  # retrieving the price history data, in UTC format (for example,
8540
8901
  # *YYYY*-*MM*-*DD*T*HH*\:*MM*\:*SS*Z).
8541
8902
  # @option params [Array<String>] :instance_types
8542
- # Filters the results by the specified instance types.
8903
+ # Filters the results by the specified instance types. Note that T2 and
8904
+ # HS1 instance types are not supported.
8543
8905
  # @option params [Array<String>] :product_descriptions
8544
8906
  # Filters the results by the specified basic product descriptions.
8545
8907
  # @option params [Array<Types::Filter>] :filters
@@ -8580,7 +8942,7 @@ module Aws
8580
8942
  # dry_run: false,
8581
8943
  # start_time: Time.now,
8582
8944
  # end_time: Time.now,
8583
- # instance_types: ["t1.micro"], # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
8945
+ # instance_types: ["t1.micro"], # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
8584
8946
  # product_descriptions: ["String"],
8585
8947
  # filters: [
8586
8948
  # {
@@ -8595,7 +8957,7 @@ module Aws
8595
8957
  #
8596
8958
  # @example Response structure
8597
8959
  # resp.spot_price_history #=> Array
8598
- # resp.spot_price_history[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
8960
+ # resp.spot_price_history[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
8599
8961
  # resp.spot_price_history[0].product_description #=> String, one of "Linux/UNIX", "Linux/UNIX (Amazon VPC)", "Windows", "Windows (Amazon VPC)"
8600
8962
  # resp.spot_price_history[0].spot_price #=> String
8601
8963
  # resp.spot_price_history[0].timestamp #=> Time
@@ -8706,10 +9068,10 @@ module Aws
8706
9068
  # * `availabilityZone` - The Availability Zone for the subnet. You can
8707
9069
  # also use `availability-zone` as the filter name.
8708
9070
  #
8709
- # * `available-ip-address-count` - The number of IP addresses in the
9071
+ # * `available-ip-address-count` - The number of IPv4 addresses in the
8710
9072
  # subnet that are available.
8711
9073
  #
8712
- # * `cidrBlock` - The CIDR block of the subnet. The CIDR block you
9074
+ # * `cidrBlock` - The IPv4 CIDR block of the subnet. The CIDR block you
8713
9075
  # specify must exactly match the subnet's CIDR block for information
8714
9076
  # to be returned for the subnet. You can also use `cidr` or
8715
9077
  # `cidr-block` as the filter names.
@@ -8718,6 +9080,15 @@ module Aws
8718
9080
  # the Availability Zone. You can also use `default-for-az` as the
8719
9081
  # filter name.
8720
9082
  #
9083
+ # * `ipv6-cidr-block-association.ipv6-cidr-block` - An IPv6 CIDR block
9084
+ # associated with the subnet.
9085
+ #
9086
+ # * `ipv6-cidr-block-association.association-id` - An association ID for
9087
+ # an IPv6 CIDR block associated with the subnet.
9088
+ #
9089
+ # * `ipv6-cidr-block-association.state` - The state of an IPv6 CIDR
9090
+ # block associated with the subnet.
9091
+ #
8721
9092
  # * `state` - The state of the subnet (`pending` \| `available`).
8722
9093
  #
8723
9094
  # * `subnet-id` - The ID of the subnet.
@@ -8759,6 +9130,12 @@ module Aws
8759
9130
  # resp.subnets[0].state #=> String, one of "pending", "available"
8760
9131
  # resp.subnets[0].vpc_id #=> String
8761
9132
  # resp.subnets[0].cidr_block #=> String
9133
+ # resp.subnets[0].ipv_6_cidr_block_association_set #=> Array
9134
+ # resp.subnets[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block #=> String
9135
+ # resp.subnets[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
9136
+ # resp.subnets[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.status_message #=> String
9137
+ # resp.subnets[0].ipv_6_cidr_block_association_set[0].association_id #=> String
9138
+ # resp.subnets[0].assign_ipv_6_address_on_creation #=> Boolean
8762
9139
  # resp.subnets[0].available_ip_address_count #=> Integer
8763
9140
  # resp.subnets[0].availability_zone #=> String
8764
9141
  # resp.subnets[0].default_for_az #=> Boolean
@@ -9431,7 +9808,8 @@ module Aws
9431
9808
  # @option params [Array<Types::Filter>] :filters
9432
9809
  # One or more filters.
9433
9810
  #
9434
- # * `accepter-vpc-info.cidr-block` - The CIDR block of the peer VPC.
9811
+ # * `accepter-vpc-info.cidr-block` - The IPv4 CIDR block of the peer
9812
+ # VPC.
9435
9813
  #
9436
9814
  # * `accepter-vpc-info.owner-id` - The AWS account ID of the owner of
9437
9815
  # the peer VPC.
@@ -9441,8 +9819,8 @@ module Aws
9441
9819
  # * `expiration-time` - The expiration date and time for the VPC peering
9442
9820
  # connection.
9443
9821
  #
9444
- # * `requester-vpc-info.cidr-block` - The CIDR block of the requester's
9445
- # VPC.
9822
+ # * `requester-vpc-info.cidr-block` - The IPv4 CIDR block of the
9823
+ # requester's VPC.
9446
9824
  #
9447
9825
  # * `requester-vpc-info.owner-id` - The AWS account ID of the owner of
9448
9826
  # the requester VPC.
@@ -9492,6 +9870,8 @@ module Aws
9492
9870
  # resp.vpc_peering_connections[0].accepter_vpc_info.cidr_block #=> String
9493
9871
  # resp.vpc_peering_connections[0].accepter_vpc_info.owner_id #=> String
9494
9872
  # resp.vpc_peering_connections[0].accepter_vpc_info.vpc_id #=> String
9873
+ # resp.vpc_peering_connections[0].accepter_vpc_info.ipv_6_cidr_block_set #=> Array
9874
+ # resp.vpc_peering_connections[0].accepter_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
9495
9875
  # resp.vpc_peering_connections[0].accepter_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
9496
9876
  # resp.vpc_peering_connections[0].accepter_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
9497
9877
  # resp.vpc_peering_connections[0].accepter_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -9499,6 +9879,8 @@ module Aws
9499
9879
  # resp.vpc_peering_connections[0].requester_vpc_info.cidr_block #=> String
9500
9880
  # resp.vpc_peering_connections[0].requester_vpc_info.owner_id #=> String
9501
9881
  # resp.vpc_peering_connections[0].requester_vpc_info.vpc_id #=> String
9882
+ # resp.vpc_peering_connections[0].requester_vpc_info.ipv_6_cidr_block_set #=> Array
9883
+ # resp.vpc_peering_connections[0].requester_vpc_info.ipv_6_cidr_block_set[0].ipv_6_cidr_block #=> String
9502
9884
  # resp.vpc_peering_connections[0].requester_vpc_info.peering_options.allow_egress_from_local_classic_link_to_remote_vpc #=> Boolean
9503
9885
  # resp.vpc_peering_connections[0].requester_vpc_info.peering_options.allow_egress_from_local_vpc_to_remote_classic_link #=> Boolean
9504
9886
  # resp.vpc_peering_connections[0].requester_vpc_info.peering_options.allow_dns_resolution_from_remote_vpc #=> Boolean
@@ -9528,13 +9910,22 @@ module Aws
9528
9910
  # @option params [Array<Types::Filter>] :filters
9529
9911
  # One or more filters.
9530
9912
  #
9531
- # * `cidr` - The CIDR block of the VPC. The CIDR block you specify must
9532
- # exactly match the VPC's CIDR block for information to be returned
9533
- # for the VPC. Must contain the slash followed by one or two digits
9534
- # (for example, `/28`).
9913
+ # * `cidr` - The IPv4 CIDR block of the VPC. The CIDR block you specify
9914
+ # must exactly match the VPC's CIDR block for information to be
9915
+ # returned for the VPC. Must contain the slash followed by one or two
9916
+ # digits (for example, `/28`).
9535
9917
  #
9536
9918
  # * `dhcp-options-id` - The ID of a set of DHCP options.
9537
9919
  #
9920
+ # * `ipv6-cidr-block-association.ipv6-cidr-block` - An IPv6 CIDR block
9921
+ # associated with the VPC.
9922
+ #
9923
+ # * `ipv6-cidr-block-association.association-id` - The association ID
9924
+ # for an IPv6 CIDR block associated with the VPC.
9925
+ #
9926
+ # * `ipv6-cidr-block-association.state` - The state of an IPv6 CIDR
9927
+ # block associated with the VPC.
9928
+ #
9538
9929
  # * `isDefault` - Indicates whether the VPC is the default VPC.
9539
9930
  #
9540
9931
  # * `state` - The state of the VPC (`pending` \| `available`).
@@ -9581,6 +9972,11 @@ module Aws
9581
9972
  # resp.vpcs[0].tags[0].value #=> String
9582
9973
  # resp.vpcs[0].instance_tenancy #=> String, one of "default", "dedicated", "host"
9583
9974
  # resp.vpcs[0].is_default #=> Boolean
9975
+ # resp.vpcs[0].ipv_6_cidr_block_association_set #=> Array
9976
+ # resp.vpcs[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block #=> String
9977
+ # resp.vpcs[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
9978
+ # resp.vpcs[0].ipv_6_cidr_block_association_set[0].ipv_6_cidr_block_state.status_message #=> String
9979
+ # resp.vpcs[0].ipv_6_cidr_block_association_set[0].association_id #=> String
9584
9980
  # @overload describe_vpcs(params = {})
9585
9981
  # @param [Hash] params ({})
9586
9982
  def describe_vpcs(params = {}, options = {})
@@ -10114,6 +10510,64 @@ module Aws
10114
10510
  req.send_request(options)
10115
10511
  end
10116
10512
 
10513
+ # Disassociates a CIDR block from a subnet. Currently, you can
10514
+ # disassociate an IPv6 CIDR block only. You must detach or delete all
10515
+ # gateways and resources that are associated with the CIDR block before
10516
+ # you can disassociate it.
10517
+ # @option params [required, String] :association_id
10518
+ # The association ID for the CIDR block.
10519
+ # @return [Types::DisassociateSubnetCidrBlockResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
10520
+ #
10521
+ # * {Types::DisassociateSubnetCidrBlockResult#subnet_id #SubnetId} => String
10522
+ # * {Types::DisassociateSubnetCidrBlockResult#ipv_6_cidr_block_association #Ipv6CidrBlockAssociation} => Types::SubnetIpv6CidrBlockAssociation
10523
+ #
10524
+ # @example Request syntax with placeholder values
10525
+ # resp = client.disassociate_subnet_cidr_block({
10526
+ # association_id: "String", # required
10527
+ # })
10528
+ #
10529
+ # @example Response structure
10530
+ # resp.subnet_id #=> String
10531
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block #=> String
10532
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
10533
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.status_message #=> String
10534
+ # resp.ipv_6_cidr_block_association.association_id #=> String
10535
+ # @overload disassociate_subnet_cidr_block(params = {})
10536
+ # @param [Hash] params ({})
10537
+ def disassociate_subnet_cidr_block(params = {}, options = {})
10538
+ req = build_request(:disassociate_subnet_cidr_block, params)
10539
+ req.send_request(options)
10540
+ end
10541
+
10542
+ # Disassociates a CIDR block from a VPC. Currently, you can disassociate
10543
+ # an IPv6 CIDR block only. You must detach or delete all gateways and
10544
+ # resources that are associated with the CIDR block before you can
10545
+ # disassociate it.
10546
+ # @option params [required, String] :association_id
10547
+ # The association ID for the CIDR block.
10548
+ # @return [Types::DisassociateVpcCidrBlockResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
10549
+ #
10550
+ # * {Types::DisassociateVpcCidrBlockResult#vpc_id #VpcId} => String
10551
+ # * {Types::DisassociateVpcCidrBlockResult#ipv_6_cidr_block_association #Ipv6CidrBlockAssociation} => Types::VpcIpv6CidrBlockAssociation
10552
+ #
10553
+ # @example Request syntax with placeholder values
10554
+ # resp = client.disassociate_vpc_cidr_block({
10555
+ # association_id: "String", # required
10556
+ # })
10557
+ #
10558
+ # @example Response structure
10559
+ # resp.vpc_id #=> String
10560
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block #=> String
10561
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.state #=> String, one of "associating", "associated", "disassociating", "disassociated", "failing", "failed"
10562
+ # resp.ipv_6_cidr_block_association.ipv_6_cidr_block_state.status_message #=> String
10563
+ # resp.ipv_6_cidr_block_association.association_id #=> String
10564
+ # @overload disassociate_vpc_cidr_block(params = {})
10565
+ # @param [Hash] params ({})
10566
+ def disassociate_vpc_cidr_block(params = {}, options = {})
10567
+ req = build_request(:disassociate_vpc_cidr_block, params)
10568
+ req.send_request(options)
10569
+ end
10570
+
10117
10571
  # Enables a virtual private gateway (VGW) to propagate routes to the
10118
10572
  # specified route table of a VPC.
10119
10573
  # @option params [required, String] :route_table_id
@@ -10201,7 +10655,7 @@ module Aws
10201
10655
  # which it's linked. Similarly, the DNS hostname of an instance in a
10202
10656
  # VPC resolves to its private IP address when addressed from a linked
10203
10657
  # EC2-Classic instance. For more information about ClassicLink, see
10204
- # [ClassicLink][1] in the Amazon Elastic Compute Cloud User Guide.
10658
+ # [ClassicLink][1] in the *Amazon Elastic Compute Cloud User Guide*.
10205
10659
  #
10206
10660
  #
10207
10661
  #
@@ -10404,19 +10858,19 @@ module Aws
10404
10858
  end
10405
10859
 
10406
10860
  # Returns details about the values and term of your specified
10407
- # Convertible Reserved Instances. When an offering ID is specified it
10408
- # returns information about whether the exchange is valid and can be
10409
- # performed.
10861
+ # Convertible Reserved Instances. When a target configuration is
10862
+ # specified, it returns information about whether the exchange is valid
10863
+ # and can be performed.
10410
10864
  # @option params [Boolean] :dry_run
10411
10865
  # Checks whether you have the required permissions for the action,
10412
10866
  # without actually making the request, and provides an error response.
10413
10867
  # If you have the required permissions, the error response is
10414
10868
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
10415
10869
  # @option params [required, Array<String>] :reserved_instance_ids
10416
- # The ID/s of the Convertible Reserved Instances you want to exchange.
10870
+ # The IDs of the Convertible Reserved Instances to exchange.
10417
10871
  # @option params [Array<Types::TargetConfigurationRequest>] :target_configurations
10418
10872
  # The configuration requirements of the Convertible Reserved Instances
10419
- # you want in exchange for your current Convertible Reserved Instances.
10873
+ # to exchange for your current Convertible Reserved Instances.
10420
10874
  # @return [Types::GetReservedInstancesExchangeQuoteResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
10421
10875
  #
10422
10876
  # * {Types::GetReservedInstancesExchangeQuoteResult#reserved_instance_value_set #ReservedInstanceValueSet} => Array&lt;Types::ReservedInstanceReservationValue&gt;
@@ -10637,7 +11091,7 @@ module Aws
10637
11091
  # user_data: {
10638
11092
  # data: "String",
10639
11093
  # },
10640
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
11094
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
10641
11095
  # placement: {
10642
11096
  # availability_zone: "String",
10643
11097
  # group_name: "String",
@@ -10924,9 +11378,9 @@ module Aws
10924
11378
  # resp.successful #=> Array
10925
11379
  # resp.successful[0] #=> String
10926
11380
  # resp.unsuccessful #=> Array
11381
+ # resp.unsuccessful[0].resource_id #=> String
10927
11382
  # resp.unsuccessful[0].error.code #=> String
10928
11383
  # resp.unsuccessful[0].error.message #=> String
10929
- # resp.unsuccessful[0].resource_id #=> String
10930
11384
  # @overload modify_hosts(params = {})
10931
11385
  # @param [Hash] params ({})
10932
11386
  def modify_hosts(params = {}, options = {})
@@ -11389,7 +11843,7 @@ module Aws
11389
11843
  # availability_zone: "String",
11390
11844
  # platform: "String",
11391
11845
  # instance_count: 1,
11392
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
11846
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
11393
11847
  # scope: "Availability Zone", # accepts Availability Zone, Region
11394
11848
  # },
11395
11849
  # ],
@@ -11527,12 +11981,21 @@ module Aws
11527
11981
  req.send_request(options)
11528
11982
  end
11529
11983
 
11530
- # Modifies a subnet attribute.
11984
+ # Modifies a subnet attribute. You can only modify one attribute at a
11985
+ # time.
11531
11986
  # @option params [required, String] :subnet_id
11532
11987
  # The ID of the subnet.
11533
11988
  # @option params [Types::AttributeBooleanValue] :map_public_ip_on_launch
11534
- # Specify `true` to indicate that instances launched into the specified
11535
- # subnet should be assigned public IP address.
11989
+ # Specify `true` to indicate that network interfaces created in the
11990
+ # specified subnet should be assigned a public IPv4 address. This
11991
+ # includes a network interface that's created when launching an
11992
+ # instance into the subnet (the instance therefore receives a public
11993
+ # IPv4 address).
11994
+ # @option params [Types::AttributeBooleanValue] :assign_ipv_6_address_on_creation
11995
+ # Specify `true` to indicate that network interfaces created in the
11996
+ # specified subnet should be assigned an IPv6 address. This includes a
11997
+ # network interface that's created when launching an instance into the
11998
+ # subnet (the instance therefore receives an IPv6 address).
11536
11999
  # @return [Struct] Returns an empty {Seahorse::Client::Response response}.
11537
12000
  #
11538
12001
  # @example Request syntax with placeholder values
@@ -11541,6 +12004,9 @@ module Aws
11541
12004
  # map_public_ip_on_launch: {
11542
12005
  # value: false,
11543
12006
  # },
12007
+ # assign_ipv_6_address_on_creation: {
12008
+ # value: false,
12009
+ # },
11544
12010
  # })
11545
12011
  # @overload modify_subnet_attribute(params = {})
11546
12012
  # @param [Hash] params ({})
@@ -11737,9 +12203,12 @@ module Aws
11737
12203
  req.send_request(options)
11738
12204
  end
11739
12205
 
11740
- # Enables monitoring for a running instance. For more information about
11741
- # monitoring instances, see [Monitoring Your Instances and Volumes][1]
11742
- # in the *Amazon Elastic Compute Cloud User Guide*.
12206
+ # Enables detailed monitoring for a running instance. Otherwise, basic
12207
+ # monitoring is enabled. For more information, see [Monitoring Your
12208
+ # Instances and Volumes][1] in the *Amazon Elastic Compute Cloud User
12209
+ # Guide*.
12210
+ #
12211
+ # To disable detailed monitoring, see .
11743
12212
  #
11744
12213
  #
11745
12214
  #
@@ -12275,9 +12744,9 @@ module Aws
12275
12744
  # resp.successful #=> Array
12276
12745
  # resp.successful[0] #=> String
12277
12746
  # resp.unsuccessful #=> Array
12747
+ # resp.unsuccessful[0].resource_id #=> String
12278
12748
  # resp.unsuccessful[0].error.code #=> String
12279
12749
  # resp.unsuccessful[0].error.message #=> String
12280
- # resp.unsuccessful[0].resource_id #=> String
12281
12750
  # @overload release_hosts(params = {})
12282
12751
  # @param [Hash] params ({})
12283
12752
  def release_hosts(params = {}, options = {})
@@ -12341,20 +12810,32 @@ module Aws
12341
12810
  # The rule number of the entry to replace.
12342
12811
  # @option params [required, String] :protocol
12343
12812
  # The IP protocol. You can specify `all` or `-1` to mean all protocols.
12813
+ # If you specify `all`, `-1`, or a protocol number other than `tcp`,
12814
+ # `udp`, or `icmp`, traffic on all ports is allowed, regardless of any
12815
+ # ports or ICMP types or codes you specify. If you specify protocol `58`
12816
+ # (ICMPv6) and specify an IPv4 CIDR block, traffic for all ICMP types
12817
+ # and codes allowed, regardless of any that you specify. If you specify
12818
+ # protocol `58` (ICMPv6) and specify an IPv6 CIDR block, you must
12819
+ # specify an ICMP type and code.
12344
12820
  # @option params [required, String] :rule_action
12345
12821
  # Indicates whether to allow or deny the traffic that matches the rule.
12346
12822
  # @option params [required, Boolean] :egress
12347
12823
  # Indicates whether to replace the egress rule.
12348
12824
  #
12349
12825
  # Default: If no value is specified, we replace the ingress rule.
12350
- # @option params [required, String] :cidr_block
12351
- # The network range to allow or deny, in CIDR notation.
12826
+ # @option params [String] :cidr_block
12827
+ # The IPv4 network range to allow or deny, in CIDR notation (for example
12828
+ # `172.16.0.0/24`).
12829
+ # @option params [String] :ipv_6_cidr_block
12830
+ # The IPv6 network range to allow or deny, in CIDR notation (for example
12831
+ # `2001:bd8:1234:1a00::/64`).
12352
12832
  # @option params [Types::IcmpTypeCode] :icmp_type_code
12353
- # ICMP protocol: The ICMP type and code. Required if specifying 1 (ICMP)
12354
- # for the protocol.
12833
+ # ICMP protocol: The ICMP or ICMPv6 type and code. Required if
12834
+ # specifying the ICMP (1) protocol, or protocol 58 (ICMPv6) with an IPv6
12835
+ # CIDR block.
12355
12836
  # @option params [Types::PortRange] :port_range
12356
12837
  # TCP or UDP protocols: The range of ports the rule applies to. Required
12357
- # if specifying 6 (TCP) or 17 (UDP) for the protocol.
12838
+ # if specifying TCP (6) or UDP (17) for the protocol.
12358
12839
  # @return [Struct] Returns an empty {Seahorse::Client::Response response}.
12359
12840
  #
12360
12841
  # @example Request syntax with placeholder values
@@ -12365,7 +12846,8 @@ module Aws
12365
12846
  # protocol: "String", # required
12366
12847
  # rule_action: "allow", # required, accepts allow, deny
12367
12848
  # egress: false, # required
12368
- # cidr_block: "String", # required
12849
+ # cidr_block: "String",
12850
+ # ipv_6_cidr_block: "String",
12369
12851
  # icmp_type_code: {
12370
12852
  # type: 1,
12371
12853
  # code: 1,
@@ -12384,8 +12866,8 @@ module Aws
12384
12866
 
12385
12867
  # Replaces an existing route within a route table in a VPC. You must
12386
12868
  # provide only one of the following: Internet gateway or virtual private
12387
- # gateway, NAT instance, NAT gateway, VPC peering connection, or network
12388
- # interface.
12869
+ # gateway, NAT instance, NAT gateway, VPC peering connection, network
12870
+ # interface, or egress-only Internet gateway.
12389
12871
  #
12390
12872
  # For more information about route tables, see [Route Tables][1] in the
12391
12873
  # *Amazon Virtual Private Cloud User Guide*.
@@ -12400,11 +12882,16 @@ module Aws
12400
12882
  # `DryRunOperation`. Otherwise, it is `UnauthorizedOperation`.
12401
12883
  # @option params [required, String] :route_table_id
12402
12884
  # The ID of the route table.
12403
- # @option params [required, String] :destination_cidr_block
12404
- # The CIDR address block used for the destination match. The value you
12405
- # provide must match the CIDR of an existing route in the table.
12885
+ # @option params [String] :destination_cidr_block
12886
+ # The IPv4 CIDR address block used for the destination match. The value
12887
+ # you provide must match the CIDR of an existing route in the table.
12406
12888
  # @option params [String] :gateway_id
12407
12889
  # The ID of an Internet gateway or virtual private gateway.
12890
+ # @option params [String] :destination_ipv_6_cidr_block
12891
+ # The IPv6 CIDR address block used for the destination match. The value
12892
+ # you provide must match the CIDR of an existing route in the table.
12893
+ # @option params [String] :egress_only_internet_gateway_id
12894
+ # \[IPv6 traffic only\] The ID of an egress-only Internet gateway.
12408
12895
  # @option params [String] :instance_id
12409
12896
  # The ID of a NAT instance in your VPC.
12410
12897
  # @option params [String] :network_interface_id
@@ -12412,15 +12899,17 @@ module Aws
12412
12899
  # @option params [String] :vpc_peering_connection_id
12413
12900
  # The ID of a VPC peering connection.
12414
12901
  # @option params [String] :nat_gateway_id
12415
- # The ID of a NAT gateway.
12902
+ # \[IPv4 traffic only\] The ID of a NAT gateway.
12416
12903
  # @return [Struct] Returns an empty {Seahorse::Client::Response response}.
12417
12904
  #
12418
12905
  # @example Request syntax with placeholder values
12419
12906
  # resp = client.replace_route({
12420
12907
  # dry_run: false,
12421
12908
  # route_table_id: "String", # required
12422
- # destination_cidr_block: "String", # required
12909
+ # destination_cidr_block: "String",
12423
12910
  # gateway_id: "String",
12911
+ # destination_ipv_6_cidr_block: "String",
12912
+ # egress_only_internet_gateway_id: "String",
12424
12913
  # instance_id: "String",
12425
12914
  # network_interface_id: "String",
12426
12915
  # vpc_peering_connection_id: "String",
@@ -12604,7 +13093,7 @@ module Aws
12604
13093
  # ],
12605
13094
  # user_data: "String",
12606
13095
  # addressing_type: "String",
12607
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
13096
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
12608
13097
  # placement: {
12609
13098
  # availability_zone: "String",
12610
13099
  # group_name: "String",
@@ -12647,6 +13136,12 @@ module Aws
12647
13136
  # ],
12648
13137
  # secondary_private_ip_address_count: 1,
12649
13138
  # associate_public_ip_address: false,
13139
+ # ipv_6_addresses: [
13140
+ # {
13141
+ # ipv_6_address: "String",
13142
+ # },
13143
+ # ],
13144
+ # ipv_6_address_count: 1,
12650
13145
  # },
12651
13146
  # ],
12652
13147
  # iam_instance_profile: {
@@ -12787,7 +13282,7 @@ module Aws
12787
13282
  # security_groups: ["String"],
12788
13283
  # user_data: "String",
12789
13284
  # addressing_type: "String",
12790
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
13285
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
12791
13286
  # placement: {
12792
13287
  # availability_zone: "String",
12793
13288
  # group_name: "String",
@@ -12827,6 +13322,12 @@ module Aws
12827
13322
  # ],
12828
13323
  # secondary_private_ip_address_count: 1,
12829
13324
  # associate_public_ip_address: false,
13325
+ # ipv_6_addresses: [
13326
+ # {
13327
+ # ipv_6_address: "String",
13328
+ # },
13329
+ # ],
13330
+ # ipv_6_address_count: 1,
12830
13331
  # },
12831
13332
  # ],
12832
13333
  # iam_instance_profile: {
@@ -12863,7 +13364,7 @@ module Aws
12863
13364
  # resp.spot_instance_requests[0].launch_specification.security_groups[0].group_id #=> String
12864
13365
  # resp.spot_instance_requests[0].launch_specification.user_data #=> String
12865
13366
  # resp.spot_instance_requests[0].launch_specification.addressing_type #=> String
12866
- # resp.spot_instance_requests[0].launch_specification.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
13367
+ # resp.spot_instance_requests[0].launch_specification.instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
12867
13368
  # resp.spot_instance_requests[0].launch_specification.placement.availability_zone #=> String
12868
13369
  # resp.spot_instance_requests[0].launch_specification.placement.group_name #=> String
12869
13370
  # resp.spot_instance_requests[0].launch_specification.kernel_id #=> String
@@ -12893,6 +13394,9 @@ module Aws
12893
13394
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].private_ip_addresses[0].primary #=> Boolean
12894
13395
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].secondary_private_ip_address_count #=> Integer
12895
13396
  # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].associate_public_ip_address #=> Boolean
13397
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_addresses #=> Array
13398
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
13399
+ # resp.spot_instance_requests[0].launch_specification.network_interfaces[0].ipv_6_address_count #=> Integer
12896
13400
  # resp.spot_instance_requests[0].launch_specification.iam_instance_profile.arn #=> String
12897
13401
  # resp.spot_instance_requests[0].launch_specification.iam_instance_profile.name #=> String
12898
13402
  # resp.spot_instance_requests[0].launch_specification.ebs_optimized #=> Boolean
@@ -13083,10 +13587,10 @@ module Aws
13083
13587
  # (for example, ports) must match the existing rule's values for the
13084
13588
  # rule to be revoked.
13085
13589
  #
13086
- # Each rule consists of the protocol and the CIDR range or source
13087
- # security group. For the TCP and UDP protocols, you must also specify
13088
- # the destination port or range of ports. For the ICMP protocol, you
13089
- # must also specify the ICMP type and code.
13590
+ # Each rule consists of the protocol and the IPv4 or IPv6 CIDR range or
13591
+ # source security group. For the TCP and UDP protocols, you must also
13592
+ # specify the destination port or range of ports. For the ICMP protocol,
13593
+ # you must also specify the ICMP type and code.
13090
13594
  #
13091
13595
  # Rule changes are propagated to instances within the security group as
13092
13596
  # quickly as possible. However, a small delay might occur.
@@ -13154,6 +13658,11 @@ module Aws
13154
13658
  # cidr_ip: "String",
13155
13659
  # },
13156
13660
  # ],
13661
+ # ipv_6_ranges: [
13662
+ # {
13663
+ # cidr_ipv_6: "String",
13664
+ # },
13665
+ # ],
13157
13666
  # prefix_list_ids: [
13158
13667
  # {
13159
13668
  # prefix_list_id: "String",
@@ -13258,6 +13767,11 @@ module Aws
13258
13767
  # cidr_ip: "String",
13259
13768
  # },
13260
13769
  # ],
13770
+ # ipv_6_ranges: [
13771
+ # {
13772
+ # cidr_ipv_6: "String",
13773
+ # },
13774
+ # ],
13261
13775
  # prefix_list_ids: [
13262
13776
  # {
13263
13777
  # prefix_list_id: "String",
@@ -13276,57 +13790,61 @@ module Aws
13276
13790
  # Launches the specified number of instances using an AMI for which you
13277
13791
  # have permissions.
13278
13792
  #
13279
- # When you launch an instance, it enters the `pending` state. After the
13280
- # instance is ready for you, it enters the `running` state. To check the
13281
- # state of your instance, call DescribeInstances.
13793
+ # You can specify a number of options, or leave the default options. The
13794
+ # following rules apply:
13282
13795
  #
13283
- # To ensure faster instance launches, break up large requests into
13284
- # smaller batches. For example, create five separate launch requests for
13285
- # 100 instances each instead of one launch request for 500 instances.
13796
+ # * \[EC2-VPC\] If you don't specify a subnet ID, we choose a default
13797
+ # subnet from your default VPC for you. If you don't have a default
13798
+ # VPC, you must specify a subnet ID in the request.
13286
13799
  #
13287
- # To tag your instance, ensure that it is `running` as CreateTags
13288
- # requires a resource ID. For more information about tagging, see
13289
- # [Tagging Your Amazon EC2 Resources][1].
13800
+ # * \[EC2-Classic\] If don't specify an Availability Zone, we choose
13801
+ # one for you.
13290
13802
  #
13291
- # If you don't specify a security group when launching an instance,
13292
- # Amazon EC2 uses the default security group. For more information, see
13293
- # [Security Groups][2] in the *Amazon Elastic Compute Cloud User Guide*.
13803
+ # * Some instance types must be launched into a VPC. If you do not have
13804
+ # a default VPC, or if you do not specify a subnet ID, the request
13805
+ # fails. For more information, see [Instance Types Available Only in a
13806
+ # VPC][1].
13294
13807
  #
13295
- # \[EC2-VPC only accounts\] If you don't specify a subnet in the
13296
- # request, we choose a default subnet from your default VPC for you.
13808
+ # * \[EC2-VPC\] All instances have a network interface with a primary
13809
+ # private IPv4 address. If you don't specify this address, we choose
13810
+ # one from the IPv4 range of your subnet.
13297
13811
  #
13298
- # \[EC2-Classic accounts\] If you're launching into EC2-Classic and you
13299
- # don't specify an Availability Zone, we choose one for you.
13812
+ # * Not all instance types support IPv6 addresses. For more information,
13813
+ # see [Amazon EC2 Instance Types][2].
13814
+ #
13815
+ # * If you don't specify a security group ID, we use the default
13816
+ # security group. For more information, see [Security Groups][3].
13817
+ #
13818
+ # * If any of the AMIs have a product code attached for which the user
13819
+ # has not subscribed, the request fails.
13820
+ #
13821
+ # To ensure faster instance launches, break up large requests into
13822
+ # smaller batches. For example, create 5 separate launch requests for
13823
+ # 100 instances each instead of 1 launch request for 500 instances.
13824
+ #
13825
+ # An instance is ready for you to use when it's in the `running` state.
13826
+ # You can check the state of your instance using DescribeInstances.
13827
+ # After launch, you can apply tags to your running instance (requires a
13828
+ # resource ID). For more information, see CreateTags and [Tagging Your
13829
+ # Amazon EC2 Resources][4].
13300
13830
  #
13301
13831
  # Linux instances have access to the public key of the key pair at boot.
13302
13832
  # You can use this key to provide secure access to the instance. Amazon
13303
13833
  # EC2 public images use this feature to provide secure access without
13304
- # passwords. For more information, see [Key Pairs][3] in the *Amazon
13834
+ # passwords. For more information, see [Key Pairs][5] in the *Amazon
13305
13835
  # Elastic Compute Cloud User Guide*.
13306
13836
  #
13307
- # You can provide optional user data when launching an instance. For
13308
- # more information, see [Instance Metadata][4] in the *Amazon Elastic
13309
- # Compute Cloud User Guide*.
13310
- #
13311
- # If any of the AMIs have a product code attached for which the user has
13312
- # not subscribed, `RunInstances` fails.
13313
- #
13314
- # Some instance types can only be launched into a VPC. If you do not
13315
- # have a default VPC, or if you do not specify a subnet ID in the
13316
- # request, `RunInstances` fails. For more information, see [Instance
13317
- # Types Available Only in a VPC][5].
13318
- #
13319
- # For more information about troubleshooting, see [What To Do If An
13320
- # Instance Immediately Terminates][6], and [Troubleshooting Connecting
13321
- # to Your Instance][7] in the *Amazon Elastic Compute Cloud User Guide*.
13837
+ # For troubleshooting, see [What To Do If An Instance Immediately
13838
+ # Terminates][6], and [Troubleshooting Connecting to Your Instance][7]
13839
+ # in the *Amazon Elastic Compute Cloud User Guide*.
13322
13840
  #
13323
13841
  #
13324
13842
  #
13325
- # [1]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html
13326
- # [2]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-network-security.html
13327
- # [3]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html
13328
- # [4]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/AESDG-chapter-instancedata.html
13329
- # [5]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-vpc.html#vpc-only-instance-types
13843
+ # [1]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-vpc.html#vpc-only-instance-types
13844
+ # [2]: http://aws.amazon.com/ec2/instance-types/
13845
+ # [3]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/using-network-security.html
13846
+ # [4]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_Tags.html
13847
+ # [5]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-key-pairs.html
13330
13848
  # [6]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/Using_InstanceStraightToTerminated.html
13331
13849
  # [7]: http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/TroubleshootingInstancesConnecting.html
13332
13850
  # @option params [Boolean] :dry_run
@@ -13438,10 +13956,8 @@ module Aws
13438
13956
  # \[EC2-VPC\] The ID of the subnet to launch the instance into.
13439
13957
  # @option params [Boolean] :disable_api_termination
13440
13958
  # If you set this parameter to `true`, you can't terminate the instance
13441
- # using the Amazon EC2 console, CLI, or API; otherwise, you can. If you
13442
- # set this parameter to `true` and then later want to be able to
13443
- # terminate the instance, you must first change the value of the
13444
- # `disableApiTermination` attribute to `false` using
13959
+ # using the Amazon EC2 console, CLI, or API; otherwise, you can. To
13960
+ # change this attribute to `false` after launch, use
13445
13961
  # ModifyInstanceAttribute. Alternatively, if you set
13446
13962
  # `InstanceInitiatedShutdownBehavior` to `terminate`, you can terminate
13447
13963
  # the instance by running the shutdown command from the instance.
@@ -13454,19 +13970,27 @@ module Aws
13454
13970
  #
13455
13971
  # Default: `stop`
13456
13972
  # @option params [String] :private_ip_address
13457
- # \[EC2-VPC\] The primary IP address. You must specify a value from the
13458
- # IP address range of the subnet.
13459
- #
13460
- # Only one private IP address can be designated as primary. Therefore,
13461
- # you can't specify this parameter if `PrivateIpAddresses.n.Primary` is
13462
- # set to `true` and `PrivateIpAddresses.n.PrivateIpAddress` is set to an
13463
- # IP address.
13464
- #
13465
- # You cannot specify this option if you're launching more than one
13466
- # instance in the request.
13467
- #
13468
- # Default: We select an IP address from the IP address range of the
13469
- # subnet.
13973
+ # \[EC2-VPC\] The primary IPv4 address. You must specify a value from
13974
+ # the IPv4 address range of the subnet.
13975
+ #
13976
+ # Only one private IP address can be designated as primary. You can't
13977
+ # specify this option if you've specified the option to designate a
13978
+ # private IP address as the primary IP address in a network interface
13979
+ # specification. You cannot specify this option if you're launching
13980
+ # more than one instance in the request.
13981
+ # @option params [Array<Types::InstanceIpv6Address>] :ipv_6_addresses
13982
+ # \[EC2-VPC\] Specify one or more IPv6 addresses from the range of the
13983
+ # subnet to associate with the primary network interface. You cannot
13984
+ # specify this option and the option to assign a number of IPv6
13985
+ # addresses in the same request. You cannot specify this option if
13986
+ # you've specified a minimum number of instances to launch.
13987
+ # @option params [Integer] :ipv_6_address_count
13988
+ # \[EC2-VPC\] A number of IPv6 addresses to associate with the primary
13989
+ # network interface. Amazon EC2 chooses the IPv6 addresses from the
13990
+ # range of your subnet. You cannot specify this option and the option to
13991
+ # assign specific IPv6 addresses in the same request. You can specify
13992
+ # this option if you've specified a minimum number of instances to
13993
+ # launch.
13470
13994
  # @option params [String] :client_token
13471
13995
  # Unique, case-sensitive identifier you provide to ensure the
13472
13996
  # idempotency of the request. For more information, see [Ensuring
@@ -13509,7 +14033,7 @@ module Aws
13509
14033
  # security_groups: ["String"],
13510
14034
  # security_group_ids: ["String"],
13511
14035
  # user_data: "String",
13512
- # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge
14036
+ # instance_type: "t1.micro", # accepts t1.micro, t2.nano, t2.micro, t2.small, t2.medium, t2.large, t2.xlarge, t2.2xlarge, m1.small, m1.medium, m1.large, m1.xlarge, m3.medium, m3.large, m3.xlarge, m3.2xlarge, m4.large, m4.xlarge, m4.2xlarge, m4.4xlarge, m4.10xlarge, m4.16xlarge, m2.xlarge, m2.2xlarge, m2.4xlarge, cr1.8xlarge, r3.large, r3.xlarge, r3.2xlarge, r3.4xlarge, r3.8xlarge, r4.large, r4.xlarge, r4.2xlarge, r4.4xlarge, r4.8xlarge, r4.16xlarge, x1.16xlarge, x1.32xlarge, i2.xlarge, i2.2xlarge, i2.4xlarge, i2.8xlarge, hi1.4xlarge, hs1.8xlarge, c1.medium, c1.xlarge, c3.large, c3.xlarge, c3.2xlarge, c3.4xlarge, c3.8xlarge, c4.large, c4.xlarge, c4.2xlarge, c4.4xlarge, c4.8xlarge, cc1.4xlarge, cc2.8xlarge, g2.2xlarge, g2.8xlarge, cg1.4xlarge, p2.xlarge, p2.8xlarge, p2.16xlarge, d2.xlarge, d2.2xlarge, d2.4xlarge, d2.8xlarge, f1.2xlarge, f1.16xlarge
13513
14037
  # placement: {
13514
14038
  # availability_zone: "String",
13515
14039
  # group_name: "String",
@@ -13541,6 +14065,12 @@ module Aws
13541
14065
  # disable_api_termination: false,
13542
14066
  # instance_initiated_shutdown_behavior: "stop", # accepts stop, terminate
13543
14067
  # private_ip_address: "String",
14068
+ # ipv_6_addresses: [
14069
+ # {
14070
+ # ipv_6_address: "String",
14071
+ # },
14072
+ # ],
14073
+ # ipv_6_address_count: 1,
13544
14074
  # client_token: "String",
13545
14075
  # additional_info: "String",
13546
14076
  # network_interfaces: [
@@ -13560,6 +14090,12 @@ module Aws
13560
14090
  # ],
13561
14091
  # secondary_private_ip_address_count: 1,
13562
14092
  # associate_public_ip_address: false,
14093
+ # ipv_6_addresses: [
14094
+ # {
14095
+ # ipv_6_address: "String",
14096
+ # },
14097
+ # ],
14098
+ # ipv_6_address_count: 1,
13563
14099
  # },
13564
14100
  # ],
13565
14101
  # iam_instance_profile: {
@@ -13589,7 +14125,7 @@ module Aws
13589
14125
  # resp.instances[0].product_codes #=> Array
13590
14126
  # resp.instances[0].product_codes[0].product_code_id #=> String
13591
14127
  # resp.instances[0].product_codes[0].product_code_type #=> String, one of "devpay", "marketplace"
13592
- # resp.instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge"
14128
+ # resp.instances[0].instance_type #=> String, one of "t1.micro", "t2.nano", "t2.micro", "t2.small", "t2.medium", "t2.large", "t2.xlarge", "t2.2xlarge", "m1.small", "m1.medium", "m1.large", "m1.xlarge", "m3.medium", "m3.large", "m3.xlarge", "m3.2xlarge", "m4.large", "m4.xlarge", "m4.2xlarge", "m4.4xlarge", "m4.10xlarge", "m4.16xlarge", "m2.xlarge", "m2.2xlarge", "m2.4xlarge", "cr1.8xlarge", "r3.large", "r3.xlarge", "r3.2xlarge", "r3.4xlarge", "r3.8xlarge", "r4.large", "r4.xlarge", "r4.2xlarge", "r4.4xlarge", "r4.8xlarge", "r4.16xlarge", "x1.16xlarge", "x1.32xlarge", "i2.xlarge", "i2.2xlarge", "i2.4xlarge", "i2.8xlarge", "hi1.4xlarge", "hs1.8xlarge", "c1.medium", "c1.xlarge", "c3.large", "c3.xlarge", "c3.2xlarge", "c3.4xlarge", "c3.8xlarge", "c4.large", "c4.xlarge", "c4.2xlarge", "c4.4xlarge", "c4.8xlarge", "cc1.4xlarge", "cc2.8xlarge", "g2.2xlarge", "g2.8xlarge", "cg1.4xlarge", "p2.xlarge", "p2.8xlarge", "p2.16xlarge", "d2.xlarge", "d2.2xlarge", "d2.4xlarge", "d2.8xlarge", "f1.2xlarge", "f1.16xlarge"
13593
14129
  # resp.instances[0].launch_time #=> Time
13594
14130
  # resp.instances[0].placement.availability_zone #=> String
13595
14131
  # resp.instances[0].placement.group_name #=> String
@@ -13656,6 +14192,8 @@ module Aws
13656
14192
  # resp.instances[0].network_interfaces[0].private_ip_addresses[0].association.public_ip #=> String
13657
14193
  # resp.instances[0].network_interfaces[0].private_ip_addresses[0].association.public_dns_name #=> String
13658
14194
  # resp.instances[0].network_interfaces[0].private_ip_addresses[0].association.ip_owner_id #=> String
14195
+ # resp.instances[0].network_interfaces[0].ipv_6_addresses #=> Array
14196
+ # resp.instances[0].network_interfaces[0].ipv_6_addresses[0].ipv_6_address #=> String
13659
14197
  # resp.instances[0].iam_instance_profile.arn #=> String
13660
14198
  # resp.instances[0].iam_instance_profile.id #=> String
13661
14199
  # resp.instances[0].ebs_optimized #=> Boolean
@@ -13766,6 +14304,12 @@ module Aws
13766
14304
  # associate_public_ip_address: false,
13767
14305
  # groups: ["String"],
13768
14306
  # delete_on_termination: false,
14307
+ # ipv_6_addresses: [
14308
+ # {
14309
+ # ipv_6_address: "Ipv6Address",
14310
+ # },
14311
+ # ],
14312
+ # ipv_6_address_count: 1,
13769
14313
  # },
13770
14314
  # ],
13771
14315
  # iam_instance_profile: {
@@ -13987,6 +14531,33 @@ module Aws
13987
14531
  req.send_request(options)
13988
14532
  end
13989
14533
 
14534
+ # Unassigns one or more IPv6 addresses from a network interface.
14535
+ # @option params [required, String] :network_interface_id
14536
+ # The ID of the network interface.
14537
+ # @option params [required, Array<String>] :ipv_6_addresses
14538
+ # The IPv6 addresses to unassign from the network interface.
14539
+ # @return [Types::UnassignIpv6AddressesResult] Returns a {Seahorse::Client::Response response} object which responds to the following methods:
14540
+ #
14541
+ # * {Types::UnassignIpv6AddressesResult#network_interface_id #NetworkInterfaceId} => String
14542
+ # * {Types::UnassignIpv6AddressesResult#unassigned_ipv_6_addresses #UnassignedIpv6Addresses} => Array&lt;String&gt;
14543
+ #
14544
+ # @example Request syntax with placeholder values
14545
+ # resp = client.unassign_ipv_6_addresses({
14546
+ # network_interface_id: "String", # required
14547
+ # ipv_6_addresses: ["String"], # required
14548
+ # })
14549
+ #
14550
+ # @example Response structure
14551
+ # resp.network_interface_id #=> String
14552
+ # resp.unassigned_ipv_6_addresses #=> Array
14553
+ # resp.unassigned_ipv_6_addresses[0] #=> String
14554
+ # @overload unassign_ipv_6_addresses(params = {})
14555
+ # @param [Hash] params ({})
14556
+ def unassign_ipv_6_addresses(params = {}, options = {})
14557
+ req = build_request(:unassign_ipv_6_addresses, params)
14558
+ req.send_request(options)
14559
+ end
14560
+
13990
14561
  # Unassigns one or more secondary private IP addresses from a network
13991
14562
  # interface.
13992
14563
  # @option params [required, String] :network_interface_id
@@ -14009,9 +14580,9 @@ module Aws
14009
14580
  req.send_request(options)
14010
14581
  end
14011
14582
 
14012
- # Disables monitoring for a running instance. For more information about
14013
- # monitoring instances, see [Monitoring Your Instances and Volumes][1]
14014
- # in the *Amazon Elastic Compute Cloud User Guide*.
14583
+ # Disables detailed monitoring for a running instance. For more
14584
+ # information, see [Monitoring Your Instances and Volumes][1] in the
14585
+ # *Amazon Elastic Compute Cloud User Guide*.
14015
14586
  #
14016
14587
  #
14017
14588
  #
@@ -14057,7 +14628,7 @@ module Aws
14057
14628
  params: params,
14058
14629
  config: config)
14059
14630
  context[:gem_name] = 'aws-sdk-ec2'
14060
- context[:gem_version] = '1.0.0.rc1'
14631
+ context[:gem_version] = '1.0.0.rc2'
14061
14632
  Seahorse::Client::Request.new(handlers, context)
14062
14633
  end
14063
14634