{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE NoImplicitPrelude #-} {-# OPTIONS_GHC -fno-warn-unused-binds #-} {-# OPTIONS_GHC -fno-warn-unused-imports #-} {-# OPTIONS_GHC -fno-warn-unused-matches #-} -- Derived from AWS service descriptions, licensed under Apache 2.0. -- | -- Module : Amazonka.CodeStar.CreateUserProfile -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Creates a profile for a user that includes user preferences, such as the -- display name and email address assocciated with the user, in AWS -- CodeStar. The user profile is not project-specific. Information in the -- user profile is displayed wherever the user\'s information appears to -- other users in AWS CodeStar. module Amazonka.CodeStar.CreateUserProfile ( -- * Creating a Request CreateUserProfile (..), newCreateUserProfile, -- * Request Lenses createUserProfile_sshPublicKey, createUserProfile_userArn, createUserProfile_displayName, createUserProfile_emailAddress, -- * Destructuring the Response CreateUserProfileResponse (..), newCreateUserProfileResponse, -- * Response Lenses createUserProfileResponse_createdTimestamp, createUserProfileResponse_displayName, createUserProfileResponse_emailAddress, createUserProfileResponse_lastModifiedTimestamp, createUserProfileResponse_sshPublicKey, createUserProfileResponse_httpStatus, createUserProfileResponse_userArn, ) where import Amazonka.CodeStar.Types import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newCreateUserProfile' smart constructor. data CreateUserProfile = CreateUserProfile' { -- | The SSH public key associated with the user in AWS CodeStar. If a -- project owner allows the user remote access to project resources, this -- public key will be used along with the user\'s private key for SSH -- access. sshPublicKey :: Prelude.Maybe Prelude.Text, -- | The Amazon Resource Name (ARN) of the user in IAM. userArn :: Prelude.Text, -- | The name that will be displayed as the friendly name for the user in AWS -- CodeStar. displayName :: Data.Sensitive Prelude.Text, -- | The email address that will be displayed as part of the user\'s profile -- in AWS CodeStar. emailAddress :: Data.Sensitive Prelude.Text } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateUserProfile' 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: -- -- 'sshPublicKey', 'createUserProfile_sshPublicKey' - The SSH public key associated with the user in AWS CodeStar. If a -- project owner allows the user remote access to project resources, this -- public key will be used along with the user\'s private key for SSH -- access. -- -- 'userArn', 'createUserProfile_userArn' - The Amazon Resource Name (ARN) of the user in IAM. -- -- 'displayName', 'createUserProfile_displayName' - The name that will be displayed as the friendly name for the user in AWS -- CodeStar. -- -- 'emailAddress', 'createUserProfile_emailAddress' - The email address that will be displayed as part of the user\'s profile -- in AWS CodeStar. newCreateUserProfile :: -- | 'userArn' Prelude.Text -> -- | 'displayName' Prelude.Text -> -- | 'emailAddress' Prelude.Text -> CreateUserProfile newCreateUserProfile pUserArn_ pDisplayName_ pEmailAddress_ = CreateUserProfile' { sshPublicKey = Prelude.Nothing, userArn = pUserArn_, displayName = Data._Sensitive Lens.# pDisplayName_, emailAddress = Data._Sensitive Lens.# pEmailAddress_ } -- | The SSH public key associated with the user in AWS CodeStar. If a -- project owner allows the user remote access to project resources, this -- public key will be used along with the user\'s private key for SSH -- access. createUserProfile_sshPublicKey :: Lens.Lens' CreateUserProfile (Prelude.Maybe Prelude.Text) createUserProfile_sshPublicKey = Lens.lens (\CreateUserProfile' {sshPublicKey} -> sshPublicKey) (\s@CreateUserProfile' {} a -> s {sshPublicKey = a} :: CreateUserProfile) -- | The Amazon Resource Name (ARN) of the user in IAM. createUserProfile_userArn :: Lens.Lens' CreateUserProfile Prelude.Text createUserProfile_userArn = Lens.lens (\CreateUserProfile' {userArn} -> userArn) (\s@CreateUserProfile' {} a -> s {userArn = a} :: CreateUserProfile) -- | The name that will be displayed as the friendly name for the user in AWS -- CodeStar. createUserProfile_displayName :: Lens.Lens' CreateUserProfile Prelude.Text createUserProfile_displayName = Lens.lens (\CreateUserProfile' {displayName} -> displayName) (\s@CreateUserProfile' {} a -> s {displayName = a} :: CreateUserProfile) Prelude.. Data._Sensitive -- | The email address that will be displayed as part of the user\'s profile -- in AWS CodeStar. createUserProfile_emailAddress :: Lens.Lens' CreateUserProfile Prelude.Text createUserProfile_emailAddress = Lens.lens (\CreateUserProfile' {emailAddress} -> emailAddress) (\s@CreateUserProfile' {} a -> s {emailAddress = a} :: CreateUserProfile) Prelude.. Data._Sensitive instance Core.AWSRequest CreateUserProfile where type AWSResponse CreateUserProfile = CreateUserProfileResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> CreateUserProfileResponse' Prelude.<$> (x Data..?> "createdTimestamp") Prelude.<*> (x Data..?> "displayName") Prelude.<*> (x Data..?> "emailAddress") Prelude.<*> (x Data..?> "lastModifiedTimestamp") Prelude.<*> (x Data..?> "sshPublicKey") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) Prelude.<*> (x Data..:> "userArn") ) instance Prelude.Hashable CreateUserProfile where hashWithSalt _salt CreateUserProfile' {..} = _salt `Prelude.hashWithSalt` sshPublicKey `Prelude.hashWithSalt` userArn `Prelude.hashWithSalt` displayName `Prelude.hashWithSalt` emailAddress instance Prelude.NFData CreateUserProfile where rnf CreateUserProfile' {..} = Prelude.rnf sshPublicKey `Prelude.seq` Prelude.rnf userArn `Prelude.seq` Prelude.rnf displayName `Prelude.seq` Prelude.rnf emailAddress instance Data.ToHeaders CreateUserProfile where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "CodeStar_20170419.CreateUserProfile" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON CreateUserProfile where toJSON CreateUserProfile' {..} = Data.object ( Prelude.catMaybes [ ("sshPublicKey" Data..=) Prelude.<$> sshPublicKey, Prelude.Just ("userArn" Data..= userArn), Prelude.Just ("displayName" Data..= displayName), Prelude.Just ("emailAddress" Data..= emailAddress) ] ) instance Data.ToPath CreateUserProfile where toPath = Prelude.const "/" instance Data.ToQuery CreateUserProfile where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newCreateUserProfileResponse' smart constructor. data CreateUserProfileResponse = CreateUserProfileResponse' { -- | The date the user profile was created, in timestamp format. createdTimestamp :: Prelude.Maybe Data.POSIX, -- | The name that is displayed as the friendly name for the user in AWS -- CodeStar. displayName :: Prelude.Maybe (Data.Sensitive Prelude.Text), -- | The email address that is displayed as part of the user\'s profile in -- AWS CodeStar. emailAddress :: Prelude.Maybe (Data.Sensitive Prelude.Text), -- | The date the user profile was last modified, in timestamp format. lastModifiedTimestamp :: Prelude.Maybe Data.POSIX, -- | The SSH public key associated with the user in AWS CodeStar. This is the -- public portion of the public\/private keypair the user can use to access -- project resources if a project owner allows the user remote access to -- those resources. sshPublicKey :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int, -- | The Amazon Resource Name (ARN) of the user in IAM. userArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'CreateUserProfileResponse' 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: -- -- 'createdTimestamp', 'createUserProfileResponse_createdTimestamp' - The date the user profile was created, in timestamp format. -- -- 'displayName', 'createUserProfileResponse_displayName' - The name that is displayed as the friendly name for the user in AWS -- CodeStar. -- -- 'emailAddress', 'createUserProfileResponse_emailAddress' - The email address that is displayed as part of the user\'s profile in -- AWS CodeStar. -- -- 'lastModifiedTimestamp', 'createUserProfileResponse_lastModifiedTimestamp' - The date the user profile was last modified, in timestamp format. -- -- 'sshPublicKey', 'createUserProfileResponse_sshPublicKey' - The SSH public key associated with the user in AWS CodeStar. This is the -- public portion of the public\/private keypair the user can use to access -- project resources if a project owner allows the user remote access to -- those resources. -- -- 'httpStatus', 'createUserProfileResponse_httpStatus' - The response's http status code. -- -- 'userArn', 'createUserProfileResponse_userArn' - The Amazon Resource Name (ARN) of the user in IAM. newCreateUserProfileResponse :: -- | 'httpStatus' Prelude.Int -> -- | 'userArn' Prelude.Text -> CreateUserProfileResponse newCreateUserProfileResponse pHttpStatus_ pUserArn_ = CreateUserProfileResponse' { createdTimestamp = Prelude.Nothing, displayName = Prelude.Nothing, emailAddress = Prelude.Nothing, lastModifiedTimestamp = Prelude.Nothing, sshPublicKey = Prelude.Nothing, httpStatus = pHttpStatus_, userArn = pUserArn_ } -- | The date the user profile was created, in timestamp format. createUserProfileResponse_createdTimestamp :: Lens.Lens' CreateUserProfileResponse (Prelude.Maybe Prelude.UTCTime) createUserProfileResponse_createdTimestamp = Lens.lens (\CreateUserProfileResponse' {createdTimestamp} -> createdTimestamp) (\s@CreateUserProfileResponse' {} a -> s {createdTimestamp = a} :: CreateUserProfileResponse) Prelude.. Lens.mapping Data._Time -- | The name that is displayed as the friendly name for the user in AWS -- CodeStar. createUserProfileResponse_displayName :: Lens.Lens' CreateUserProfileResponse (Prelude.Maybe Prelude.Text) createUserProfileResponse_displayName = Lens.lens (\CreateUserProfileResponse' {displayName} -> displayName) (\s@CreateUserProfileResponse' {} a -> s {displayName = a} :: CreateUserProfileResponse) Prelude.. Lens.mapping Data._Sensitive -- | The email address that is displayed as part of the user\'s profile in -- AWS CodeStar. createUserProfileResponse_emailAddress :: Lens.Lens' CreateUserProfileResponse (Prelude.Maybe Prelude.Text) createUserProfileResponse_emailAddress = Lens.lens (\CreateUserProfileResponse' {emailAddress} -> emailAddress) (\s@CreateUserProfileResponse' {} a -> s {emailAddress = a} :: CreateUserProfileResponse) Prelude.. Lens.mapping Data._Sensitive -- | The date the user profile was last modified, in timestamp format. createUserProfileResponse_lastModifiedTimestamp :: Lens.Lens' CreateUserProfileResponse (Prelude.Maybe Prelude.UTCTime) createUserProfileResponse_lastModifiedTimestamp = Lens.lens (\CreateUserProfileResponse' {lastModifiedTimestamp} -> lastModifiedTimestamp) (\s@CreateUserProfileResponse' {} a -> s {lastModifiedTimestamp = a} :: CreateUserProfileResponse) Prelude.. Lens.mapping Data._Time -- | The SSH public key associated with the user in AWS CodeStar. This is the -- public portion of the public\/private keypair the user can use to access -- project resources if a project owner allows the user remote access to -- those resources. createUserProfileResponse_sshPublicKey :: Lens.Lens' CreateUserProfileResponse (Prelude.Maybe Prelude.Text) createUserProfileResponse_sshPublicKey = Lens.lens (\CreateUserProfileResponse' {sshPublicKey} -> sshPublicKey) (\s@CreateUserProfileResponse' {} a -> s {sshPublicKey = a} :: CreateUserProfileResponse) -- | The response's http status code. createUserProfileResponse_httpStatus :: Lens.Lens' CreateUserProfileResponse Prelude.Int createUserProfileResponse_httpStatus = Lens.lens (\CreateUserProfileResponse' {httpStatus} -> httpStatus) (\s@CreateUserProfileResponse' {} a -> s {httpStatus = a} :: CreateUserProfileResponse) -- | The Amazon Resource Name (ARN) of the user in IAM. createUserProfileResponse_userArn :: Lens.Lens' CreateUserProfileResponse Prelude.Text createUserProfileResponse_userArn = Lens.lens (\CreateUserProfileResponse' {userArn} -> userArn) (\s@CreateUserProfileResponse' {} a -> s {userArn = a} :: CreateUserProfileResponse) instance Prelude.NFData CreateUserProfileResponse where rnf CreateUserProfileResponse' {..} = Prelude.rnf createdTimestamp `Prelude.seq` Prelude.rnf displayName `Prelude.seq` Prelude.rnf emailAddress `Prelude.seq` Prelude.rnf lastModifiedTimestamp `Prelude.seq` Prelude.rnf sshPublicKey `Prelude.seq` Prelude.rnf httpStatus `Prelude.seq` Prelude.rnf userArn