/*
 * Copyright 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.
 */
/*
 * Do not modify this file. This file is generated from the network-firewall-2020-11-12.normal.json service model.
 */
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.NetworkFirewall.Model
{
    /// 
    /// Container for the parameters to the AssociateSubnets operation.
    /// Associates the specified subnets in the Amazon VPC to the firewall. You can specify
    /// one subnet for each of the Availability Zones that the VPC spans. 
    /// 
    ///  
    /// 
    /// This request creates an Network Firewall firewall endpoint in each of the subnets.
    /// To enable the firewall's protections, you must also modify the VPC's route tables
    /// for each subnet's Availability Zone, to redirect the traffic that's coming into and
    /// going out of the zone through the firewall endpoint. 
    /// 
    /// 
    public partial class AssociateSubnetsRequest : AmazonNetworkFirewallRequest
    {
        private string _firewallArn;
        private string _firewallName;
        private List _subnetMappings = new List();
        private string _updateToken;
        /// 
        /// Gets and sets the property FirewallArn. 
        /// 
        /// The Amazon Resource Name (ARN) of the firewall.
        /// 
        ///  
        /// 
        /// You must specify the ARN or the name, and you can specify both. 
        /// 
        /// 
        [AWSProperty(Min=1, Max=256)]
        public string FirewallArn
        {
            get { return this._firewallArn; }
            set { this._firewallArn = value; }
        }
        // Check to see if FirewallArn property is set
        internal bool IsSetFirewallArn()
        {
            return this._firewallArn != null;
        }
        /// 
        /// Gets and sets the property FirewallName. 
        /// 
        /// The descriptive name of the firewall. You can't change the name of a firewall after
        /// you create it.
        /// 
        ///  
        /// 
        /// You must specify the ARN or the name, and you can specify both. 
        /// 
        /// 
        [AWSProperty(Min=1, Max=128)]
        public string FirewallName
        {
            get { return this._firewallName; }
            set { this._firewallName = value; }
        }
        // Check to see if FirewallName property is set
        internal bool IsSetFirewallName()
        {
            return this._firewallName != null;
        }
        /// 
        /// Gets and sets the property SubnetMappings. 
        /// 
        /// The IDs of the subnets that you want to associate with the firewall. 
        /// 
        /// 
        [AWSProperty(Required=true)]
        public List SubnetMappings
        {
            get { return this._subnetMappings; }
            set { this._subnetMappings = value; }
        }
        // Check to see if SubnetMappings property is set
        internal bool IsSetSubnetMappings()
        {
            return this._subnetMappings != null && this._subnetMappings.Count > 0; 
        }
        /// 
        /// Gets and sets the property UpdateToken. 
        /// 
        /// An optional token that you can use for optimistic locking. Network Firewall returns
        /// a token to your requests that access the firewall. The token marks the state of the
        /// firewall resource at the time of the request. 
        /// 
        ///  
        /// 
        /// To make an unconditional change to the firewall, omit the token in your update request.
        /// Without the token, Network Firewall performs your updates regardless of whether the
        /// firewall has changed since you last retrieved it.
        /// 
        ///  
        /// 
        /// To make a conditional change to the firewall, provide the token in your update request.
        /// Network Firewall uses the token to ensure that the firewall hasn't changed since you
        /// last retrieved it. If it has changed, the operation fails with an InvalidTokenException.
        /// If this happens, retrieve the firewall again to get a current copy of it with a new
        /// token. Reapply your changes as needed, then try the operation again using the new
        /// token. 
        /// 
        /// 
        [AWSProperty(Min=1, Max=1024)]
        public string UpdateToken
        {
            get { return this._updateToken; }
            set { this._updateToken = value; }
        }
        // Check to see if UpdateToken property is set
        internal bool IsSetUpdateToken()
        {
            return this._updateToken != null;
        }
    }
}