/*
 * 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 ram-2018-01-04.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.RAM.Model
{
    /// 
    /// Container for the parameters to the AssociateResourceSharePermission operation.
    /// Adds or replaces the RAM permission for a resource type included in a resource share.
    /// You can have exactly one permission associated with each resource type in the resource
    /// share. You can add a new RAM permission only if there are currently no resources of
    /// that resource type currently in the resource share.
    /// 
    public partial class AssociateResourceSharePermissionRequest : AmazonRAMRequest
    {
        private string _clientToken;
        private string _permissionArn;
        private int? _permissionVersion;
        private bool? _replace;
        private string _resourceShareArn;
        /// 
        /// Gets and sets the property ClientToken. 
        /// 
        /// Specifies a unique, case-sensitive identifier that you provide to ensure the idempotency
        /// of the request. This lets you safely retry the request without accidentally performing
        /// the same operation a second time. Passing the same value to a later call to an operation
        /// requires that you also pass the same value for all other parameters. We recommend
        /// that you use a UUID
        /// type of value..
        /// 
        ///  
        /// 
        /// If you don't provide this value, then Amazon Web Services generates a random one for
        /// you.
        /// 
        ///  
        /// 
        /// If you retry the operation with the same ClientToken, but with different
        /// parameters, the retry fails with an IdempotentParameterMismatch error.
        /// 
        /// 
        public string ClientToken
        {
            get { return this._clientToken; }
            set { this._clientToken = value; }
        }
        // Check to see if ClientToken property is set
        internal bool IsSetClientToken()
        {
            return this._clientToken != null;
        }
        /// 
        /// Gets and sets the property PermissionArn. 
        /// 
        /// Specifies the Amazon
        /// Resource Name (ARN) of the RAM permission to associate with the resource share.
        /// To find the ARN for a permission, use either the ListPermissions operation
        /// or go to the Permissions
        /// library page in the RAM console and then choose the name of the permission. The
        /// ARN is displayed on the detail page.
        /// 
        /// 
        [AWSProperty(Required=true)]
        public string PermissionArn
        {
            get { return this._permissionArn; }
            set { this._permissionArn = value; }
        }
        // Check to see if PermissionArn property is set
        internal bool IsSetPermissionArn()
        {
            return this._permissionArn != null;
        }
        /// 
        /// Gets and sets the property PermissionVersion. 
        /// 
        /// Specifies the version of the RAM permission to associate with the resource share.
        /// You can specify only the version that is currently set as the default version
        /// for the permission. If you also set the replace pararameter to true,
        /// then this operation updates an outdated version of the permission to the current default
        /// version.
        /// 
        ///   
        /// 
        /// You don't need to specify this parameter because the default behavior is to use the
        /// version that is currently set as the default version for the permission. This parameter
        /// is supported for backwards compatibility.
        /// 
        ///  
        /// 
        public int PermissionVersion
        {
            get { return this._permissionVersion.GetValueOrDefault(); }
            set { this._permissionVersion = value; }
        }
        // Check to see if PermissionVersion property is set
        internal bool IsSetPermissionVersion()
        {
            return this._permissionVersion.HasValue; 
        }
        /// 
        /// Gets and sets the property Replace. 
        /// 
        /// Specifies whether the specified permission should replace the existing permission
        /// associated with the resource share. Use true to replace the current permissions.
        /// Use false to add the permission to a resource share that currently doesn't
        /// have a permission. The default value is false.
        /// 
        ///   
        /// 
        /// A resource share can have only one permission per resource type. If a resource share
        /// already has a permission for the specified resource type and you don't set replace
        /// to true then the operation returns an error. This helps prevent accidental
        /// overwriting of a permission.
        /// 
        ///  
        /// 
        public bool Replace
        {
            get { return this._replace.GetValueOrDefault(); }
            set { this._replace = value; }
        }
        // Check to see if Replace property is set
        internal bool IsSetReplace()
        {
            return this._replace.HasValue; 
        }
        /// 
        /// Gets and sets the property ResourceShareArn. 
        /// 
        /// Specifies the Amazon
        /// Resource Name (ARN) of the resource share to which you want to add or replace
        /// permissions.
        /// 
        /// 
        [AWSProperty(Required=true)]
        public string ResourceShareArn
        {
            get { return this._resourceShareArn; }
            set { this._resourceShareArn = value; }
        }
        // Check to see if ResourceShareArn property is set
        internal bool IsSetResourceShareArn()
        {
            return this._resourceShareArn != null;
        }
    }
}