/* * 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; } } }