This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
pxz-hos-client-cpp-module/support/aws-sdk-cpp-master/aws-cpp-sdk-email/include/aws/email/model/SNSAction.h

200 lines
8.7 KiB
C++

/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
* SPDX-License-Identifier: Apache-2.0.
*/
#pragma once
#include <aws/email/SES_EXPORTS.h>
#include <aws/core/utils/memory/stl/AWSStreamFwd.h>
#include <aws/core/utils/memory/stl/AWSString.h>
#include <aws/email/model/SNSActionEncoding.h>
#include <utility>
namespace Aws
{
namespace Utils
{
namespace Xml
{
class XmlNode;
} // namespace Xml
} // namespace Utils
namespace SES
{
namespace Model
{
/**
* <p>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.</p> <p>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 <a
* href="https://docs.aws.amazon.com/ses/latest/DeveloperGuide/receiving-email-permissions.html">Amazon
* SES Developer Guide</a>.</p> <p>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.</p>
* <p>For information about using a receipt rule to publish an Amazon
* SNS notification, see the <a
* href="https://docs.aws.amazon.com/ses/latest/DeveloperGuide/receiving-email-action-sns.html">Amazon
* SES Developer Guide</a>.</p><p><h3>See Also:</h3> <a
* href="http://docs.aws.amazon.com/goto/WebAPI/email-2010-12-01/SNSAction">AWS API
* Reference</a></p>
*/
class AWS_SES_API SNSAction
{
public:
SNSAction();
SNSAction(const Aws::Utils::Xml::XmlNode& xmlNode);
SNSAction& operator=(const Aws::Utils::Xml::XmlNode& xmlNode);
void OutputToStream(Aws::OStream& ostream, const char* location, unsigned index, const char* locationValue) const;
void OutputToStream(Aws::OStream& oStream, const char* location) const;
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline const Aws::String& GetTopicArn() const{ return m_topicArn; }
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline bool TopicArnHasBeenSet() const { return m_topicArnHasBeenSet; }
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline void SetTopicArn(const Aws::String& value) { m_topicArnHasBeenSet = true; m_topicArn = value; }
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline void SetTopicArn(Aws::String&& value) { m_topicArnHasBeenSet = true; m_topicArn = std::move(value); }
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline void SetTopicArn(const char* value) { m_topicArnHasBeenSet = true; m_topicArn.assign(value); }
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline SNSAction& WithTopicArn(const Aws::String& value) { SetTopicArn(value); return *this;}
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline SNSAction& WithTopicArn(Aws::String&& value) { SetTopicArn(std::move(value)); return *this;}
/**
* <p>The Amazon Resource Name (ARN) of the Amazon SNS topic to notify. An example
* of an Amazon SNS topic ARN is
* <code>arn:aws:sns:us-west-2:123456789012:MyTopic</code>. For more information
* about Amazon SNS topics, see the <a
* href="https://docs.aws.amazon.com/sns/latest/dg/CreateTopic.html">Amazon SNS
* Developer Guide</a>.</p>
*/
inline SNSAction& WithTopicArn(const char* value) { SetTopicArn(value); return *this;}
/**
* <p>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.</p>
*/
inline const SNSActionEncoding& GetEncoding() const{ return m_encoding; }
/**
* <p>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.</p>
*/
inline bool EncodingHasBeenSet() const { return m_encodingHasBeenSet; }
/**
* <p>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.</p>
*/
inline void SetEncoding(const SNSActionEncoding& value) { m_encodingHasBeenSet = true; m_encoding = value; }
/**
* <p>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.</p>
*/
inline void SetEncoding(SNSActionEncoding&& value) { m_encodingHasBeenSet = true; m_encoding = std::move(value); }
/**
* <p>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.</p>
*/
inline SNSAction& WithEncoding(const SNSActionEncoding& value) { SetEncoding(value); return *this;}
/**
* <p>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.</p>
*/
inline SNSAction& WithEncoding(SNSActionEncoding&& value) { SetEncoding(std::move(value)); return *this;}
private:
Aws::String m_topicArn;
bool m_topicArnHasBeenSet;
SNSActionEncoding m_encoding;
bool m_encodingHasBeenSet;
};
} // namespace Model
} // namespace SES
} // namespace Aws