/*
* 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
{
///
/// Contains information about an IAM role, including all of the role's policies.
///
///
///
/// This data type is used as a response element in the GetAccountAuthorizationDetails
/// operation.
///
///
public partial class RoleDetail
{
private string _arn;
private string _assumeRolePolicyDocument;
private List _attachedManagedPolicies = new List();
private DateTime? _createDate;
private List _instanceProfileList = new List();
private string _path;
private AttachedPermissionsBoundary _permissionsBoundary;
private string _roleId;
private RoleLastUsed _roleLastUsed;
private string _roleName;
private List _rolePolicyList = new List();
private List _tags = new List();
///
/// Gets and sets the property Arn.
///
[AWSProperty(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;
}
///
/// Gets and sets the property AssumeRolePolicyDocument.
///
/// The trust policy that grants permission to assume the role.
///
///
[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;
}
///
/// Gets and sets the property AttachedManagedPolicies.
///
/// A list of managed policies attached to the role. These policies are the role's access
/// (permissions) policies.
///
///
public List AttachedManagedPolicies
{
get { return this._attachedManagedPolicies; }
set { this._attachedManagedPolicies = value; }
}
// Check to see if AttachedManagedPolicies property is set
internal bool IsSetAttachedManagedPolicies()
{
return this._attachedManagedPolicies != null && this._attachedManagedPolicies.Count > 0;
}
///
/// Gets and sets the property CreateDate.
///
/// The date and time, in ISO 8601 date-time
/// format, when the role was created.
///
///
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;
}
///
/// Gets and sets the property InstanceProfileList.
///
/// A list of instance profiles that contain this role.
///
///
public List InstanceProfileList
{
get { return this._instanceProfileList; }
set { this._instanceProfileList = value; }
}
// Check to see if InstanceProfileList property is set
internal bool IsSetInstanceProfileList()
{
return this._instanceProfileList != null && this._instanceProfileList.Count > 0;
}
///
/// Gets and sets the property Path.
///
/// The path to the role. For more information about paths, see IAM
/// identifiers in the IAM User Guide.
///
///
[AWSProperty(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;
}
///
/// Gets and sets the property PermissionsBoundary.
///
/// The ARN of the policy used to set the permissions boundary for the role.
///
///
///
/// For more information about permissions boundaries, see Permissions
/// boundaries for IAM identities in the IAM User Guide.
///
///
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;
}
///
/// Gets and sets the property RoleId.
///
/// The stable and unique string identifying the role. For more information about IDs,
/// see IAM
/// identifiers in the IAM User Guide.
///
///
[AWSProperty(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;
}
///
/// Gets and sets the property RoleLastUsed.
///
/// 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 Regions
/// where data is tracked in the IAM User Guide.
///
///
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;
}
///
/// Gets and sets the property RoleName.
///
/// The friendly name that identifies the role.
///
///
[AWSProperty(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;
}
///
/// Gets and sets the property RolePolicyList.
///
/// A list of inline policies embedded in the role. These policies are the role's access
/// (permissions) policies.
///
///
public List RolePolicyList
{
get { return this._rolePolicyList; }
set { this._rolePolicyList = value; }
}
// Check to see if RolePolicyList property is set
internal bool IsSetRolePolicyList()
{
return this._rolePolicyList != null && this._rolePolicyList.Count > 0;
}
///
/// Gets and sets the property Tags.
///
/// A list of tags that are attached to the role. For more information about tagging,
/// see Tagging
/// IAM resources in the IAM User Guide.
///
///
[AWSProperty(Max=50)]
public List 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;
}
}
}