/*
 * 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
{
    /// 
    /// Container for the parameters to the UpdateRuleGroup operation.
    /// Updates the specified RuleGroup.
    /// 
    ///   
    /// 
    /// This operation completely replaces the mutable specifications that you already have
    /// for the rule group with the ones that you provide to this call. 
    /// 
    ///  
    /// 
    /// To modify a rule group, do the following: 
    /// 
    ///   -  
    /// 
    /// Retrieve it by calling GetRuleGroup 
    /// 
    ///  
  -  
    /// 
    /// Update its settings as needed
    /// 
    ///  
  -  
    /// 
    /// Provide the complete rule group specification to this call
    /// 
    ///  
  
  
    /// 
    /// When you make changes to web ACLs or web ACL components, like rules and rule groups,
    /// WAF propagates the changes everywhere that the web ACL and its components are stored
    /// and used. Your changes are applied within seconds, but there might be a brief period
    /// of inconsistency when the changes have arrived in some places and not in others. So,
    /// for example, if you change a rule action setting, the action might be the old action
    /// in one area and the new action in another area. Or if you add an IP address to an
    /// IP set used in a blocking rule, the new address might briefly be blocked in one area
    /// while still allowed in another. This temporary inconsistency can occur when you first
    /// associate a web ACL with an Amazon Web Services resource and when you change a web
    /// ACL that is already associated with a resource. Generally, any inconsistencies of
    /// this type last only a few seconds.
    /// 
    ///  
    /// 
    ///  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 UpdateRuleGroupRequest : AmazonWAFV2Request
    {
        private Dictionary _customResponseBodies = new Dictionary();
        private string _description;
        private string _id;
        private string _lockToken;
        private string _name;
        private List _rules = new List();
        private Scope _scope;
        private VisibilityConfig _visibilityConfig;
        /// 
        /// 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 LockToken. 
        /// 
        /// A token used for optimistic locking. WAF returns a token to your get
        /// and list requests, to mark the state of the entity at the time of the
        /// request. To make changes to the entity associated with the token, you provide the
        /// token to operations like update and delete. WAF uses the
        /// token to ensure that no changes have been made to the entity since you last retrieved
        /// it. If a change has been made, the update fails with a WAFOptimisticLockException.
        /// If this happens, perform another get, and use the new token returned
        /// by that operation. 
        /// 
        /// 
        [AWSProperty(Required=true, Min=1, Max=36)]
        public string LockToken
        {
            get { return this._lockToken; }
            set { this._lockToken = value; }
        }
        // Check to see if LockToken property is set
        internal bool IsSetLockToken()
        {
            return this._lockToken != 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 Scope. 
        /// 
        /// Specifies whether this is for an Amazon CloudFront distribution or for a regional
        /// application. A regional application can be an Application Load Balancer (ALB), an
        /// Amazon API Gateway REST API, an AppSync GraphQL API, an Amazon Cognito user pool,
        /// an App Runner service, or an Amazon Web Services Verified Access instance. 
        /// 
        ///  
        /// 
        /// To work with CloudFront, you must also specify the Region US East (N. Virginia) as
        /// follows: 
        /// 
        ///   -  
        /// 
        /// CLI - Specify the Region when you use the CloudFront scope: 
--scope=CLOUDFRONT
        /// --region=us-east-1. 
        /// 
        ///    -  
        /// 
        /// API and SDKs - For all calls, use the Region endpoint us-east-1. 
        /// 
        ///  
  
        /// 
        [AWSProperty(Required=true)]
        public Scope Scope
        {
            get { return this._scope; }
            set { this._scope = value; }
        }
        // Check to see if Scope property is set
        internal bool IsSetScope()
        {
            return this._scope != null;
        }
        /// 
        /// 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;
        }
    }
}