/*
 * 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 kendra-2019-02-03.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.Kendra.Model
{
    /// 
    /// Container for the parameters to the DeletePrincipalMapping operation.
    /// Deletes a group so that all users and sub groups that belong to the group can no longer
    /// access documents only available to that group.
    /// 
    ///  
    /// 
    /// For example, after deleting the group "Summer Interns", all interns who belonged to
    /// that group no longer see intern-only documents in their search results.
    /// 
    ///  
    /// 
    /// If you want to delete or replace users or sub groups of a group, you need to use the
    /// PutPrincipalMapping operation. For example, if a user in the group "Engineering"
    /// leaves the engineering team and another user takes their place, you provide an updated
    /// list of users or sub groups that belong to the "Engineering" group when calling PutPrincipalMapping.
    /// You can update your internal list of users or sub groups and input this list when
    /// calling PutPrincipalMapping.
    /// 
    ///  
    /// 
    ///  DeletePrincipalMapping is currently not supported in the Amazon Web
    /// Services GovCloud (US-West) region.
    /// 
    /// 
    public partial class DeletePrincipalMappingRequest : AmazonKendraRequest
    {
        private string _dataSourceId;
        private string _groupId;
        private string _indexId;
        private long? _orderingId;
        /// 
        /// Gets and sets the property DataSourceId. 
        /// 
        /// The identifier of the data source you want to delete a group from.
        /// 
        ///  
        /// 
        /// A group can be tied to multiple data sources. You can delete a group from accessing
        /// documents in a certain data source. For example, the groups "Research", "Engineering",
        /// and "Sales and Marketing" are all tied to the company's documents stored in the data
        /// sources Confluence and Salesforce. You want to delete "Research" and "Engineering"
        /// groups from Salesforce, so that these groups cannot access customer-related documents
        /// stored in Salesforce. Only "Sales and Marketing" should access documents in the Salesforce
        /// data source.
        /// 
        /// 
        [AWSProperty(Min=1, Max=100)]
        public string DataSourceId
        {
            get { return this._dataSourceId; }
            set { this._dataSourceId = value; }
        }
        // Check to see if DataSourceId property is set
        internal bool IsSetDataSourceId()
        {
            return this._dataSourceId != null;
        }
        /// 
        /// Gets and sets the property GroupId. 
        /// 
        /// The identifier of the group you want to delete.
        /// 
        /// 
        [AWSProperty(Required=true, Min=1, Max=1024)]
        public string GroupId
        {
            get { return this._groupId; }
            set { this._groupId = value; }
        }
        // Check to see if GroupId property is set
        internal bool IsSetGroupId()
        {
            return this._groupId != null;
        }
        /// 
        /// Gets and sets the property IndexId. 
        /// 
        /// The identifier of the index you want to delete a group from.
        /// 
        /// 
        [AWSProperty(Required=true, Min=36, Max=36)]
        public string IndexId
        {
            get { return this._indexId; }
            set { this._indexId = value; }
        }
        // Check to see if IndexId property is set
        internal bool IsSetIndexId()
        {
            return this._indexId != null;
        }
        /// 
        /// Gets and sets the property OrderingId. 
        /// 
        /// The timestamp identifier you specify to ensure Amazon Kendra does not override the
        /// latest DELETE action with previous actions. The highest number ID, which
        /// is the ordering ID, is the latest action you want to process and apply on top of other
        /// actions with lower number IDs. This prevents previous actions with lower number IDs
        /// from possibly overriding the latest action.
        /// 
        ///  
        /// 
        /// The ordering ID can be the Unix time of the last update you made to a group members
        /// list. You would then provide this list when calling PutPrincipalMapping.
        /// This ensures your DELETE action for that updated group with the latest
        /// members list doesn't get overwritten by earlier DELETE actions for the
        /// same group which are yet to be processed.
        /// 
        ///  
        /// 
        /// The default ordering ID is the current Unix time in milliseconds that the action was
        /// received by Amazon Kendra. 
        /// 
        /// 
        [AWSProperty(Min=0, Max=32535158400000)]
        public long OrderingId
        {
            get { return this._orderingId.GetValueOrDefault(); }
            set { this._orderingId = value; }
        }
        // Check to see if OrderingId property is set
        internal bool IsSetOrderingId()
        {
            return this._orderingId.HasValue; 
        }
    }
}