{-# 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.PinpointSmsVoiceV2.DeletePool -- 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 an existing pool. Deleting a pool disassociates all origination -- identities from that pool. -- -- If the pool status isn\'t active or if deletion protection is enabled, -- an Error is returned. -- -- A pool is a collection of phone numbers and SenderIds. A pool can -- include one or more phone numbers and SenderIds that are associated with -- your Amazon Web Services account. module Amazonka.PinpointSmsVoiceV2.DeletePool ( -- * Creating a Request DeletePool (..), newDeletePool, -- * Request Lenses deletePool_poolId, -- * Destructuring the Response DeletePoolResponse (..), newDeletePoolResponse, -- * Response Lenses deletePoolResponse_createdTimestamp, deletePoolResponse_messageType, deletePoolResponse_optOutListName, deletePoolResponse_poolArn, deletePoolResponse_poolId, deletePoolResponse_selfManagedOptOutsEnabled, deletePoolResponse_sharedRoutesEnabled, deletePoolResponse_status, deletePoolResponse_twoWayChannelArn, deletePoolResponse_twoWayEnabled, deletePoolResponse_httpStatus, ) where import qualified Amazonka.Core as Core import qualified Amazonka.Core.Lens.Internal as Lens import qualified Amazonka.Data as Data import Amazonka.PinpointSmsVoiceV2.Types import qualified Amazonka.Prelude as Prelude import qualified Amazonka.Request as Request import qualified Amazonka.Response as Response -- | /See:/ 'newDeletePool' smart constructor. data DeletePool = DeletePool' { -- | The PoolId or PoolArn of the pool to delete. You can use DescribePools -- to find the values for PoolId and PoolArn . poolId :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeletePool' 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: -- -- 'poolId', 'deletePool_poolId' - The PoolId or PoolArn of the pool to delete. You can use DescribePools -- to find the values for PoolId and PoolArn . newDeletePool :: -- | 'poolId' Prelude.Text -> DeletePool newDeletePool pPoolId_ = DeletePool' {poolId = pPoolId_} -- | The PoolId or PoolArn of the pool to delete. You can use DescribePools -- to find the values for PoolId and PoolArn . deletePool_poolId :: Lens.Lens' DeletePool Prelude.Text deletePool_poolId = Lens.lens (\DeletePool' {poolId} -> poolId) (\s@DeletePool' {} a -> s {poolId = a} :: DeletePool) instance Core.AWSRequest DeletePool where type AWSResponse DeletePool = DeletePoolResponse request overrides = Request.postJSON (overrides defaultService) response = Response.receiveJSON ( \s h x -> DeletePoolResponse' Prelude.<$> (x Data..?> "CreatedTimestamp") Prelude.<*> (x Data..?> "MessageType") Prelude.<*> (x Data..?> "OptOutListName") Prelude.<*> (x Data..?> "PoolArn") Prelude.<*> (x Data..?> "PoolId") Prelude.<*> (x Data..?> "SelfManagedOptOutsEnabled") Prelude.<*> (x Data..?> "SharedRoutesEnabled") Prelude.<*> (x Data..?> "Status") Prelude.<*> (x Data..?> "TwoWayChannelArn") Prelude.<*> (x Data..?> "TwoWayEnabled") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable DeletePool where hashWithSalt _salt DeletePool' {..} = _salt `Prelude.hashWithSalt` poolId instance Prelude.NFData DeletePool where rnf DeletePool' {..} = Prelude.rnf poolId instance Data.ToHeaders DeletePool where toHeaders = Prelude.const ( Prelude.mconcat [ "X-Amz-Target" Data.=# ( "PinpointSMSVoiceV2.DeletePool" :: Prelude.ByteString ), "Content-Type" Data.=# ( "application/x-amz-json-1.0" :: Prelude.ByteString ) ] ) instance Data.ToJSON DeletePool where toJSON DeletePool' {..} = Data.object ( Prelude.catMaybes [Prelude.Just ("PoolId" Data..= poolId)] ) instance Data.ToPath DeletePool where toPath = Prelude.const "/" instance Data.ToQuery DeletePool where toQuery = Prelude.const Prelude.mempty -- | /See:/ 'newDeletePoolResponse' smart constructor. data DeletePoolResponse = DeletePoolResponse' { -- | The time when the pool was created, in -- format. createdTimestamp :: Prelude.Maybe Data.POSIX, -- | The message type that was associated with the deleted pool. messageType :: Prelude.Maybe MessageType, -- | The name of the OptOutList that was associated with the deleted pool. optOutListName :: Prelude.Maybe Prelude.Text, -- | The Amazon Resource Name (ARN) of the pool that was deleted. poolArn :: Prelude.Maybe Prelude.Text, -- | The PoolId of the pool that was deleted. poolId :: Prelude.Maybe Prelude.Text, -- | By default this is set to false. When an end recipient sends a message -- that begins with HELP or STOP to one of your dedicated numbers, Amazon -- Pinpoint automatically replies with a customizable message and adds the -- end recipient to the OptOutList. When set to true you\'re responsible -- for responding to HELP and STOP requests. You\'re also responsible for -- tracking and honoring opt-out requests. selfManagedOptOutsEnabled :: Prelude.Maybe Prelude.Bool, -- | Indicates whether shared routes are enabled for the pool. sharedRoutesEnabled :: Prelude.Maybe Prelude.Bool, -- | The current status of the pool. -- -- - CREATING: The pool is currently being created and isn\'t yet -- available for use. -- -- - ACTIVE: The pool is active and available for use. -- -- - DELETING: The pool is being deleted. status :: Prelude.Maybe PoolStatus, -- | The Amazon Resource Name (ARN) of the TwoWayChannel. twoWayChannelArn :: Prelude.Maybe Prelude.Text, -- | By default this is set to false. When set to true you can receive -- incoming text messages from your end recipients. twoWayEnabled :: Prelude.Maybe Prelude.Bool, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'DeletePoolResponse' 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', 'deletePoolResponse_createdTimestamp' - The time when the pool was created, in -- format. -- -- 'messageType', 'deletePoolResponse_messageType' - The message type that was associated with the deleted pool. -- -- 'optOutListName', 'deletePoolResponse_optOutListName' - The name of the OptOutList that was associated with the deleted pool. -- -- 'poolArn', 'deletePoolResponse_poolArn' - The Amazon Resource Name (ARN) of the pool that was deleted. -- -- 'poolId', 'deletePoolResponse_poolId' - The PoolId of the pool that was deleted. -- -- 'selfManagedOptOutsEnabled', 'deletePoolResponse_selfManagedOptOutsEnabled' - By default this is set to false. When an end recipient sends a message -- that begins with HELP or STOP to one of your dedicated numbers, Amazon -- Pinpoint automatically replies with a customizable message and adds the -- end recipient to the OptOutList. When set to true you\'re responsible -- for responding to HELP and STOP requests. You\'re also responsible for -- tracking and honoring opt-out requests. -- -- 'sharedRoutesEnabled', 'deletePoolResponse_sharedRoutesEnabled' - Indicates whether shared routes are enabled for the pool. -- -- 'status', 'deletePoolResponse_status' - The current status of the pool. -- -- - CREATING: The pool is currently being created and isn\'t yet -- available for use. -- -- - ACTIVE: The pool is active and available for use. -- -- - DELETING: The pool is being deleted. -- -- 'twoWayChannelArn', 'deletePoolResponse_twoWayChannelArn' - The Amazon Resource Name (ARN) of the TwoWayChannel. -- -- 'twoWayEnabled', 'deletePoolResponse_twoWayEnabled' - By default this is set to false. When set to true you can receive -- incoming text messages from your end recipients. -- -- 'httpStatus', 'deletePoolResponse_httpStatus' - The response's http status code. newDeletePoolResponse :: -- | 'httpStatus' Prelude.Int -> DeletePoolResponse newDeletePoolResponse pHttpStatus_ = DeletePoolResponse' { createdTimestamp = Prelude.Nothing, messageType = Prelude.Nothing, optOutListName = Prelude.Nothing, poolArn = Prelude.Nothing, poolId = Prelude.Nothing, selfManagedOptOutsEnabled = Prelude.Nothing, sharedRoutesEnabled = Prelude.Nothing, status = Prelude.Nothing, twoWayChannelArn = Prelude.Nothing, twoWayEnabled = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The time when the pool was created, in -- format. deletePoolResponse_createdTimestamp :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.UTCTime) deletePoolResponse_createdTimestamp = Lens.lens (\DeletePoolResponse' {createdTimestamp} -> createdTimestamp) (\s@DeletePoolResponse' {} a -> s {createdTimestamp = a} :: DeletePoolResponse) Prelude.. Lens.mapping Data._Time -- | The message type that was associated with the deleted pool. deletePoolResponse_messageType :: Lens.Lens' DeletePoolResponse (Prelude.Maybe MessageType) deletePoolResponse_messageType = Lens.lens (\DeletePoolResponse' {messageType} -> messageType) (\s@DeletePoolResponse' {} a -> s {messageType = a} :: DeletePoolResponse) -- | The name of the OptOutList that was associated with the deleted pool. deletePoolResponse_optOutListName :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Text) deletePoolResponse_optOutListName = Lens.lens (\DeletePoolResponse' {optOutListName} -> optOutListName) (\s@DeletePoolResponse' {} a -> s {optOutListName = a} :: DeletePoolResponse) -- | The Amazon Resource Name (ARN) of the pool that was deleted. deletePoolResponse_poolArn :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Text) deletePoolResponse_poolArn = Lens.lens (\DeletePoolResponse' {poolArn} -> poolArn) (\s@DeletePoolResponse' {} a -> s {poolArn = a} :: DeletePoolResponse) -- | The PoolId of the pool that was deleted. deletePoolResponse_poolId :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Text) deletePoolResponse_poolId = Lens.lens (\DeletePoolResponse' {poolId} -> poolId) (\s@DeletePoolResponse' {} a -> s {poolId = a} :: DeletePoolResponse) -- | By default this is set to false. When an end recipient sends a message -- that begins with HELP or STOP to one of your dedicated numbers, Amazon -- Pinpoint automatically replies with a customizable message and adds the -- end recipient to the OptOutList. When set to true you\'re responsible -- for responding to HELP and STOP requests. You\'re also responsible for -- tracking and honoring opt-out requests. deletePoolResponse_selfManagedOptOutsEnabled :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Bool) deletePoolResponse_selfManagedOptOutsEnabled = Lens.lens (\DeletePoolResponse' {selfManagedOptOutsEnabled} -> selfManagedOptOutsEnabled) (\s@DeletePoolResponse' {} a -> s {selfManagedOptOutsEnabled = a} :: DeletePoolResponse) -- | Indicates whether shared routes are enabled for the pool. deletePoolResponse_sharedRoutesEnabled :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Bool) deletePoolResponse_sharedRoutesEnabled = Lens.lens (\DeletePoolResponse' {sharedRoutesEnabled} -> sharedRoutesEnabled) (\s@DeletePoolResponse' {} a -> s {sharedRoutesEnabled = a} :: DeletePoolResponse) -- | The current status of the pool. -- -- - CREATING: The pool is currently being created and isn\'t yet -- available for use. -- -- - ACTIVE: The pool is active and available for use. -- -- - DELETING: The pool is being deleted. deletePoolResponse_status :: Lens.Lens' DeletePoolResponse (Prelude.Maybe PoolStatus) deletePoolResponse_status = Lens.lens (\DeletePoolResponse' {status} -> status) (\s@DeletePoolResponse' {} a -> s {status = a} :: DeletePoolResponse) -- | The Amazon Resource Name (ARN) of the TwoWayChannel. deletePoolResponse_twoWayChannelArn :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Text) deletePoolResponse_twoWayChannelArn = Lens.lens (\DeletePoolResponse' {twoWayChannelArn} -> twoWayChannelArn) (\s@DeletePoolResponse' {} a -> s {twoWayChannelArn = a} :: DeletePoolResponse) -- | By default this is set to false. When set to true you can receive -- incoming text messages from your end recipients. deletePoolResponse_twoWayEnabled :: Lens.Lens' DeletePoolResponse (Prelude.Maybe Prelude.Bool) deletePoolResponse_twoWayEnabled = Lens.lens (\DeletePoolResponse' {twoWayEnabled} -> twoWayEnabled) (\s@DeletePoolResponse' {} a -> s {twoWayEnabled = a} :: DeletePoolResponse) -- | The response's http status code. deletePoolResponse_httpStatus :: Lens.Lens' DeletePoolResponse Prelude.Int deletePoolResponse_httpStatus = Lens.lens (\DeletePoolResponse' {httpStatus} -> httpStatus) (\s@DeletePoolResponse' {} a -> s {httpStatus = a} :: DeletePoolResponse) instance Prelude.NFData DeletePoolResponse where rnf DeletePoolResponse' {..} = Prelude.rnf createdTimestamp `Prelude.seq` Prelude.rnf messageType `Prelude.seq` Prelude.rnf optOutListName `Prelude.seq` Prelude.rnf poolArn `Prelude.seq` Prelude.rnf poolId `Prelude.seq` Prelude.rnf selfManagedOptOutsEnabled `Prelude.seq` Prelude.rnf sharedRoutesEnabled `Prelude.seq` Prelude.rnf status `Prelude.seq` Prelude.rnf twoWayChannelArn `Prelude.seq` Prelude.rnf twoWayEnabled `Prelude.seq` Prelude.rnf httpStatus