/*
* 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 wafv2-2019-07-29.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.WAFV2.Model
{
///
/// A rule group defines a collection of rules to inspect and control web requests that
/// you can use in a WebACL. When you create a rule group, you define an immutable
/// capacity limit. If you update a rule group, you must stay within the capacity. This
/// allows others to reuse the rule group with confidence in its capacity requirements.
///
public partial class RuleGroup
{
private string _arn;
private List _availableLabels = new List();
private long? _capacity;
private List _consumedLabels = new List();
private Dictionary _customResponseBodies = new Dictionary();
private string _description;
private string _id;
private string _labelNamespace;
private string _name;
private List _rules = new List();
private VisibilityConfig _visibilityConfig;
///
/// Gets and sets the property ARN.
///
/// The Amazon Resource Name (ARN) of the entity.
///
///
[AWSProperty(Required=true, Min=20, Max=2048)]
public string ARN
{
get { return this._arn; }
set { this._arn = value; }
}
// Check to see if ARN property is set
internal bool IsSetARN()
{
return this._arn != null;
}
///
/// Gets and sets the property AvailableLabels.
///
/// The labels that one or more rules in this rule group add to matching web requests.
/// These labels are defined in the RuleLabels
for a Rule.
///
///
public List AvailableLabels
{
get { return this._availableLabels; }
set { this._availableLabels = value; }
}
// Check to see if AvailableLabels property is set
internal bool IsSetAvailableLabels()
{
return this._availableLabels != null && this._availableLabels.Count > 0;
}
///
/// Gets and sets the property Capacity.
///
/// The web ACL capacity units (WCUs) required for this rule group.
///
///
///
/// When you create your own rule group, you define this, and you cannot change it after
/// creation. When you add or modify the rules in a rule group, WAF enforces this limit.
/// You can check the capacity for a set of rules using CheckCapacity.
///
///
///
/// WAF uses WCUs to calculate and control the operating resources that are used to run
/// your rules, rule groups, and web ACLs. WAF calculates capacity differently for each
/// rule type, to reflect the relative cost of each rule. Simple rules that cost little
/// to run use fewer WCUs than more complex rules that use more processing power. Rule
/// group capacity is fixed at creation, which helps users plan their web ACL WCU usage
/// when they use a rule group. For more information, see WAF
/// web ACL capacity units (WCU) in the WAF Developer Guide.
///
///
[AWSProperty(Required=true, Min=1)]
public long Capacity
{
get { return this._capacity.GetValueOrDefault(); }
set { this._capacity = value; }
}
// Check to see if Capacity property is set
internal bool IsSetCapacity()
{
return this._capacity.HasValue;
}
///
/// Gets and sets the property ConsumedLabels.
///
/// The labels that one or more rules in this rule group match against in label match
/// statements. These labels are defined in a LabelMatchStatement
specification,
/// in the Statement definition of a rule.
///
///
public List ConsumedLabels
{
get { return this._consumedLabels; }
set { this._consumedLabels = value; }
}
// Check to see if ConsumedLabels property is set
internal bool IsSetConsumedLabels()
{
return this._consumedLabels != null && this._consumedLabels.Count > 0;
}
///
/// Gets and sets the property CustomResponseBodies.
///
/// A map of custom response keys and content bodies. When you create a rule with a block
/// action, you can send a custom response to the web request. You define these for the
/// rule group, and then use them in the rules that you define in the rule group.
///
///
///
/// For information about customizing web requests and responses, see Customizing
/// web requests and responses in WAF in the WAF Developer Guide.
///
///
///
/// For information about the limits on count and size for custom request and response
/// settings, see WAF
/// quotas in the WAF Developer Guide.
///
///
[AWSProperty(Min=1)]
public Dictionary CustomResponseBodies
{
get { return this._customResponseBodies; }
set { this._customResponseBodies = value; }
}
// Check to see if CustomResponseBodies property is set
internal bool IsSetCustomResponseBodies()
{
return this._customResponseBodies != null && this._customResponseBodies.Count > 0;
}
///
/// Gets and sets the property Description.
///
/// A description of the rule group that helps with identification.
///
///
[AWSProperty(Min=1, Max=256)]
public string Description
{
get { return this._description; }
set { this._description = value; }
}
// Check to see if Description property is set
internal bool IsSetDescription()
{
return this._description != null;
}
///
/// Gets and sets the property Id.
///
/// A unique identifier for the rule group. This ID is returned in the responses to create
/// and list commands. You provide it to operations like update and delete.
///
///
[AWSProperty(Required=true, Min=1, Max=36)]
public string Id
{
get { return this._id; }
set { this._id = value; }
}
// Check to see if Id property is set
internal bool IsSetId()
{
return this._id != null;
}
///
/// Gets and sets the property LabelNamespace.
///
/// The label namespace prefix for this rule group. All labels added by rules in this
/// rule group have this prefix.
///
/// -
///
/// The syntax for the label namespace prefix for your rule groups is the following:
///
///
///
///
awswaf:<account ID>:rulegroup:<rule group name>:
///
/// -
///
/// When a rule with a label matches a web request, WAF adds the fully qualified label
/// to the request. A fully qualified label is made up of the label namespace from the
/// rule group or web ACL where the rule is defined and the label from the rule, separated
/// by a colon:
///
///
///
///
<label namespace>:<label from rule>
///
///
///
[AWSProperty(Min=1, Max=1024)]
public string LabelNamespace
{
get { return this._labelNamespace; }
set { this._labelNamespace = value; }
}
// Check to see if LabelNamespace property is set
internal bool IsSetLabelNamespace()
{
return this._labelNamespace != null;
}
///
/// Gets and sets the property Name.
///
/// The name of the rule group. You cannot change the name of a rule group after you create
/// it.
///
///
[AWSProperty(Required=true, Min=1, Max=128)]
public string Name
{
get { return this._name; }
set { this._name = value; }
}
// Check to see if Name property is set
internal bool IsSetName()
{
return this._name != null;
}
///
/// Gets and sets the property Rules.
///
/// The Rule statements used to identify the web requests that you want to allow,
/// block, or count. Each rule includes one top-level statement that WAF uses to identify
/// matching web requests, and parameters that govern how WAF handles them.
///
///
public List Rules
{
get { return this._rules; }
set { this._rules = value; }
}
// Check to see if Rules property is set
internal bool IsSetRules()
{
return this._rules != null && this._rules.Count > 0;
}
///
/// Gets and sets the property VisibilityConfig.
///
/// Defines and enables Amazon CloudWatch metrics and web request sample collection.
///
///
[AWSProperty(Required=true)]
public VisibilityConfig VisibilityConfig
{
get { return this._visibilityConfig; }
set { this._visibilityConfig = value; }
}
// Check to see if VisibilityConfig property is set
internal bool IsSetVisibilityConfig()
{
return this._visibilityConfig != null;
}
}
}