/*
 * 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 DeleteRegexPatternSet operation.
    /// Deletes the specified RegexPatternSet.
    /// 
    public partial class DeleteRegexPatternSetRequest : AmazonWAFV2Request
    {
        private string _id;
        private string _lockToken;
        private string _name;
        private Scope _scope;
        /// 
        /// Gets and sets the property Id. 
        /// 
        /// A unique identifier for the set. 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 set. You cannot change the name after you create the set.
        /// 
        /// 
        [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 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;
        }
    }
}