/* * 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 iam-2010-05-08.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.IdentityManagement.Model { /// <summary> /// Contains information about an IAM role. This structure is returned as a response element /// in several API operations that interact with roles. /// </summary> public partial class Role { private string _arn; private string _assumeRolePolicyDocument; private DateTime? _createDate; private string _description; private int? _maxSessionDuration; private string _path; private AttachedPermissionsBoundary _permissionsBoundary; private string _roleId; private RoleLastUsed _roleLastUsed; private string _roleName; private List<Tag> _tags = new List<Tag>(); /// <summary> /// Gets and sets the property Arn. /// <para> /// The Amazon Resource Name (ARN) specifying the role. For more information about ARNs /// and how to use them in policies, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/Using_Identifiers.html">IAM /// identifiers</a> in the <i>IAM User Guide</i> guide. /// </para> /// </summary> [AWSProperty(Required=true, Min=20, Max=2048)] public string Arn { get { return this._arn; } set { this._arn = value; } } // Check to see if Arn property is set internal bool IsSetArn() { return this._arn != null; } /// <summary> /// Gets and sets the property AssumeRolePolicyDocument. /// <para> /// The policy that grants an entity permission to assume the role. /// </para> /// </summary> [AWSProperty(Min=1, Max=131072)] public string AssumeRolePolicyDocument { get { return this._assumeRolePolicyDocument; } set { this._assumeRolePolicyDocument = value; } } // Check to see if AssumeRolePolicyDocument property is set internal bool IsSetAssumeRolePolicyDocument() { return this._assumeRolePolicyDocument != null; } /// <summary> /// Gets and sets the property CreateDate. /// <para> /// The date and time, in <a href="http://www.iso.org/iso/iso8601">ISO 8601 date-time /// format</a>, when the role was created. /// </para> /// </summary> [AWSProperty(Required=true)] public DateTime CreateDate { get { return this._createDate.GetValueOrDefault(); } set { this._createDate = value; } } // Check to see if CreateDate property is set internal bool IsSetCreateDate() { return this._createDate.HasValue; } /// <summary> /// Gets and sets the property Description. /// <para> /// A description of the role that you provide. /// </para> /// </summary> [AWSProperty(Max=1000)] public string Description { get { return this._description; } set { this._description = value; } } // Check to see if Description property is set internal bool IsSetDescription() { return this._description != null; } /// <summary> /// Gets and sets the property MaxSessionDuration. /// <para> /// The maximum session duration (in seconds) for the specified role. Anyone who uses /// the CLI, or API to assume the role can specify the duration using the optional <code>DurationSeconds</code> /// API parameter or <code>duration-seconds</code> CLI parameter. /// </para> /// </summary> [AWSProperty(Min=3600, Max=43200)] public int MaxSessionDuration { get { return this._maxSessionDuration.GetValueOrDefault(); } set { this._maxSessionDuration = value; } } // Check to see if MaxSessionDuration property is set internal bool IsSetMaxSessionDuration() { return this._maxSessionDuration.HasValue; } /// <summary> /// Gets and sets the property Path. /// <para> /// The path to the role. For more information about paths, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/Using_Identifiers.html">IAM /// identifiers</a> in the <i>IAM User Guide</i>. /// </para> /// </summary> [AWSProperty(Required=true, Min=1, Max=512)] public string Path { get { return this._path; } set { this._path = value; } } // Check to see if Path property is set internal bool IsSetPath() { return this._path != null; } /// <summary> /// Gets and sets the property PermissionsBoundary. /// <para> /// The ARN of the policy used to set the permissions boundary for the role. /// </para> /// /// <para> /// For more information about permissions boundaries, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_boundaries.html">Permissions /// boundaries for IAM identities </a> in the <i>IAM User Guide</i>. /// </para> /// </summary> public AttachedPermissionsBoundary PermissionsBoundary { get { return this._permissionsBoundary; } set { this._permissionsBoundary = value; } } // Check to see if PermissionsBoundary property is set internal bool IsSetPermissionsBoundary() { return this._permissionsBoundary != null; } /// <summary> /// Gets and sets the property RoleId. /// <para> /// The stable and unique string identifying the role. For more information about IDs, /// see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/Using_Identifiers.html">IAM /// identifiers</a> in the <i>IAM User Guide</i>. /// </para> /// </summary> [AWSProperty(Required=true, Min=16, Max=128)] public string RoleId { get { return this._roleId; } set { this._roleId = value; } } // Check to see if RoleId property is set internal bool IsSetRoleId() { return this._roleId != null; } /// <summary> /// Gets and sets the property RoleLastUsed. /// <para> /// Contains information about the last time that an IAM role was used. This includes /// the date and time and the Region in which the role was last used. Activity is only /// reported for the trailing 400 days. This period can be shorter if your Region began /// supporting these features within the last year. The role might have been used more /// than 400 days ago. For more information, see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/access_policies_access-advisor.html#access-advisor_tracking-period">Regions /// where data is tracked</a> in the <i>IAM user Guide</i>. /// </para> /// </summary> public RoleLastUsed RoleLastUsed { get { return this._roleLastUsed; } set { this._roleLastUsed = value; } } // Check to see if RoleLastUsed property is set internal bool IsSetRoleLastUsed() { return this._roleLastUsed != null; } /// <summary> /// Gets and sets the property RoleName. /// <para> /// The friendly name that identifies the role. /// </para> /// </summary> [AWSProperty(Required=true, Min=1, Max=64)] public string RoleName { get { return this._roleName; } set { this._roleName = value; } } // Check to see if RoleName property is set internal bool IsSetRoleName() { return this._roleName != null; } /// <summary> /// Gets and sets the property Tags. /// <para> /// A list of tags that are attached to the role. For more information about tagging, /// see <a href="https://docs.aws.amazon.com/IAM/latest/UserGuide/id_tags.html">Tagging /// IAM resources</a> in the <i>IAM User Guide</i>. /// </para> /// </summary> [AWSProperty(Max=50)] public List<Tag> Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } } }