Copyright | (c) 2013-2023 Brendan Hay |
---|---|
License | Mozilla Public License, v. 2.0. |
Maintainer | Brendan Hay |
Stability | auto-generated |
Portability | non-portable (GHC extensions) |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
Publishes up to ten messages to the specified topic. This is a batch
version of Publish
. For FIFO topics, multiple messages within a single
batch are published in the order they are sent, and messages are
deduplicated within the batch and across batches for 5 minutes.
The result of publishing each message is reported individually in the
response. Because the batch request can result in a combination of
successful and unsuccessful actions, you should check for batch errors
even when the call returns an HTTP status code of 200
.
The maximum allowed individual message size and the maximum total payload size (the sum of the individual lengths of all of the batched messages) are both 256 KB (262,144 bytes).
Some actions take lists of parameters. These lists are specified using
the param.n
notation. Values of n
are integers starting from 1. For
example, a parameter list with two elements looks like this:
&AttributeName.1=first
&AttributeName.2=second
If you send a batch message to a topic, Amazon SNS publishes the batch message to each endpoint that is subscribed to the topic. The format of the batch message depends on the notification protocol for each subscribed endpoint.
When a messageId
is returned, the batch message is saved and Amazon
SNS immediately delivers the message to subscribers.
Synopsis
- data PublishBatch = PublishBatch' {}
- newPublishBatch :: Text -> PublishBatch
- publishBatch_topicArn :: Lens' PublishBatch Text
- publishBatch_publishBatchRequestEntries :: Lens' PublishBatch [PublishBatchRequestEntry]
- data PublishBatchResponse = PublishBatchResponse' {}
- newPublishBatchResponse :: Int -> PublishBatchResponse
- publishBatchResponse_failed :: Lens' PublishBatchResponse (Maybe [BatchResultErrorEntry])
- publishBatchResponse_successful :: Lens' PublishBatchResponse (Maybe [PublishBatchResultEntry])
- publishBatchResponse_httpStatus :: Lens' PublishBatchResponse Int
Creating a Request
data PublishBatch Source #
See: newPublishBatch
smart constructor.
PublishBatch' | |
|
Instances
Create a value of PublishBatch
with all optional fields omitted.
Use generic-lens or optics to modify other optional fields.
The following record fields are available, with the corresponding lenses provided for backwards compatibility:
PublishBatch
, publishBatch_topicArn
- The Amazon resource name (ARN) of the topic you want to batch publish
to.
$sel:publishBatchRequestEntries:PublishBatch'
, publishBatch_publishBatchRequestEntries
- A list of PublishBatch
request entries to be sent to the SNS topic.
Request Lenses
publishBatch_topicArn :: Lens' PublishBatch Text Source #
The Amazon resource name (ARN) of the topic you want to batch publish to.
publishBatch_publishBatchRequestEntries :: Lens' PublishBatch [PublishBatchRequestEntry] Source #
A list of PublishBatch
request entries to be sent to the SNS topic.
Destructuring the Response
data PublishBatchResponse Source #
See: newPublishBatchResponse
smart constructor.
PublishBatchResponse' | |
|
Instances
newPublishBatchResponse Source #
Create a value of PublishBatchResponse
with all optional fields omitted.
Use generic-lens or optics to modify other optional fields.
The following record fields are available, with the corresponding lenses provided for backwards compatibility:
$sel:failed:PublishBatchResponse'
, publishBatchResponse_failed
- A list of failed PublishBatch
responses.
$sel:successful:PublishBatchResponse'
, publishBatchResponse_successful
- A list of successful PublishBatch
responses.
$sel:httpStatus:PublishBatchResponse'
, publishBatchResponse_httpStatus
- The response's http status code.
Response Lenses
publishBatchResponse_failed :: Lens' PublishBatchResponse (Maybe [BatchResultErrorEntry]) Source #
A list of failed PublishBatch
responses.
publishBatchResponse_successful :: Lens' PublishBatchResponse (Maybe [PublishBatchResultEntry]) Source #
A list of successful PublishBatch
responses.
publishBatchResponse_httpStatus :: Lens' PublishBatchResponse Int Source #
The response's http status code.