{-# 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.WorkMail.DeleteAlias -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Remove one or more specified aliases from a set of aliases for a given -- user. module Amazonka.WorkMail.DeleteAlias ( -- * Creating a Request DeleteAlias (..), newDeleteAlias, -- * Request Lenses deleteAlias_organizationId, deleteAlias_entityId, deleteAlias_alias, -- * Destructuring the Response DeleteAliasResponse (..), newDeleteAliasResponse, -- * Response Lenses deleteAliasResponse_httpStatus, ) 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.WorkMail.Types -- | /See:/ 'newDeleteAlias' smart constructor. data DeleteAlias = DeleteAlias' { -- | The identifier for the organization under which the user exists. organizationId :: Prelude.Text, -- | The identifier for the member (user or group) from which to have the -- aliases removed. entityId :: Prelude.Text, -- | The aliases to be removed from the user\'s set of aliases. Duplicate -- entries in the list are collapsed into single entries (the list is -- transformed into a set). alias :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteAlias' 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: -- -- 'organizationId', 'deleteAlias_organizationId' - The identifier for the organization under which the user exists. -- -- 'entityId', 'deleteAlias_entityId' - The identifier for the member (user or group) from which to have the -- aliases removed. -- -- 'alias', 'deleteAlias_alias' - The aliases to be removed from the user\'s set of aliases. Duplicate -- entries in the list are collapsed into single entries (the list is -- transformed into a set). newDeleteAlias :: -- | 'organizationId' Prelude.Text -> -- | 'entityId' Prelude.Text -> -- | 'alias' Prelude.Text -> DeleteAlias newDeleteAlias pOrganizationId_ pEntityId_ pAlias_ = DeleteAlias' { organizationId = pOrganizationId_, entityId = pEntityId_, alias = pAlias_ } -- | The identifier for the organization under which the user exists. deleteAlias_organizationId :: Lens.Lens' DeleteAlias Prelude.Text deleteAlias_organizationId = Lens.lens (\DeleteAlias' {organizationId} -> organizationId) (\s@DeleteAlias' {} a -> s {organizationId = a} :: DeleteAlias) -- | The identifier for the member (user or group) from which to have the -- aliases removed. deleteAlias_entityId :: Lens.Lens' DeleteAlias Prelude.Text deleteAlias_entityId = Lens.lens (\DeleteAlias' {entityId} -> entityId) (\s@DeleteAlias' {} a -> s {entityId = a} :: DeleteAlias) -- | The aliases to be removed from the user\'s set of aliases. Duplicate -- entries in the list are collapsed into single entries (the list is -- transformed into a set). deleteAlias_alias :: Lens.Lens' DeleteAlias Prelude.Text deleteAlias_alias = Lens.lens (\DeleteAlias' {alias} -> alias) (\s@DeleteAlias' {} a -> s {alias = a} :: DeleteAlias) instance Core.AWSRequest DeleteAlias where type AWSResponse DeleteAlias = DeleteAliasResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveEmpty ( \s h x -> DeleteAliasResponse' Prelude.<$> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeleteAlias where hashWithSalt _salt DeleteAlias' {..} = _salt `Prelude.hashWithSalt` organizationId `Prelude.hashWithSalt` entityId `Prelude.hashWithSalt` alias instance Prelude.NFData DeleteAlias where rnf DeleteAlias' {..} = Prelude.rnf organizationId `Prelude.seq` Prelude.rnf entityId `Prelude.seq` Prelude.rnf alias instance Data.ToHeaders DeleteAlias where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "WorkMailService.DeleteAlias" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.1" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeleteAlias where toJSON DeleteAlias' {..} = Data.object ( Prelude.catMaybes [ Prelude.Just ("OrganizationId" Data..= organizationId), Prelude.Just ("EntityId" Data..= entityId), Prelude.Just ("Alias" Data..= alias) ] ) instance Data.ToPath DeleteAlias where toPath = Prelude.const "/" instance Data.ToQuery DeleteAlias where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeleteAliasResponse' smart constructor. data DeleteAliasResponse = DeleteAliasResponse' { -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeleteAliasResponse' 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: -- -- 'httpStatus', 'deleteAliasResponse_httpStatus' - The response's http status code. newDeleteAliasResponse :: -- | 'httpStatus' Prelude.Int -> DeleteAliasResponse newDeleteAliasResponse pHttpStatus_ = DeleteAliasResponse' {httpStatus = pHttpStatus_} -- | The response's http status code. deleteAliasResponse_httpStatus :: Lens.Lens' DeleteAliasResponse Prelude.Int deleteAliasResponse_httpStatus = Lens.lens (\DeleteAliasResponse' {httpStatus} -> httpStatus) (\s@DeleteAliasResponse' {} a -> s {httpStatus = a} :: DeleteAliasResponse) instance Prelude.NFData DeleteAliasResponse where rnf DeleteAliasResponse' {..} = Prelude.rnf httpStatus