/*
 * Copyright 2018-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance with
 * the License. A copy of the License is located at
 * 
 * http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
 * CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions
 * and limitations under the License.
 */
package com.amazonaws.services.ec2.model;
import java.io.Serializable;
import javax.annotation.Generated;
import com.amazonaws.AmazonWebServiceRequest;
import com.amazonaws.Request;
import com.amazonaws.services.ec2.model.transform.DescribeVpcsRequestMarshaller;
/**
 * 
 */
@Generated("com.amazonaws:aws-java-sdk-code-generator")
public class DescribeVpcsRequest extends AmazonWebServiceRequest implements Serializable, Cloneable, DryRunSupportedRequest 
     * The filters.
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     * The IDs of the VPCs.
     *  
     * Default: Describes all your VPCs.
     *  
     * The token returned from a previous paginated request. Pagination continues from the end of the items returned by
     * the previous request.
     *  
     * The maximum number of items to return for this request. To get the next page of items, make another request with
     * the token returned in the output. For more information, see Pagination.
     *  
     * The filters.
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     *  
     * 
     * 
*/
    private com.amazonaws.internal.SdkInternalListcidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match the
     * VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or two digits
     * (for example, /28).
     * cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     * cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated with
     * the VPC.
     * cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     * dhcp-options-id - The ID of a set of DHCP options.
     * ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     * ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6 CIDR
     * block is allocated.
     * ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block associated
     * with the VPC.
     * ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     * is-default - Indicates whether the VPC is the default VPC.
     * owner-id - The ID of the Amazon Web Services account that owns the VPC.
     * state - The state of the VPC (pending | available).
     * tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag key in
     * the filter name and the tag value as the filter value. For example, to find all resources that have a tag with
     * the key Owner and the value TeamA, specify tag:Owner for the filter name
     * and TeamA for the filter value.
     * tag-key - The key of a tag assigned to the resource. Use this filter to find all resources assigned
     * a tag with a specific key, regardless of the tag value.
     * vpc-id - The ID of the VPC.
     * 
     * 
* 
     * @return The filters.cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match the
     * VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or two digits
     * (for example, /28).
     * cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     * cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated with
     * the VPC.
     * cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     * dhcp-options-id - The ID of a set of DHCP options.
     * ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     * ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6 CIDR
     * block is allocated.
     * ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block associated
     * with the VPC.
     * ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     * is-default - Indicates whether the VPC is the default VPC.
     * owner-id - The ID of the Amazon Web Services account that owns the VPC.
     * state - The state of the VPC (pending | available).
     * tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag key in
     * the filter name and the tag value as the filter value. For example, to find all resources that have a tag with
     * the key Owner and the value TeamA, specify tag:Owner for the filter name
     * and TeamA for the filter value.
     * tag-key - The key of a tag assigned to the resource. Use this filter to find all resources assigned
     * a tag with a specific key, regardless of the tag value.
     * vpc-id - The ID of the VPC.
     * 
     *         cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match
     *         the VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one
     *         or two digits (for example, /28).
     *         
     *         cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     *         
     *         cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated
     *         with the VPC.
     *         
     *         cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     *         
     *         dhcp-options-id - The ID of a set of DHCP options.
     *         
     *         ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     *         
     *         ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6
     *         CIDR block is allocated.
     *         
     *         ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block
     *         associated with the VPC.
     *         
     *         ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     *         
     *         is-default - Indicates whether the VPC is the default VPC.
     *         
     *         owner-id - The ID of the Amazon Web Services account that owns the VPC.
     *         
     *         state - The state of the VPC (pending | available).
     *         
     *         tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag
     *         key in the filter name and the tag value as the filter value. For example, to find all resources that
     *         have a tag with the key Owner and the value TeamA, specify
     *         tag:Owner for the filter name and TeamA for the filter value.
     *         
     *         tag-key - The key of a tag assigned to the resource. Use this filter to find all resources
     *         assigned a tag with a specific key, regardless of the tag value.
     *         
     *         vpc-id - The ID of the VPC.
     *         
* The filters. *
*
     * cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match the
     * VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or two digits
     * (for example, /28).
     * 
     * cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     * 
     * cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated with
     * the VPC.
     * 
     * cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     * 
     * dhcp-options-id - The ID of a set of DHCP options.
     * 
     * ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     * 
     * ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6 CIDR
     * block is allocated.
     * 
     * ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block associated
     * with the VPC.
     * 
     * ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     * 
     * is-default - Indicates whether the VPC is the default VPC.
     * 
     * owner-id - The ID of the Amazon Web Services account that owns the VPC.
     * 
     * state - The state of the VPC (pending | available).
     * 
     * tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag key in
     * the filter name and the tag value as the filter value. For example, to find all resources that have a tag with
     * the key Owner and the value TeamA, specify tag:Owner for the filter name
     * and TeamA for the filter value.
     * 
     * tag-key - The key of a tag assigned to the resource. Use this filter to find all resources assigned
     * a tag with a specific key, regardless of the tag value.
     * 
     * vpc-id - The ID of the VPC.
     * 
     *        cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match
     *        the VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or
     *        two digits (for example, /28).
     *        
     *        cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     *        
     *        cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated
     *        with the VPC.
     *        
     *        cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     *        
     *        dhcp-options-id - The ID of a set of DHCP options.
     *        
     *        ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     *        
     *        ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6
     *        CIDR block is allocated.
     *        
     *        ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block
     *        associated with the VPC.
     *        
     *        ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     *        
     *        is-default - Indicates whether the VPC is the default VPC.
     *        
     *        owner-id - The ID of the Amazon Web Services account that owns the VPC.
     *        
     *        state - The state of the VPC (pending | available).
     *        
     *        tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag
     *        key in the filter name and the tag value as the filter value. For example, to find all resources that have
     *        a tag with the key Owner and the value TeamA, specify tag:Owner for
     *        the filter name and TeamA for the filter value.
     *        
     *        tag-key - The key of a tag assigned to the resource. Use this filter to find all resources
     *        assigned a tag with a specific key, regardless of the tag value.
     *        
     *        vpc-id - The ID of the VPC.
     *        
* The filters. *
*
     * cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match the
     * VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or two digits
     * (for example, /28).
     * 
     * cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     * 
     * cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated with
     * the VPC.
     * 
     * cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     * 
     * dhcp-options-id - The ID of a set of DHCP options.
     * 
     * ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     * 
     * ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6 CIDR
     * block is allocated.
     * 
     * ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block associated
     * with the VPC.
     * 
     * ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     * 
     * is-default - Indicates whether the VPC is the default VPC.
     * 
     * owner-id - The ID of the Amazon Web Services account that owns the VPC.
     * 
     * state - The state of the VPC (pending | available).
     * 
     * tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag key in
     * the filter name and the tag value as the filter value. For example, to find all resources that have a tag with
     * the key Owner and the value TeamA, specify tag:Owner for the filter name
     * and TeamA for the filter value.
     * 
     * tag-key - The key of a tag assigned to the resource. Use this filter to find all resources assigned
     * a tag with a specific key, regardless of the tag value.
     * 
     * vpc-id - The ID of the VPC.
     * 
* NOTE: This method appends the values to the existing list (if any). Use * {@link #setFilters(java.util.Collection)} or {@link #withFilters(java.util.Collection)} if you want to override * the existing values. *
* * @param filters * The filters. *
     *        cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match
     *        the VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or
     *        two digits (for example, /28).
     *        
     *        cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     *        
     *        cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated
     *        with the VPC.
     *        
     *        cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     *        
     *        dhcp-options-id - The ID of a set of DHCP options.
     *        
     *        ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     *        
     *        ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6
     *        CIDR block is allocated.
     *        
     *        ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block
     *        associated with the VPC.
     *        
     *        ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     *        
     *        is-default - Indicates whether the VPC is the default VPC.
     *        
     *        owner-id - The ID of the Amazon Web Services account that owns the VPC.
     *        
     *        state - The state of the VPC (pending | available).
     *        
     *        tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag
     *        key in the filter name and the tag value as the filter value. For example, to find all resources that have
     *        a tag with the key Owner and the value TeamA, specify tag:Owner for
     *        the filter name and TeamA for the filter value.
     *        
     *        tag-key - The key of a tag assigned to the resource. Use this filter to find all resources
     *        assigned a tag with a specific key, regardless of the tag value.
     *        
     *        vpc-id - The ID of the VPC.
     *        
* The filters. *
*
     * cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match the
     * VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or two digits
     * (for example, /28).
     * 
     * cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     * 
     * cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated with
     * the VPC.
     * 
     * cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     * 
     * dhcp-options-id - The ID of a set of DHCP options.
     * 
     * ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     * 
     * ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6 CIDR
     * block is allocated.
     * 
     * ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block associated
     * with the VPC.
     * 
     * ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     * 
     * is-default - Indicates whether the VPC is the default VPC.
     * 
     * owner-id - The ID of the Amazon Web Services account that owns the VPC.
     * 
     * state - The state of the VPC (pending | available).
     * 
     * tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag key in
     * the filter name and the tag value as the filter value. For example, to find all resources that have a tag with
     * the key Owner and the value TeamA, specify tag:Owner for the filter name
     * and TeamA for the filter value.
     * 
     * tag-key - The key of a tag assigned to the resource. Use this filter to find all resources assigned
     * a tag with a specific key, regardless of the tag value.
     * 
     * vpc-id - The ID of the VPC.
     * 
     *        cidr - The primary IPv4 CIDR block of the VPC. The CIDR block you specify must exactly match
     *        the VPC's CIDR block for information to be returned for the VPC. Must contain the slash followed by one or
     *        two digits (for example, /28).
     *        
     *        cidr-block-association.cidr-block - An IPv4 CIDR block associated with the VPC.
     *        
     *        cidr-block-association.association-id - The association ID for an IPv4 CIDR block associated
     *        with the VPC.
     *        
     *        cidr-block-association.state - The state of an IPv4 CIDR block associated with the VPC.
     *        
     *        dhcp-options-id - The ID of a set of DHCP options.
     *        
     *        ipv6-cidr-block-association.ipv6-cidr-block - An IPv6 CIDR block associated with the VPC.
     *        
     *        ipv6-cidr-block-association.ipv6-pool - The ID of the IPv6 address pool from which the IPv6
     *        CIDR block is allocated.
     *        
     *        ipv6-cidr-block-association.association-id - The association ID for an IPv6 CIDR block
     *        associated with the VPC.
     *        
     *        ipv6-cidr-block-association.state - The state of an IPv6 CIDR block associated with the VPC.
     *        
     *        is-default - Indicates whether the VPC is the default VPC.
     *        
     *        owner-id - The ID of the Amazon Web Services account that owns the VPC.
     *        
     *        state - The state of the VPC (pending | available).
     *        
     *        tag:<key> - The key/value combination of a tag assigned to the resource. Use the tag
     *        key in the filter name and the tag value as the filter value. For example, to find all resources that have
     *        a tag with the key Owner and the value TeamA, specify tag:Owner for
     *        the filter name and TeamA for the filter value.
     *        
     *        tag-key - The key of a tag assigned to the resource. Use this filter to find all resources
     *        assigned a tag with a specific key, regardless of the tag value.
     *        
     *        vpc-id - The ID of the VPC.
     *        
* The IDs of the VPCs. *
** Default: Describes all your VPCs. *
* * @return The IDs of the VPCs. *
     *         Default: Describes all your VPCs.
     */
    public java.util.List 
     * The IDs of the VPCs.
     *  
     * Default: Describes all your VPCs.
     * 
     *        Default: Describes all your VPCs.
     */
    public void setVpcIds(java.util.Collection 
     * The IDs of the VPCs.
     *  
     * Default: Describes all your VPCs.
     *  
     * NOTE: This method appends the values to the existing list (if any). Use
     * {@link #setVpcIds(java.util.Collection)} or {@link #withVpcIds(java.util.Collection)} if you want to override the
     * existing values.
     * 
     *        Default: Describes all your VPCs.
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public DescribeVpcsRequest withVpcIds(String... vpcIds) {
        if (this.vpcIds == null) {
            setVpcIds(new com.amazonaws.internal.SdkInternalList 
     * The IDs of the VPCs.
     *  
     * Default: Describes all your VPCs.
     * 
     *        Default: Describes all your VPCs.
     * @return Returns a reference to this object so that method calls can be chained together.
     */
    public DescribeVpcsRequest withVpcIds(java.util.Collection 
     * The token returned from a previous paginated request. Pagination continues from the end of the items returned by
     * the previous request.
     *  
     * The token returned from a previous paginated request. Pagination continues from the end of the items returned by
     * the previous request.
     *  
     * The token returned from a previous paginated request. Pagination continues from the end of the items returned by
     * the previous request.
     *  
     * The maximum number of items to return for this request. To get the next page of items, make another request with
     * the token returned in the output. For more information, see Pagination.
     *  
     * The maximum number of items to return for this request. To get the next page of items, make another request with
     * the token returned in the output. For more information, see Pagination.
     *  
     * The maximum number of items to return for this request. To get the next page of items, make another request with
     * the token returned in the output. For more information, see Pagination.
     *