{-# 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.Transfer.DeleteUser -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Deletes the user belonging to a file transfer protocol-enabled server -- you specify. -- -- No response returns from this operation. -- -- When you delete a user from a server, the user\'s information is lost. module Amazonka.Transfer.DeleteUser ( -- * Creating a Request DeleteUser (..), newDeleteUser, -- * Request Lenses deleteUser_serverId, deleteUser_userName, -- * Destructuring the Response DeleteUserResponse (..), newDeleteUserResponse, ) where 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 import Amazonka.Transfer.Types -- | /See:/ 'newDeleteUser' smart constructor. data DeleteUser = DeleteUser' { -- | A system-assigned unique identifier for a server instance that has the -- user assigned to it. serverId :: Prelude.Text, -- | A unique string that identifies a user that is being deleted from a -- server. userName :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteUser' 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: -- -- 'serverId', 'deleteUser_serverId' - A system-assigned unique identifier for a server instance that has the -- user assigned to it. -- -- 'userName', 'deleteUser_userName' - A unique string that identifies a user that is being deleted from a -- server. newDeleteUser :: -- | 'serverId' Prelude.Text -> -- | 'userName' Prelude.Text -> DeleteUser newDeleteUser pServerId_ pUserName_ = DeleteUser' { serverId = pServerId_, userName = pUserName_ } -- | A system-assigned unique identifier for a server instance that has the -- user assigned to it. deleteUser_serverId :: Lens.Lens' DeleteUser Prelude.Text deleteUser_serverId = Lens.lens (\DeleteUser' {serverId} -> serverId) (\s@DeleteUser' {} a -> s {serverId = a} :: DeleteUser) -- | A unique string that identifies a user that is being deleted from a -- server. deleteUser_userName :: Lens.Lens' DeleteUser Prelude.Text deleteUser_userName = Lens.lens (\DeleteUser' {userName} -> userName) (\s@DeleteUser' {} a -> s {userName = a} :: DeleteUser) instance Core.AWSRequest DeleteUser where type AWSResponse DeleteUser = DeleteUserResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveNull DeleteUserResponse' instance Prelude.Hashable DeleteUser where hashWithSalt _salt DeleteUser' {..} = _salt `Prelude.hashWithSalt` serverId `Prelude.hashWithSalt` userName instance Prelude.NFData DeleteUser where rnf DeleteUser' {..} = Prelude.rnf serverId `Prelude.seq` Prelude.rnf userName instance Data.ToHeaders DeleteUser where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ("TransferService.DeleteUser" :: Prelude.ByteString), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteUser where toJSON DeleteUser' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("ServerId" Data..= serverId), Prelude.Just ("UserName" Data..= userName) ] ) instance Data.ToPath DeleteUser where toPath = Prelude.const "/" instance Data.ToQuery DeleteUser where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteUserResponse' smart constructor. data DeleteUserResponse = DeleteUserResponse' { } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteUserResponse' with all optional fields omitted. -- -- Use or to modify other optional fields. newDeleteUserResponse :: DeleteUserResponse newDeleteUserResponse = DeleteUserResponse' instance Prelude.NFData DeleteUserResponse where rnf _ = ()