{-# 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.SES.SendBounce -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) -- -- Generates and sends a bounce message to the sender of an email you -- received through Amazon SES. You can only use this API on an email up to -- 24 hours after you receive it. -- -- You cannot use this API to send generic bounces for mail that was not -- received by Amazon SES. -- -- For information about receiving email through Amazon SES, see the -- . -- -- You can execute this operation no more than once per second. module Amazonka.SES.SendBounce ( -- * Creating a Request SendBounce (..), newSendBounce, -- * Request Lenses sendBounce_bounceSenderArn, sendBounce_explanation, sendBounce_messageDsn, sendBounce_originalMessageId, sendBounce_bounceSender, sendBounce_bouncedRecipientInfoList, -- * Destructuring the Response SendBounceResponse (..), newSendBounceResponse, -- * Response Lenses sendBounceResponse_messageId, sendBounceResponse_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.SES.Types -- | Represents a request to send a bounce message to the sender of an email -- you received through Amazon SES. -- -- /See:/ 'newSendBounce' smart constructor. data SendBounce = SendBounce' { -- | This parameter is used only for sending authorization. It is the ARN of -- the identity that is associated with the sending authorization policy -- that permits you to use the address in the \"From\" header of the -- bounce. For more information about sending authorization, see the -- . bounceSenderArn :: Prelude.Maybe Prelude.Text, -- | Human-readable text for the bounce message to explain the failure. If -- not specified, the text will be auto-generated based on the bounced -- recipient information. explanation :: Prelude.Maybe Prelude.Text, -- | Message-related DSN fields. If not specified, Amazon SES will choose the -- values. messageDsn :: Prelude.Maybe MessageDsn, -- | The message ID of the message to be bounced. originalMessageId :: Prelude.Text, -- | The address to use in the \"From\" header of the bounce message. This -- must be an identity that you have verified with Amazon SES. bounceSender :: Prelude.Text, -- | A list of recipients of the bounced message, including the information -- required to create the Delivery Status Notifications (DSNs) for the -- recipients. You must specify at least one @BouncedRecipientInfo@ in the -- list. bouncedRecipientInfoList :: [BouncedRecipientInfo] } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SendBounce' 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: -- -- 'bounceSenderArn', 'sendBounce_bounceSenderArn' - This parameter is used only for sending authorization. It is the ARN of -- the identity that is associated with the sending authorization policy -- that permits you to use the address in the \"From\" header of the -- bounce. For more information about sending authorization, see the -- . -- -- 'explanation', 'sendBounce_explanation' - Human-readable text for the bounce message to explain the failure. If -- not specified, the text will be auto-generated based on the bounced -- recipient information. -- -- 'messageDsn', 'sendBounce_messageDsn' - Message-related DSN fields. If not specified, Amazon SES will choose the -- values. -- -- 'originalMessageId', 'sendBounce_originalMessageId' - The message ID of the message to be bounced. -- -- 'bounceSender', 'sendBounce_bounceSender' - The address to use in the \"From\" header of the bounce message. This -- must be an identity that you have verified with Amazon SES. -- -- 'bouncedRecipientInfoList', 'sendBounce_bouncedRecipientInfoList' - A list of recipients of the bounced message, including the information -- required to create the Delivery Status Notifications (DSNs) for the -- recipients. You must specify at least one @BouncedRecipientInfo@ in the -- list. newSendBounce :: -- | 'originalMessageId' Prelude.Text -> -- | 'bounceSender' Prelude.Text -> SendBounce newSendBounce pOriginalMessageId_ pBounceSender_ = SendBounce' { bounceSenderArn = Prelude.Nothing, explanation = Prelude.Nothing, messageDsn = Prelude.Nothing, originalMessageId = pOriginalMessageId_, bounceSender = pBounceSender_, bouncedRecipientInfoList = Prelude.mempty } -- | This parameter is used only for sending authorization. It is the ARN of -- the identity that is associated with the sending authorization policy -- that permits you to use the address in the \"From\" header of the -- bounce. For more information about sending authorization, see the -- . sendBounce_bounceSenderArn :: Lens.Lens' SendBounce (Prelude.Maybe Prelude.Text) sendBounce_bounceSenderArn = Lens.lens (\SendBounce' {bounceSenderArn} -> bounceSenderArn) (\s@SendBounce' {} a -> s {bounceSenderArn = a} :: SendBounce) -- | Human-readable text for the bounce message to explain the failure. If -- not specified, the text will be auto-generated based on the bounced -- recipient information. sendBounce_explanation :: Lens.Lens' SendBounce (Prelude.Maybe Prelude.Text) sendBounce_explanation = Lens.lens (\SendBounce' {explanation} -> explanation) (\s@SendBounce' {} a -> s {explanation = a} :: SendBounce) -- | Message-related DSN fields. If not specified, Amazon SES will choose the -- values. sendBounce_messageDsn :: Lens.Lens' SendBounce (Prelude.Maybe MessageDsn) sendBounce_messageDsn = Lens.lens (\SendBounce' {messageDsn} -> messageDsn) (\s@SendBounce' {} a -> s {messageDsn = a} :: SendBounce) -- | The message ID of the message to be bounced. sendBounce_originalMessageId :: Lens.Lens' SendBounce Prelude.Text sendBounce_originalMessageId = Lens.lens (\SendBounce' {originalMessageId} -> originalMessageId) (\s@SendBounce' {} a -> s {originalMessageId = a} :: SendBounce) -- | The address to use in the \"From\" header of the bounce message. This -- must be an identity that you have verified with Amazon SES. sendBounce_bounceSender :: Lens.Lens' SendBounce Prelude.Text sendBounce_bounceSender = Lens.lens (\SendBounce' {bounceSender} -> bounceSender) (\s@SendBounce' {} a -> s {bounceSender = a} :: SendBounce) -- | A list of recipients of the bounced message, including the information -- required to create the Delivery Status Notifications (DSNs) for the -- recipients. You must specify at least one @BouncedRecipientInfo@ in the -- list. sendBounce_bouncedRecipientInfoList :: Lens.Lens' SendBounce [BouncedRecipientInfo] sendBounce_bouncedRecipientInfoList = Lens.lens (\SendBounce' {bouncedRecipientInfoList} -> bouncedRecipientInfoList) (\s@SendBounce' {} a -> s {bouncedRecipientInfoList = a} :: SendBounce) Prelude.. Lens.coerced instance Core.AWSRequest SendBounce where type AWSResponse SendBounce = SendBounceResponse request overrides = Request.postQuery (overrides defaultService) response = Response.receiveXMLWrapper "SendBounceResult" ( \s h x -> SendBounceResponse' Prelude.<$> (x Data..@? "MessageId") Prelude.<*> (Prelude.pure (Prelude.fromEnum s)) ) instance Prelude.Hashable SendBounce where hashWithSalt _salt SendBounce' {..} = _salt `Prelude.hashWithSalt` bounceSenderArn `Prelude.hashWithSalt` explanation `Prelude.hashWithSalt` messageDsn `Prelude.hashWithSalt` originalMessageId `Prelude.hashWithSalt` bounceSender `Prelude.hashWithSalt` bouncedRecipientInfoList instance Prelude.NFData SendBounce where rnf SendBounce' {..} = Prelude.rnf bounceSenderArn `Prelude.seq` Prelude.rnf explanation `Prelude.seq` Prelude.rnf messageDsn `Prelude.seq` Prelude.rnf originalMessageId `Prelude.seq` Prelude.rnf bounceSender `Prelude.seq` Prelude.rnf bouncedRecipientInfoList instance Data.ToHeaders SendBounce where toHeaders = Prelude.const Prelude.mempty instance Data.ToPath SendBounce where toPath = Prelude.const "/" instance Data.ToQuery SendBounce where toQuery SendBounce' {..} = Prelude.mconcat [ "Action" Data.=: ("SendBounce" :: Prelude.ByteString), "Version" Data.=: ("2010-12-01" :: Prelude.ByteString), "BounceSenderArn" Data.=: bounceSenderArn, "Explanation" Data.=: explanation, "MessageDsn" Data.=: messageDsn, "OriginalMessageId" Data.=: originalMessageId, "BounceSender" Data.=: bounceSender, "BouncedRecipientInfoList" Data.=: Data.toQueryList "member" bouncedRecipientInfoList ] -- | Represents a unique message ID. -- -- /See:/ 'newSendBounceResponse' smart constructor. data SendBounceResponse = SendBounceResponse' { -- | The message ID of the bounce message. messageId :: Prelude.Maybe Prelude.Text, -- | The response's http status code. httpStatus :: Prelude.Int } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SendBounceResponse' 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: -- -- 'messageId', 'sendBounceResponse_messageId' - The message ID of the bounce message. -- -- 'httpStatus', 'sendBounceResponse_httpStatus' - The response's http status code. newSendBounceResponse :: -- | 'httpStatus' Prelude.Int -> SendBounceResponse newSendBounceResponse pHttpStatus_ = SendBounceResponse' { messageId = Prelude.Nothing, httpStatus = pHttpStatus_ } -- | The message ID of the bounce message. sendBounceResponse_messageId :: Lens.Lens' SendBounceResponse (Prelude.Maybe Prelude.Text) sendBounceResponse_messageId = Lens.lens (\SendBounceResponse' {messageId} -> messageId) (\s@SendBounceResponse' {} a -> s {messageId = a} :: SendBounceResponse) -- | The response's http status code. sendBounceResponse_httpStatus :: Lens.Lens' SendBounceResponse Prelude.Int sendBounceResponse_httpStatus = Lens.lens (\SendBounceResponse' {httpStatus} -> httpStatus) (\s@SendBounceResponse' {} a -> s {httpStatus = a} :: SendBounceResponse) instance Prelude.NFData SendBounceResponse where rnf SendBounceResponse' {..} = Prelude.rnf messageId `Prelude.seq` Prelude.rnf httpStatus