{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.IAM.Types.User -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.IAM.Types.User where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.IAM.Types.AttachedPermissionsBoundary import Amazonka.IAM.Types.Tag import qualified Amazonka.Prelude as Prelude -- | Contains information about an IAM user entity. -- -- This data type is used as a response element in the following -- operations: -- -- - CreateUser -- -- - GetUser -- -- - ListUsers -- -- /See:/ 'newUser' smart constructor. data User = User' { -- | The date and time, in -- , when the -- user\'s password was last used to sign in to an Amazon Web Services -- website. For a list of Amazon Web Services websites that capture a -- user\'s last sign-in time, see the -- -- 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. passwordLastUsed :: Prelude.Maybe Data.ISO8601, -- | The path to the user. For more information about paths, see -- -- in the /IAM User Guide/. -- -- The ARN of the policy used to set the permissions boundary for the user. path :: Prelude.Maybe Prelude.Text, -- | For more information about permissions boundaries, see -- -- in the /IAM User Guide/. permissionsBoundary :: Prelude.Maybe AttachedPermissionsBoundary, -- | A list of tags that are associated with the user. For more information -- about tagging, see -- -- in the /IAM User Guide/. tags :: Prelude.Maybe [Tag], -- | The friendly name identifying the user. userName :: Prelude.Text, -- | The stable and unique string identifying the user. For more information -- about IDs, see -- -- in the /IAM User Guide/. userId :: Prelude.Text, -- | The Amazon Resource Name (ARN) that identifies the user. For more -- information about ARNs and how to use ARNs in policies, see -- -- in the /IAM User Guide/. arn :: Prelude.Text, -- | The date and time, in -- , when the -- user was created. createDate :: Data.ISO8601 } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'User' with all optional fields omitted. -- -- Use or to modify other optional fields. -- -- The following record fields are available, with the corresponding lenses provided -- for backwards compatibility: -- -- 'passwordLastUsed', 'user_passwordLastUsed' - The date and time, in -- , when the -- user\'s password was last used to sign in to an Amazon Web Services -- website. For a list of Amazon Web Services websites that capture a -- user\'s last sign-in time, see the -- -- 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. -- -- 'path', 'user_path' - The path to the user. For more information about paths, see -- -- in the /IAM User Guide/. -- -- The ARN of the policy used to set the permissions boundary for the user. -- -- 'permissionsBoundary', 'user_permissionsBoundary' - For more information about permissions boundaries, see -- -- in the /IAM User Guide/. -- -- 'tags', 'user_tags' - A list of tags that are associated with the user. For more information -- about tagging, see -- -- in the /IAM User Guide/. -- -- 'userName', 'user_userName' - The friendly name identifying the user. -- -- 'userId', 'user_userId' - The stable and unique string identifying the user. For more information -- about IDs, see -- -- in the /IAM User Guide/. -- -- 'arn', 'user_arn' - The Amazon Resource Name (ARN) that identifies the user. For more -- information about ARNs and how to use ARNs in policies, see -- -- in the /IAM User Guide/. -- -- 'createDate', 'user_createDate' - The date and time, in -- , when the -- user was created. newUser :: -- | 'userName' Prelude.Text -> -- | 'userId' Prelude.Text -> -- | 'arn' Prelude.Text -> -- | 'createDate' Prelude.UTCTime -> User newUser pUserName_ pUserId_ pArn_ pCreateDate_ = User' { passwordLastUsed = Prelude.Nothing, path = Prelude.Nothing, permissionsBoundary = Prelude.Nothing, tags = Prelude.Nothing, userName = pUserName_, userId = pUserId_, arn = pArn_, createDate = Data._Time Lens.# pCreateDate_ } -- | The date and time, in -- , when the -- user\'s password was last used to sign in to an Amazon Web Services -- website. For a list of Amazon Web Services websites that capture a -- user\'s last sign-in time, see the -- -- 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. user_passwordLastUsed :: Lens.Lens' User (Prelude.Maybe Prelude.UTCTime) user_passwordLastUsed = Lens.lens (\User' {passwordLastUsed} -> passwordLastUsed) (\s@User' {} a -> s {passwordLastUsed = a} :: User) Prelude.. Lens.mapping Data._Time -- | The path to the user. For more information about paths, see -- -- in the /IAM User Guide/. -- -- The ARN of the policy used to set the permissions boundary for the user. user_path :: Lens.Lens' User (Prelude.Maybe Prelude.Text) user_path = Lens.lens (\User' {path} -> path) (\s@User' {} a -> s {path = a} :: User) -- | For more information about permissions boundaries, see -- -- in the /IAM User Guide/. user_permissionsBoundary :: Lens.Lens' User (Prelude.Maybe AttachedPermissionsBoundary) user_permissionsBoundary = Lens.lens (\User' {permissionsBoundary} -> permissionsBoundary) (\s@User' {} a -> s {permissionsBoundary = a} :: User) -- | A list of tags that are associated with the user. For more information -- about tagging, see -- -- in the /IAM User Guide/. user_tags :: Lens.Lens' User (Prelude.Maybe [Tag]) user_tags = Lens.lens (\User' {tags} -> tags) (\s@User' {} a -> s {tags = a} :: User) Prelude.. Lens.mapping Lens.coerced -- | The friendly name identifying the user. user_userName :: Lens.Lens' User Prelude.Text user_userName = Lens.lens (\User' {userName} -> userName) (\s@User' {} a -> s {userName = a} :: User) -- | The stable and unique string identifying the user. For more information -- about IDs, see -- -- in the /IAM User Guide/. user_userId :: Lens.Lens' User Prelude.Text user_userId = Lens.lens (\User' {userId} -> userId) (\s@User' {} a -> s {userId = a} :: User) -- | The Amazon Resource Name (ARN) that identifies the user. For more -- information about ARNs and how to use ARNs in policies, see -- -- in the /IAM User Guide/. user_arn :: Lens.Lens' User Prelude.Text user_arn = Lens.lens (\User' {arn} -> arn) (\s@User' {} a -> s {arn = a} :: User) -- | The date and time, in -- , when the -- user was created. user_createDate :: Lens.Lens' User Prelude.UTCTime user_createDate = Lens.lens (\User' {createDate} -> createDate) (\s@User' {} a -> s {createDate = a} :: User) Prelude.. Data._Time instance Data.FromXML User where parseXML x = User' Prelude.<$> (x Data..@? "PasswordLastUsed") Prelude.<*> (x Data..@? "Path") Prelude.<*> (x Data..@? "PermissionsBoundary") Prelude.<*> ( x Data..@? "Tags" Core..!@ Prelude.mempty Prelude.>>= Core.may (Data.parseXMLList "member") ) Prelude.<*> (x Data..@ "UserName") Prelude.<*> (x Data..@ "UserId") Prelude.<*> (x Data..@ "Arn") Prelude.<*> (x Data..@ "CreateDate") instance Prelude.Hashable User where hashWithSalt _salt User' {..} = _salt `Prelude.hashWithSalt` passwordLastUsed `Prelude.hashWithSalt` path `Prelude.hashWithSalt` permissionsBoundary `Prelude.hashWithSalt` tags `Prelude.hashWithSalt` userName `Prelude.hashWithSalt` userId `Prelude.hashWithSalt` arn `Prelude.hashWithSalt` createDate instance Prelude.NFData User where rnf User' {..} = Prelude.rnf passwordLastUsed `Prelude.seq` Prelude.rnf path `Prelude.seq` Prelude.rnf permissionsBoundary `Prelude.seq` Prelude.rnf tags `Prelude.seq` Prelude.rnf userName `Prelude.seq` Prelude.rnf userId `Prelude.seq` Prelude.rnf arn `Prelude.seq` Prelude.rnf createDate