{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DuplicateRecordFields #-} {-# LANGUAGE NamedFieldPuns #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RecordWildCards #-} {-# LANGUAGE StrictData #-} {-# LANGUAGE NoImplicitPrelude #-} {-# 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.Types.SNSAction -- Copyright : (c) 2013-2023 Brendan Hay -- License : Mozilla Public License, v. 2.0. -- Maintainer : Brendan Hay -- Stability : auto-generated -- Portability : non-portable (GHC extensions) module Amazonka.SES.Types.SNSAction 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 Amazonka.SES.Types.SNSActionEncoding -- | When included in a receipt rule, this action publishes a notification to -- Amazon Simple Notification Service (Amazon SNS). This action includes a -- complete copy of the email content in the Amazon SNS notifications. -- Amazon SNS notifications for all other actions simply provide -- information about the email. They do not include the email content -- itself. -- -- If you own the Amazon SNS topic, you don\'t need to do anything to give -- Amazon SES permission to publish emails to it. However, if you don\'t -- own the Amazon SNS topic, you need to attach a policy to the topic to -- give Amazon SES permissions to access it. For information about giving -- permissions, see the -- . -- -- You can only publish emails that are 150 KB or less (including the -- header) to Amazon SNS. Larger emails will bounce. If you anticipate -- emails larger than 150 KB, use the S3 action instead. -- -- For information about using a receipt rule to publish an Amazon SNS -- notification, see the -- . -- -- /See:/ 'newSNSAction' smart constructor. data SNSAction = SNSAction' { -- | The encoding to use for the email within the Amazon SNS notification. -- UTF-8 is easier to use, but may not preserve all special characters when -- a message was encoded with a different encoding format. Base64 preserves -- all special characters. The default value is UTF-8. encoding :: Prelude.Maybe SNSActionEncoding, -- | The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An -- example of an Amazon SNS topic ARN is -- @arn:aws:sns:us-west-2:123456789012:MyTopic@. For more information about -- Amazon SNS topics, see the -- . topicArn :: Prelude.Text } deriving (Prelude.Eq, Prelude.Read, Prelude.Show, Prelude.Generic) -- | -- Create a value of 'SNSAction' 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: -- -- 'encoding', 'sNSAction_encoding' - The encoding to use for the email within the Amazon SNS notification. -- UTF-8 is easier to use, but may not preserve all special characters when -- a message was encoded with a different encoding format. Base64 preserves -- all special characters. The default value is UTF-8. -- -- 'topicArn', 'sNSAction_topicArn' - The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An -- example of an Amazon SNS topic ARN is -- @arn:aws:sns:us-west-2:123456789012:MyTopic@. For more information about -- Amazon SNS topics, see the -- . newSNSAction :: -- | 'topicArn' Prelude.Text -> SNSAction newSNSAction pTopicArn_ = SNSAction' { encoding = Prelude.Nothing, topicArn = pTopicArn_ } -- | The encoding to use for the email within the Amazon SNS notification. -- UTF-8 is easier to use, but may not preserve all special characters when -- a message was encoded with a different encoding format. Base64 preserves -- all special characters. The default value is UTF-8. sNSAction_encoding :: Lens.Lens' SNSAction (Prelude.Maybe SNSActionEncoding) sNSAction_encoding = Lens.lens (\SNSAction' {encoding} -> encoding) (\s@SNSAction' {} a -> s {encoding = a} :: SNSAction) -- | The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An -- example of an Amazon SNS topic ARN is -- @arn:aws:sns:us-west-2:123456789012:MyTopic@. For more information about -- Amazon SNS topics, see the -- . sNSAction_topicArn :: Lens.Lens' SNSAction Prelude.Text sNSAction_topicArn = Lens.lens (\SNSAction' {topicArn} -> topicArn) (\s@SNSAction' {} a -> s {topicArn = a} :: SNSAction) instance Data.FromXML SNSAction where parseXML x = SNSAction' Prelude.<$> (x Data..@? "Encoding") Prelude.<*> (x Data..@ "TopicArn") instance Prelude.Hashable SNSAction where hashWithSalt _salt SNSAction' {..} = _salt `Prelude.hashWithSalt` encoding `Prelude.hashWithSalt` topicArn instance Prelude.NFData SNSAction where rnf SNSAction' {..} = Prelude.rnf encoding `Prelude.seq` Prelude.rnf topicArn instance Data.ToQuery SNSAction where toQuery SNSAction' {..} = Prelude.mconcat [ "Encoding" Data.=: encoding, "TopicArn" Data.=: topicArn ]