/* * Copyright 2010-2014 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 Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.IdentityManagement.Model { /// /// Contains information about an IAM user entity. /// /// /// /// This data type is used as a response element in the following operations: /// /// /// public partial class User { private string _arn; private DateTime? _createDate; private DateTime? _passwordLastUsed; private string _path; private AttachedPermissionsBoundary _permissionsBoundary; private List _tags = new List(); private string _userId; private string _userName; /// /// Empty constructor used to set properties independently even when a simple constructor is available /// public User() { } /// /// Instantiates User with the parameterized properties /// /// The path to the user. For more information about paths, see IAM Identifiers in the IAM User Guide. /// The friendly name identifying the user. /// The stable and unique string identifying the user. For more information about IDs, see IAM Identifiers in the IAM User Guide. /// The Amazon Resource Name (ARN) that identifies the user. For more information about ARNs and how to use ARNs in policies, see IAM Identifiers in the IAM User Guide. /// The date and time, in ISO 8601 date-time format, when the user was created. public User(string path, string userName, string userId, string arn, DateTime createDate) { _path = path; _userName = userName; _userId = userId; _arn = arn; _createDate = createDate; } /// /// Gets and sets the property Arn. /// /// The Amazon Resource Name (ARN) that identifies the user. For more information about /// ARNs and how to use ARNs in policies, see IAM /// Identifiers in the IAM User Guide. /// /// [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; } /// /// Gets and sets the property CreateDate. /// /// The date and time, in ISO 8601 date-time /// format, when the user was created. /// /// [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; } /// /// Gets and sets the property PasswordLastUsed. /// /// The date and time, in ISO 8601 date-time /// format, when the user's password was last used to sign in to an AWS website. For /// a list of AWS websites that capture a user's last sign-in time, see the Credential /// Reports topic in the IAM User Guide. If a password is used more than once /// in a five-minute span, only the first use is returned in this field. If the field /// is null (no value), then it indicates that they never signed in with a password. This /// can be because: /// ///
  • /// /// The user never had a password. /// ///
  • /// /// A password exists but has not been used since IAM started tracking this information /// on October 20, 2014. /// ///
/// /// A null value does not mean that the user never had a password. Also, if the /// user does not currently have a password but had one in the past, then this field contains /// the date and time the most recent password was used. /// /// /// /// This value is returned only in the GetUser and ListUsers operations. /// /// ///
public DateTime PasswordLastUsed { get { return this._passwordLastUsed.GetValueOrDefault(); } set { this._passwordLastUsed = value; } } // Check to see if PasswordLastUsed property is set internal bool IsSetPasswordLastUsed() { return this._passwordLastUsed.HasValue; } /// /// Gets and sets the property Path. /// /// The path to the user. For more information about paths, see IAM /// Identifiers in the IAM User Guide. /// /// [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; } /// /// Gets and sets the property PermissionsBoundary. /// /// The ARN of the policy used to set the permissions boundary for the user. /// /// /// /// 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 Tags. /// /// A list of tags that are associated with the specified user. For more information about /// tagging, see Tagging /// IAM Identities 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; } /// /// Gets and sets the property UserId. /// /// The stable and unique string identifying the user. For more information about IDs, /// see IAM /// Identifiers in the IAM User Guide. /// /// [AWSProperty(Required=true, Min=16, Max=128)] public string UserId { get { return this._userId; } set { this._userId = value; } } // Check to see if UserId property is set internal bool IsSetUserId() { return this._userId != null; } /// /// Gets and sets the property UserName. /// /// The friendly name identifying the user. /// /// [AWSProperty(Required=true, Min=1, Max=64)] public string UserName { get { return this._userName; } set { this._userName = value; } } // Check to see if UserName property is set internal bool IsSetUserName() { return this._userName != null; } } }