/* * Copyright 2010-2023 Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ package com.amazonaws.services.sns.model; import java.io.Serializable; import com.amazonaws.AmazonWebServiceRequest; /** *
* Subscribes an endpoint to an Amazon SNS topic. If the endpoint type is HTTP/S
* or email, or if the endpoint and the topic are not in the same Amazon Web
* Services account, the endpoint owner must run the
* ConfirmSubscription
action to confirm the subscription.
*
* You call the ConfirmSubscription
action with the token from the
* subscription response. Confirmation tokens are valid for three days.
*
* This action is throttled at 100 transactions per second (TPS). *
*/ public class SubscribeRequest extends AmazonWebServiceRequest implements Serializable { /** ** The ARN of the topic you want to subscribe to. *
*/ private String topicArn; /** ** The protocol that you want to use. Supported protocols include: *
*
* http
– delivery of JSON-encoded message via HTTP POST
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS
* queue
*
* application
– delivery of JSON-encoded message to an
* EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an Lambda
* function
*
* firehose
– delivery of JSON-encoded message to an Amazon
* Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints vary by * protocol: *
*
* For the http
protocol, the (public) endpoint is a URL
* beginning with http://
.
*
* For the https
protocol, the (public) endpoint is a URL
* beginning with https://
.
*
* For the email
protocol, the endpoint is an email address.
*
* For the email-json
protocol, the endpoint is an email
* address.
*
* For the sms
protocol, the endpoint is a phone number of an
* SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon
* SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN of an
* Lambda function.
*
* For the firehose
protocol, the endpoint is the ARN of an
* Amazon Kinesis Data Firehose delivery stream.
*
* A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the special
* request parameters that the Subscribe
action uses:
*
* DeliveryPolicy
– The policy that defines how Amazon SNS
* retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than receiving every
* message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose the
* filtering scope by using one of the following string value types:
*
* MessageAttributes
(default) – The filter is applied on the
* message attributes.
*
* MessageBody
– The filter is applied on the message body.
*
* RawMessageDelivery
– When set to true
, enables
* raw message delivery to Amazon SQS or HTTP/S endpoints. This eliminates
* the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable messages
* to the specified Amazon SQS dead-letter queue. Messages that can't be
* delivered due to client errors (for example, when the subscribed endpoint
* is unreachable) or server errors (for example, when the service that
* powers the subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data Firehose * delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that has the
* following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis Data * Firehose delivery stream subscriptions. For more information, see Fanout to Kinesis Data Firehose delivery streams in the Amazon * SNS Developer Guide. *
*
* Sets whether the response from the Subscribe
request
* includes the subscription ARN, even if the subscription is not yet
* confirmed.
*
* If you set this parameter to true
, the response includes the
* ARN in all cases, even if the subscription is not yet confirmed. In
* addition to the ARN for confirmed subscriptions, the response also
* includes the pending subscription
ARN value for
* subscriptions that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
*
* The default value is false
.
*
* The ARN of the topic you want to subscribe to. *
* @param protocol* The protocol that you want to use. Supported protocols * include: *
*
* http
– delivery of JSON-encoded message via HTTP
* POST
*
* https
– delivery of JSON-encoded message via
* HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via
* SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an
* Amazon SQS queue
*
* application
– delivery of JSON-encoded message to
* an EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an
* Lambda function
*
* firehose
– delivery of JSON-encoded message to an
* Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints * vary by protocol: *
*
* For the http
protocol, the (public) endpoint is a
* URL beginning with http://
.
*
* For the https
protocol, the (public) endpoint is
* a URL beginning with https://
.
*
* For the email
protocol, the endpoint is an email
* address.
*
* For the email-json
protocol, the endpoint is an
* email address.
*
* For the sms
protocol, the endpoint is a phone
* number of an SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of
* an Amazon SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN
* of an Lambda function.
*
* For the firehose
protocol, the endpoint is the
* ARN of an Amazon Kinesis Data Firehose delivery stream.
*
* The ARN of the topic you want to subscribe to. *
* * @return* The ARN of the topic you want to subscribe to. *
*/ public String getTopicArn() { return topicArn; } /** ** The ARN of the topic you want to subscribe to. *
* * @param topicArn* The ARN of the topic you want to subscribe to. *
*/ public void setTopicArn(String topicArn) { this.topicArn = topicArn; } /** ** The ARN of the topic you want to subscribe to. *
** Returns a reference to this object so that method calls can be chained * together. * * @param topicArn
* The ARN of the topic you want to subscribe to. *
* @return A reference to this updated object so that method calls can be * chained together. */ public SubscribeRequest withTopicArn(String topicArn) { this.topicArn = topicArn; return this; } /** ** The protocol that you want to use. Supported protocols include: *
*
* http
– delivery of JSON-encoded message via HTTP POST
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS
* queue
*
* application
– delivery of JSON-encoded message to an
* EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an Lambda
* function
*
* firehose
– delivery of JSON-encoded message to an Amazon
* Kinesis Data Firehose delivery stream.
*
* The protocol that you want to use. Supported protocols include: *
*
* http
– delivery of JSON-encoded message via HTTP
* POST
*
* https
– delivery of JSON-encoded message via HTTPS
* POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via
* SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an Amazon
* SQS queue
*
* application
– delivery of JSON-encoded message to an
* EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an
* Lambda function
*
* firehose
– delivery of JSON-encoded message to an
* Amazon Kinesis Data Firehose delivery stream.
*
* The protocol that you want to use. Supported protocols include: *
*
* http
– delivery of JSON-encoded message via HTTP POST
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS
* queue
*
* application
– delivery of JSON-encoded message to an
* EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an Lambda
* function
*
* firehose
– delivery of JSON-encoded message to an Amazon
* Kinesis Data Firehose delivery stream.
*
* The protocol that you want to use. Supported protocols * include: *
*
* http
– delivery of JSON-encoded message via HTTP
* POST
*
* https
– delivery of JSON-encoded message via
* HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via
* SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an
* Amazon SQS queue
*
* application
– delivery of JSON-encoded message to
* an EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an
* Lambda function
*
* firehose
– delivery of JSON-encoded message to an
* Amazon Kinesis Data Firehose delivery stream.
*
* The protocol that you want to use. Supported protocols include: *
*
* http
– delivery of JSON-encoded message via HTTP POST
*
* https
– delivery of JSON-encoded message via HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an Amazon SQS
* queue
*
* application
– delivery of JSON-encoded message to an
* EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an Lambda
* function
*
* firehose
– delivery of JSON-encoded message to an Amazon
* Kinesis Data Firehose delivery stream.
*
* Returns a reference to this object so that method calls can be chained * together. * * @param protocol
* The protocol that you want to use. Supported protocols * include: *
*
* http
– delivery of JSON-encoded message via HTTP
* POST
*
* https
– delivery of JSON-encoded message via
* HTTPS POST
*
* email
– delivery of message via SMTP
*
* email-json
– delivery of JSON-encoded message via
* SMTP
*
* sms
– delivery of message via SMS
*
* sqs
– delivery of JSON-encoded message to an
* Amazon SQS queue
*
* application
– delivery of JSON-encoded message to
* an EndpointArn for a mobile app and device
*
* lambda
– delivery of JSON-encoded message to an
* Lambda function
*
* firehose
– delivery of JSON-encoded message to an
* Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints vary by * protocol: *
*
* For the http
protocol, the (public) endpoint is a URL
* beginning with http://
.
*
* For the https
protocol, the (public) endpoint is a URL
* beginning with https://
.
*
* For the email
protocol, the endpoint is an email address.
*
* For the email-json
protocol, the endpoint is an email
* address.
*
* For the sms
protocol, the endpoint is a phone number of an
* SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon
* SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN of an
* Lambda function.
*
* For the firehose
protocol, the endpoint is the ARN of an
* Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints * vary by protocol: *
*
* For the http
protocol, the (public) endpoint is a
* URL beginning with http://
.
*
* For the https
protocol, the (public) endpoint is a
* URL beginning with https://
.
*
* For the email
protocol, the endpoint is an email
* address.
*
* For the email-json
protocol, the endpoint is an
* email address.
*
* For the sms
protocol, the endpoint is a phone number
* of an SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of an
* Amazon SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN of
* an Lambda function.
*
* For the firehose
protocol, the endpoint is the ARN
* of an Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints vary by * protocol: *
*
* For the http
protocol, the (public) endpoint is a URL
* beginning with http://
.
*
* For the https
protocol, the (public) endpoint is a URL
* beginning with https://
.
*
* For the email
protocol, the endpoint is an email address.
*
* For the email-json
protocol, the endpoint is an email
* address.
*
* For the sms
protocol, the endpoint is a phone number of an
* SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon
* SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN of an
* Lambda function.
*
* For the firehose
protocol, the endpoint is the ARN of an
* Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints * vary by protocol: *
*
* For the http
protocol, the (public) endpoint is a
* URL beginning with http://
.
*
* For the https
protocol, the (public) endpoint is
* a URL beginning with https://
.
*
* For the email
protocol, the endpoint is an email
* address.
*
* For the email-json
protocol, the endpoint is an
* email address.
*
* For the sms
protocol, the endpoint is a phone
* number of an SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of
* an Amazon SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN
* of an Lambda function.
*
* For the firehose
protocol, the endpoint is the
* ARN of an Amazon Kinesis Data Firehose delivery stream.
*
* The endpoint that you want to receive notifications. Endpoints vary by * protocol: *
*
* For the http
protocol, the (public) endpoint is a URL
* beginning with http://
.
*
* For the https
protocol, the (public) endpoint is a URL
* beginning with https://
.
*
* For the email
protocol, the endpoint is an email address.
*
* For the email-json
protocol, the endpoint is an email
* address.
*
* For the sms
protocol, the endpoint is a phone number of an
* SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of an Amazon
* SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN of an
* Lambda function.
*
* For the firehose
protocol, the endpoint is the ARN of an
* Amazon Kinesis Data Firehose delivery stream.
*
* Returns a reference to this object so that method calls can be chained * together. * * @param endpoint
* The endpoint that you want to receive notifications. Endpoints * vary by protocol: *
*
* For the http
protocol, the (public) endpoint is a
* URL beginning with http://
.
*
* For the https
protocol, the (public) endpoint is
* a URL beginning with https://
.
*
* For the email
protocol, the endpoint is an email
* address.
*
* For the email-json
protocol, the endpoint is an
* email address.
*
* For the sms
protocol, the endpoint is a phone
* number of an SMS-enabled device.
*
* For the sqs
protocol, the endpoint is the ARN of
* an Amazon SQS queue.
*
* For the application
protocol, the endpoint is the
* EndpointArn of a mobile app and device.
*
* For the lambda
protocol, the endpoint is the ARN
* of an Lambda function.
*
* For the firehose
protocol, the endpoint is the
* ARN of an Amazon Kinesis Data Firehose delivery stream.
*
* A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the special
* request parameters that the Subscribe
action uses:
*
* DeliveryPolicy
– The policy that defines how Amazon SNS
* retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than receiving every
* message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose the
* filtering scope by using one of the following string value types:
*
* MessageAttributes
(default) – The filter is applied on the
* message attributes.
*
* MessageBody
– The filter is applied on the message body.
*
* RawMessageDelivery
– When set to true
, enables
* raw message delivery to Amazon SQS or HTTP/S endpoints. This eliminates
* the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable messages
* to the specified Amazon SQS dead-letter queue. Messages that can't be
* delivered due to client errors (for example, when the subscribed endpoint
* is unreachable) or server errors (for example, when the service that
* powers the subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data Firehose * delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that has the
* following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis Data * Firehose delivery stream subscriptions. For more information, see Fanout to Kinesis Data Firehose delivery streams in the Amazon * SNS Developer Guide. *
** A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the
* special request parameters that the Subscribe
action
* uses:
*
* DeliveryPolicy
– The policy that defines how Amazon
* SNS retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than
* receiving every message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose
* the filtering scope by using one of the following string value
* types:
*
* MessageAttributes
(default) – The filter is applied
* on the message attributes.
*
* MessageBody
– The filter is applied on the message
* body.
*
* RawMessageDelivery
– When set to true
,
* enables raw message delivery to Amazon SQS or HTTP/S endpoints.
* This eliminates the need for the endpoints to process JSON
* formatting, which is otherwise created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable
* messages to the specified Amazon SQS dead-letter queue. Messages
* that can't be delivered due to client errors (for example, when
* the subscribed endpoint is unreachable) or server errors (for
* example, when the service that powers the subscribed endpoint
* becomes unavailable) are held in the dead-letter queue for
* further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data * Firehose delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that
* has the following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis * Data Firehose delivery stream subscriptions. For more * information, see Fanout to Kinesis Data Firehose delivery streams in the * Amazon SNS Developer Guide. *
** A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the special
* request parameters that the Subscribe
action uses:
*
* DeliveryPolicy
– The policy that defines how Amazon SNS
* retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than receiving every
* message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose the
* filtering scope by using one of the following string value types:
*
* MessageAttributes
(default) – The filter is applied on the
* message attributes.
*
* MessageBody
– The filter is applied on the message body.
*
* RawMessageDelivery
– When set to true
, enables
* raw message delivery to Amazon SQS or HTTP/S endpoints. This eliminates
* the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable messages
* to the specified Amazon SQS dead-letter queue. Messages that can't be
* delivered due to client errors (for example, when the subscribed endpoint
* is unreachable) or server errors (for example, when the service that
* powers the subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data Firehose * delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that has the
* following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis Data * Firehose delivery stream subscriptions. For more information, see Fanout to Kinesis Data Firehose delivery streams in the Amazon * SNS Developer Guide. *
** A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the
* special request parameters that the Subscribe
* action uses:
*
* DeliveryPolicy
– The policy that defines how
* Amazon SNS retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets
* your subscriber receive only a subset of messages, rather than
* receiving every message published to the topic.
*
* FilterPolicyScope
– This attribute lets you
* choose the filtering scope by using one of the following
* string value types:
*
* MessageAttributes
(default) – The filter is
* applied on the message attributes.
*
* MessageBody
– The filter is applied on the
* message body.
*
* RawMessageDelivery
– When set to
* true
, enables raw message delivery to Amazon SQS
* or HTTP/S endpoints. This eliminates the need for the
* endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends
* undeliverable messages to the specified Amazon SQS dead-letter
* queue. Messages that can't be delivered due to client errors
* (for example, when the subscribed endpoint is unreachable) or
* server errors (for example, when the service that powers the
* subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data * Firehose delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role
* that has the following:
*
* Permission to write to the Kinesis Data Firehose delivery * stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for * Kinesis Data Firehose delivery stream subscriptions. For more * information, see Fanout to Kinesis Data Firehose delivery streams in the * Amazon SNS Developer Guide. *
** A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the special
* request parameters that the Subscribe
action uses:
*
* DeliveryPolicy
– The policy that defines how Amazon SNS
* retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than receiving every
* message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose the
* filtering scope by using one of the following string value types:
*
* MessageAttributes
(default) – The filter is applied on the
* message attributes.
*
* MessageBody
– The filter is applied on the message body.
*
* RawMessageDelivery
– When set to true
, enables
* raw message delivery to Amazon SQS or HTTP/S endpoints. This eliminates
* the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable messages
* to the specified Amazon SQS dead-letter queue. Messages that can't be
* delivered due to client errors (for example, when the subscribed endpoint
* is unreachable) or server errors (for example, when the service that
* powers the subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data Firehose * delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that has the
* following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis Data * Firehose delivery stream subscriptions. For more information, see Fanout to Kinesis Data Firehose delivery streams in the Amazon * SNS Developer Guide. *
** Returns a reference to this object so that method calls can be chained * together. * * @param attributes
* A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the
* special request parameters that the Subscribe
* action uses:
*
* DeliveryPolicy
– The policy that defines how
* Amazon SNS retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets
* your subscriber receive only a subset of messages, rather than
* receiving every message published to the topic.
*
* FilterPolicyScope
– This attribute lets you
* choose the filtering scope by using one of the following
* string value types:
*
* MessageAttributes
(default) – The filter is
* applied on the message attributes.
*
* MessageBody
– The filter is applied on the
* message body.
*
* RawMessageDelivery
– When set to
* true
, enables raw message delivery to Amazon SQS
* or HTTP/S endpoints. This eliminates the need for the
* endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends
* undeliverable messages to the specified Amazon SQS dead-letter
* queue. Messages that can't be delivered due to client errors
* (for example, when the subscribed endpoint is unreachable) or
* server errors (for example, when the service that powers the
* subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data * Firehose delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role
* that has the following:
*
* Permission to write to the Kinesis Data Firehose delivery * stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for * Kinesis Data Firehose delivery stream subscriptions. For more * information, see Fanout to Kinesis Data Firehose delivery streams in the * Amazon SNS Developer Guide. *
** A map of attributes with their corresponding values. *
*
* The following lists the names, descriptions, and values of the special
* request parameters that the Subscribe
action uses:
*
* DeliveryPolicy
– The policy that defines how Amazon SNS
* retries failed deliveries to HTTP/S endpoints.
*
* FilterPolicy
– The simple JSON object that lets your
* subscriber receive only a subset of messages, rather than receiving every
* message published to the topic.
*
* FilterPolicyScope
– This attribute lets you choose the
* filtering scope by using one of the following string value types:
*
* MessageAttributes
(default) – The filter is applied on the
* message attributes.
*
* MessageBody
– The filter is applied on the message body.
*
* RawMessageDelivery
– When set to true
, enables
* raw message delivery to Amazon SQS or HTTP/S endpoints. This eliminates
* the need for the endpoints to process JSON formatting, which is otherwise
* created for Amazon SNS metadata.
*
* RedrivePolicy
– When specified, sends undeliverable messages
* to the specified Amazon SQS dead-letter queue. Messages that can't be
* delivered due to client errors (for example, when the subscribed endpoint
* is unreachable) or server errors (for example, when the service that
* powers the subscribed endpoint becomes unavailable) are held in the
* dead-letter queue for further analysis or reprocessing.
*
* The following attribute applies only to Amazon Kinesis Data Firehose * delivery stream subscriptions: *
*
* SubscriptionRoleArn
– The ARN of the IAM role that has the
* following:
*
* Permission to write to the Kinesis Data Firehose delivery stream *
** Amazon SNS listed as a trusted entity *
** Specifying a valid ARN for this attribute is required for Kinesis Data * Firehose delivery stream subscriptions. For more information, see Fanout to Kinesis Data Firehose delivery streams in the Amazon * SNS Developer Guide. *
*
* The method adds a new key-value pair into Attributes parameter, and
* returns a reference to this object so that method calls can be chained
* together.
*
* @param key The key of the entry to be added into Attributes.
* @param value The corresponding value of the entry to be added into
* Attributes.
* @return A reference to this updated object so that method calls can be
* chained together.
*/
public SubscribeRequest addAttributesEntry(String key, String value) {
if (null == this.attributes) {
this.attributes = new java.util.HashMap
* Returns a reference to this object so that method calls can be chained
* together.
*/
public SubscribeRequest clearAttributesEntries() {
this.attributes = null;
return this;
}
/**
*
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Sets whether the response from the
* If you set this parameter to
* The default value is
* Returns a reference to this object so that method calls can be chained
* together.
*
* @param returnSubscriptionArn
* Sets whether the response from the
* If you set this parameter to
* The default value is Subscribe
request
* includes the subscription ARN, even if the subscription is not yet
* confirmed.
* true
, the response includes the
* ARN in all cases, even if the subscription is not yet confirmed. In
* addition to the ARN for confirmed subscriptions, the response also
* includes the pending subscription
ARN value for
* subscriptions that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
request
* includes the subscription ARN, even if the subscription is not
* yet confirmed.
* true
, the response
* includes the ARN in all cases, even if the subscription is not
* yet confirmed. In addition to the ARN for confirmed
* subscriptions, the response also includes the
* pending subscription
ARN value for subscriptions
* that aren't yet confirmed. A subscription becomes confirmed when
* the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
request
* includes the subscription ARN, even if the subscription is not yet
* confirmed.
* true
, the response includes the
* ARN in all cases, even if the subscription is not yet confirmed. In
* addition to the ARN for confirmed subscriptions, the response also
* includes the pending subscription
ARN value for
* subscriptions that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
request
* includes the subscription ARN, even if the subscription is not
* yet confirmed.
* true
, the response
* includes the ARN in all cases, even if the subscription is not
* yet confirmed. In addition to the ARN for confirmed
* subscriptions, the response also includes the
* pending subscription
ARN value for subscriptions
* that aren't yet confirmed. A subscription becomes confirmed when
* the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
request
* includes the subscription ARN, even if the subscription is not yet
* confirmed.
* true
, the response includes the
* ARN in all cases, even if the subscription is not yet confirmed. In
* addition to the ARN for confirmed subscriptions, the response also
* includes the pending subscription
ARN value for
* subscriptions that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
* request includes the subscription ARN, even if the
* subscription is not yet confirmed.
* true
, the response
* includes the ARN in all cases, even if the subscription is not
* yet confirmed. In addition to the ARN for confirmed
* subscriptions, the response also includes the
* pending subscription
ARN value for subscriptions
* that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
* action with a confirmation token.
* false
.
* Subscribe
request
* includes the subscription ARN, even if the subscription is not yet
* confirmed.
* true
, the response includes the
* ARN in all cases, even if the subscription is not yet confirmed. In
* addition to the ARN for confirmed subscriptions, the response also
* includes the pending subscription
ARN value for
* subscriptions that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
action
* with a confirmation token.
* false
.
* Subscribe
* request includes the subscription ARN, even if the
* subscription is not yet confirmed.
* true
, the response
* includes the ARN in all cases, even if the subscription is not
* yet confirmed. In addition to the ARN for confirmed
* subscriptions, the response also includes the
* pending subscription
ARN value for subscriptions
* that aren't yet confirmed. A subscription becomes confirmed
* when the subscriber calls the ConfirmSubscription
* action with a confirmation token.
* false
.
*