/*
* 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 AssociateFirewallPolicy operation.
/// Associates a FirewallPolicy to a Firewall.
///
///
///
/// A firewall policy defines how to monitor and manage your VPC network traffic, using
/// a collection of inspection rule groups and other settings. Each firewall requires
/// one firewall policy association, and you can use the same firewall policy for multiple
/// firewalls.
///
///
public partial class AssociateFirewallPolicyRequest : AmazonNetworkFirewallRequest
{
private string _firewallArn;
private string _firewallName;
private string _firewallPolicyArn;
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 FirewallPolicyArn.
///
/// The Amazon Resource Name (ARN) of the firewall policy.
///
///
[AWSProperty(Required=true, Min=1, Max=256)]
public string FirewallPolicyArn
{
get { return this._firewallPolicyArn; }
set { this._firewallPolicyArn = value; }
}
// Check to see if FirewallPolicyArn property is set
internal bool IsSetFirewallPolicyArn()
{
return this._firewallPolicyArn != null;
}
///
/// 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;
}
}
}