/*
* 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 DisassociateSubnets operation.
/// Removes the specified subnet associations from the firewall. This removes the firewall
/// endpoints from the subnets and removes any network filtering protections that the
/// endpoints were providing.
///
public partial class DisassociateSubnetsRequest : AmazonNetworkFirewallRequest
{
private string _firewallArn;
private string _firewallName;
private List _subnetIds = 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 SubnetIds.
///
/// The unique identifiers for the subnets that you want to disassociate.
///
///
[AWSProperty(Required=true)]
public List SubnetIds
{
get { return this._subnetIds; }
set { this._subnetIds = value; }
}
// Check to see if SubnetIds property is set
internal bool IsSetSubnetIds()
{
return this._subnetIds != null && this._subnetIds.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;
}
}
}