/*
 * 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
{
    /// 
    /// This is the response object from the DescribeRuleGroup operation.
    /// 
    public partial class DescribeRuleGroupResponse : AmazonWebServiceResponse
    {
        private RuleGroup _ruleGroup;
        private RuleGroupResponse _ruleGroupResponse;
        private string _updateToken;
        /// 
        /// Gets and sets the property RuleGroup. 
        /// 
        /// The object that defines the rules in a rule group. This, along with RuleGroupResponse,
        /// define the rule group. You can retrieve all objects for a rule group by calling DescribeRuleGroup.
        /// 
        /// 
        ///  
        /// 
        /// Network Firewall uses a rule group to inspect and control network traffic. You define
        /// stateless rule groups to inspect individual packets and you define stateful rule groups
        /// to inspect packets in the context of their traffic flow. 
        /// 
        ///  
        /// 
        /// To use a rule group, you include it by reference in an Network Firewall firewall policy,
        /// then you use the policy in a firewall. You can reference a rule group from more than
        /// one firewall policy, and you can use a firewall policy in more than one firewall.
        /// 
        /// 
        /// 
        public RuleGroup RuleGroup
        {
            get { return this._ruleGroup; }
            set { this._ruleGroup = value; }
        }
        // Check to see if RuleGroup property is set
        internal bool IsSetRuleGroup()
        {
            return this._ruleGroup != null;
        }
        /// 
        /// Gets and sets the property RuleGroupResponse. 
        /// 
        /// The high-level properties of a rule group. This, along with the RuleGroup,
        /// define the rule group. You can retrieve all objects for a rule group by calling DescribeRuleGroup.
        /// 
        /// 
        /// 
        [AWSProperty(Required=true)]
        public RuleGroupResponse RuleGroupResponse
        {
            get { return this._ruleGroupResponse; }
            set { this._ruleGroupResponse = value; }
        }
        // Check to see if RuleGroupResponse property is set
        internal bool IsSetRuleGroupResponse()
        {
            return this._ruleGroupResponse != null;
        }
        /// 
        /// Gets and sets the property UpdateToken. 
        /// 
        /// A token used for optimistic locking. Network Firewall returns a token to your requests
        /// that access the rule group. The token marks the state of the rule group resource at
        /// the time of the request. 
        /// 
        ///  
        /// 
        /// To make changes to the rule group, you provide the token in your request. Network
        /// Firewall uses the token to ensure that the rule group hasn't changed since you last
        /// retrieved it. If it has changed, the operation fails with an InvalidTokenException.
        /// If this happens, retrieve the rule group again to get a current copy of it with a
        /// current token. Reapply your changes as needed, then try the operation again using
        /// the new token. 
        /// 
        /// 
        [AWSProperty(Required=true, 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;
        }
    }
}