Class Queue.Builder
- All Implemented Interfaces:
software.amazon.jsii.Builder<Queue>
- Enclosing class:
- Queue
Queue
.-
Method Summary
Modifier and TypeMethodDescriptionbuild()
contentBasedDeduplication
(Boolean contentBasedDeduplication) Specifies whether to enable content-based deduplication.static Queue.Builder
dataKeyReuse
(Duration dataKeyReuse) The length of time that Amazon SQS reuses a data key before calling KMS again.deadLetterQueue
(DeadLetterQueue deadLetterQueue) Send messages to this queue if they were unsuccessfully dequeued a number of times.deduplicationScope
(DeduplicationScope deduplicationScope) For high throughput for FIFO queues, specifies whether message deduplication occurs at the message group or queue level.deliveryDelay
(Duration deliveryDelay) The time in seconds that the delivery of all messages in the queue is delayed.encryption
(QueueEncryption encryption) Whether the contents of the queue are encrypted, and by what type of key.encryptionMasterKey
(IKey encryptionMasterKey) External KMS master key to use for queue encryption.Whether this a first-in-first-out (FIFO) queue.fifoThroughputLimit
(FifoThroughputLimit fifoThroughputLimit) For high throughput for FIFO queues, specifies whether the FIFO queue throughput quota applies to the entire queue or per message group.maxMessageSizeBytes
(Number maxMessageSizeBytes) The limit of how many bytes that a message can contain before Amazon SQS rejects it.A name for the queue.receiveMessageWaitTime
(Duration receiveMessageWaitTime) Default wait time for ReceiveMessage calls.removalPolicy
(RemovalPolicy removalPolicy) Policy to apply when the queue is removed from the stack.retentionPeriod
(Duration retentionPeriod) The number of seconds that Amazon SQS retains a message.visibilityTimeout
(Duration visibilityTimeout) Timeout of processing a single message.
-
Method Details
-
create
@Stability(Stable) public static Queue.Builder create(software.constructs.Construct scope, String id) - Parameters:
scope
- This parameter is required.id
- This parameter is required.- Returns:
- a new instance of
Queue.Builder
.
-
contentBasedDeduplication
@Stability(Stable) public Queue.Builder contentBasedDeduplication(Boolean contentBasedDeduplication) Specifies whether to enable content-based deduplication.During the deduplication interval (5 minutes), Amazon SQS treats messages that are sent with identical content (excluding attributes) as duplicates and delivers only one copy of the message.
If you don't enable content-based deduplication and you want to deduplicate messages, provide an explicit deduplication ID in your SendMessage() call.
(Only applies to FIFO queues.)
Default: false
- Parameters:
contentBasedDeduplication
- Specifies whether to enable content-based deduplication. This parameter is required.- Returns:
this
-
dataKeyReuse
The length of time that Amazon SQS reuses a data key before calling KMS again.The value must be an integer between 60 (1 minute) and 86,400 (24 hours). The default is 300 (5 minutes).
Default: Duration.minutes(5)
- Parameters:
dataKeyReuse
- The length of time that Amazon SQS reuses a data key before calling KMS again. This parameter is required.- Returns:
this
-
deadLetterQueue
Send messages to this queue if they were unsuccessfully dequeued a number of times.Default: no dead-letter queue
- Parameters:
deadLetterQueue
- Send messages to this queue if they were unsuccessfully dequeued a number of times. This parameter is required.- Returns:
this
-
deduplicationScope
For high throughput for FIFO queues, specifies whether message deduplication occurs at the message group or queue level.(Only applies to FIFO queues.)
Default: DeduplicationScope.QUEUE
- Parameters:
deduplicationScope
- For high throughput for FIFO queues, specifies whether message deduplication occurs at the message group or queue level. This parameter is required.- Returns:
this
-
deliveryDelay
The time in seconds that the delivery of all messages in the queue is delayed.You can specify an integer value of 0 to 900 (15 minutes). The default value is 0.
Default: 0
- Parameters:
deliveryDelay
- The time in seconds that the delivery of all messages in the queue is delayed. This parameter is required.- Returns:
this
-
encryption
Whether the contents of the queue are encrypted, and by what type of key.Be aware that encryption is not available in all regions, please see the docs for current availability details.
Default: Unencrypted
- Parameters:
encryption
- Whether the contents of the queue are encrypted, and by what type of key. This parameter is required.- Returns:
this
-
encryptionMasterKey
External KMS master key to use for queue encryption.Individual messages will be encrypted using data keys. The data keys in turn will be encrypted using this key, and reused for a maximum of
dataKeyReuseSecs
seconds.If the 'encryptionMasterKey' property is set, 'encryption' type will be implicitly set to "KMS".
Default: If encryption is set to KMS and not specified, a key will be created.
- Parameters:
encryptionMasterKey
- External KMS master key to use for queue encryption. This parameter is required.- Returns:
this
-
fifo
Whether this a first-in-first-out (FIFO) queue.Default: false, unless queueName ends in '.fifo' or 'contentBasedDeduplication' is true.
- Parameters:
fifo
- Whether this a first-in-first-out (FIFO) queue. This parameter is required.- Returns:
this
-
fifoThroughputLimit
@Stability(Stable) public Queue.Builder fifoThroughputLimit(FifoThroughputLimit fifoThroughputLimit) For high throughput for FIFO queues, specifies whether the FIFO queue throughput quota applies to the entire queue or per message group.(Only applies to FIFO queues.)
Default: FifoThroughputLimit.PER_QUEUE
- Parameters:
fifoThroughputLimit
- For high throughput for FIFO queues, specifies whether the FIFO queue throughput quota applies to the entire queue or per message group. This parameter is required.- Returns:
this
-
maxMessageSizeBytes
The limit of how many bytes that a message can contain before Amazon SQS rejects it.You can specify an integer value from 1024 bytes (1 KiB) to 262144 bytes (256 KiB). The default value is 262144 (256 KiB).
Default: 256KiB
- Parameters:
maxMessageSizeBytes
- The limit of how many bytes that a message can contain before Amazon SQS rejects it. This parameter is required.- Returns:
this
-
queueName
A name for the queue.If specified and this is a FIFO queue, must end in the string '.fifo'.
Default: CloudFormation-generated name
- Parameters:
queueName
- A name for the queue. This parameter is required.- Returns:
this
-
receiveMessageWaitTime
Default wait time for ReceiveMessage calls.Does not wait if set to 0, otherwise waits this amount of seconds by default for messages to arrive.
For more information, see Amazon SQS Long Poll.
Default: 0
- Parameters:
receiveMessageWaitTime
- Default wait time for ReceiveMessage calls. This parameter is required.- Returns:
this
-
removalPolicy
Policy to apply when the queue is removed from the stack.Even though queues are technically stateful, their contents are transient and it is common to add and remove Queues while rearchitecting your application. The default is therefore
DESTROY
. Change it toRETAIN
if the messages are so valuable that accidentally losing them would be unacceptable.Default: RemovalPolicy.DESTROY
- Parameters:
removalPolicy
- Policy to apply when the queue is removed from the stack. This parameter is required.- Returns:
this
-
retentionPeriod
The number of seconds that Amazon SQS retains a message.You can specify an integer value from 60 seconds (1 minute) to 1209600 seconds (14 days). The default value is 345600 seconds (4 days).
Default: Duration.days(4)
- Parameters:
retentionPeriod
- The number of seconds that Amazon SQS retains a message. This parameter is required.- Returns:
this
-
visibilityTimeout
Timeout of processing a single message.After dequeuing, the processor has this much time to handle the message and delete it from the queue before it becomes visible again for dequeueing by another processor.
Values must be from 0 to 43200 seconds (12 hours). If you don't specify a value, AWS CloudFormation uses the default value of 30 seconds.
Default: Duration.seconds(30)
- Parameters:
visibilityTimeout
- Timeout of processing a single message. This parameter is required.- Returns:
this
-
build
-