1 | ;
|
2 | var _a;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.Queue = exports.FifoThroughputLimit = exports.DeduplicationScope = exports.QueueEncryption = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const kms = require("@aws-cdk/aws-kms");
|
8 | const core_1 = require("@aws-cdk/core");
|
9 | const queue_base_1 = require("./queue-base");
|
10 | const sqs_generated_1 = require("./sqs.generated");
|
11 | const validate_props_1 = require("./validate-props");
|
12 | /**
|
13 | * What kind of encryption to apply to this queue
|
14 | */
|
15 | var QueueEncryption;
|
16 | (function (QueueEncryption) {
|
17 | /**
|
18 | * Messages in the queue are not encrypted
|
19 | */
|
20 | QueueEncryption["UNENCRYPTED"] = "NONE";
|
21 | /**
|
22 | * Server-side KMS encryption with a master key managed by SQS.
|
23 | */
|
24 | QueueEncryption["KMS_MANAGED"] = "MANAGED";
|
25 | /**
|
26 | * Server-side encryption with a KMS key managed by the user.
|
27 | *
|
28 | * If `encryptionKey` is specified, this key will be used, otherwise, one will be defined.
|
29 | */
|
30 | QueueEncryption["KMS"] = "KMS";
|
31 | })(QueueEncryption = exports.QueueEncryption || (exports.QueueEncryption = {}));
|
32 | /**
|
33 | * What kind of deduplication scope to apply
|
34 | */
|
35 | var DeduplicationScope;
|
36 | (function (DeduplicationScope) {
|
37 | /**
|
38 | * Deduplication occurs at the message group level
|
39 | */
|
40 | DeduplicationScope["MESSAGE_GROUP"] = "messageGroup";
|
41 | /**
|
42 | * Deduplication occurs at the message queue level
|
43 | */
|
44 | DeduplicationScope["QUEUE"] = "queue";
|
45 | })(DeduplicationScope = exports.DeduplicationScope || (exports.DeduplicationScope = {}));
|
46 | /**
|
47 | * Whether the FIFO queue throughput quota applies to the entire queue or per message group
|
48 | */
|
49 | var FifoThroughputLimit;
|
50 | (function (FifoThroughputLimit) {
|
51 | /**
|
52 | * Throughput quota applies per queue
|
53 | */
|
54 | FifoThroughputLimit["PER_QUEUE"] = "perQueue";
|
55 | /**
|
56 | * Throughput quota applies per message group id
|
57 | */
|
58 | FifoThroughputLimit["PER_MESSAGE_GROUP_ID"] = "perMessageGroupId";
|
59 | })(FifoThroughputLimit = exports.FifoThroughputLimit || (exports.FifoThroughputLimit = {}));
|
60 | /**
|
61 | * A new Amazon SQS queue
|
62 | */
|
63 | class Queue extends queue_base_1.QueueBase {
|
64 | constructor(scope, id, props = {}) {
|
65 | super(scope, id, {
|
66 | physicalName: props.queueName,
|
67 | });
|
68 | this.autoCreatePolicy = true;
|
69 | try {
|
70 | jsiiDeprecationWarnings._aws_cdk_aws_sqs_QueueProps(props);
|
71 | }
|
72 | catch (error) {
|
73 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
74 | Error.captureStackTrace(error, Queue);
|
75 | }
|
76 | throw error;
|
77 | }
|
78 | validate_props_1.validateProps(props);
|
79 | const redrivePolicy = props.deadLetterQueue
|
80 | ? {
|
81 | deadLetterTargetArn: props.deadLetterQueue.queue.queueArn,
|
82 | maxReceiveCount: props.deadLetterQueue.maxReceiveCount,
|
83 | }
|
84 | : undefined;
|
85 | const { encryptionMasterKey, encryptionProps } = _determineEncryptionProps.call(this);
|
86 | const fifoProps = this.determineFifoProps(props);
|
87 | this.fifo = fifoProps.fifoQueue || false;
|
88 | const queue = new sqs_generated_1.CfnQueue(this, 'Resource', {
|
89 | queueName: this.physicalName,
|
90 | ...fifoProps,
|
91 | ...encryptionProps,
|
92 | redrivePolicy,
|
93 | delaySeconds: props.deliveryDelay && props.deliveryDelay.toSeconds(),
|
94 | maximumMessageSize: props.maxMessageSizeBytes,
|
95 | messageRetentionPeriod: props.retentionPeriod && props.retentionPeriod.toSeconds(),
|
96 | receiveMessageWaitTimeSeconds: props.receiveMessageWaitTime && props.receiveMessageWaitTime.toSeconds(),
|
97 | visibilityTimeout: props.visibilityTimeout && props.visibilityTimeout.toSeconds(),
|
98 | });
|
99 | queue.applyRemovalPolicy(props.removalPolicy ?? core_1.RemovalPolicy.DESTROY);
|
100 | this.queueArn = this.getResourceArnAttribute(queue.attrArn, {
|
101 | service: 'sqs',
|
102 | resource: this.physicalName,
|
103 | });
|
104 | this.queueName = this.getResourceNameAttribute(queue.attrQueueName);
|
105 | this.encryptionMasterKey = encryptionMasterKey;
|
106 | this.queueUrl = queue.ref;
|
107 | this.deadLetterQueue = props.deadLetterQueue;
|
108 | function _determineEncryptionProps() {
|
109 | let encryption = props.encryption || QueueEncryption.UNENCRYPTED;
|
110 | if (encryption !== QueueEncryption.KMS && props.encryptionMasterKey) {
|
111 | encryption = QueueEncryption.KMS; // KMS is implied by specifying an encryption key
|
112 | }
|
113 | if (encryption === QueueEncryption.UNENCRYPTED) {
|
114 | return { encryptionProps: {} };
|
115 | }
|
116 | if (encryption === QueueEncryption.KMS_MANAGED) {
|
117 | return {
|
118 | encryptionProps: {
|
119 | kmsMasterKeyId: 'alias/aws/sqs',
|
120 | kmsDataKeyReusePeriodSeconds: props.dataKeyReuse && props.dataKeyReuse.toSeconds(),
|
121 | },
|
122 | };
|
123 | }
|
124 | if (encryption === QueueEncryption.KMS) {
|
125 | const masterKey = props.encryptionMasterKey || new kms.Key(this, 'Key', {
|
126 | description: `Created by ${this.node.path}`,
|
127 | });
|
128 | return {
|
129 | encryptionMasterKey: masterKey,
|
130 | encryptionProps: {
|
131 | kmsMasterKeyId: masterKey.keyArn,
|
132 | kmsDataKeyReusePeriodSeconds: props.dataKeyReuse && props.dataKeyReuse.toSeconds(),
|
133 | },
|
134 | };
|
135 | }
|
136 | throw new Error(`Unexpected 'encryptionType': ${encryption}`);
|
137 | }
|
138 | }
|
139 | /**
|
140 | * Import an existing SQS queue provided an ARN
|
141 | *
|
142 | * @param scope The parent creating construct
|
143 | * @param id The construct's name
|
144 | * @param queueArn queue ARN (i.e. arn:aws:sqs:us-east-2:444455556666:queue1)
|
145 | */
|
146 | static fromQueueArn(scope, id, queueArn) {
|
147 | return Queue.fromQueueAttributes(scope, id, { queueArn });
|
148 | }
|
149 | /**
|
150 | * Import an existing queue
|
151 | */
|
152 | static fromQueueAttributes(scope, id, attrs) {
|
153 | try {
|
154 | jsiiDeprecationWarnings._aws_cdk_aws_sqs_QueueAttributes(attrs);
|
155 | }
|
156 | catch (error) {
|
157 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
158 | Error.captureStackTrace(error, this.fromQueueAttributes);
|
159 | }
|
160 | throw error;
|
161 | }
|
162 | const stack = core_1.Stack.of(scope);
|
163 | const parsedArn = stack.splitArn(attrs.queueArn, core_1.ArnFormat.NO_RESOURCE_NAME);
|
164 | const queueName = attrs.queueName || parsedArn.resource;
|
165 | const queueUrl = attrs.queueUrl || `https://sqs.${parsedArn.region}.${stack.urlSuffix}/${parsedArn.account}/${queueName}`;
|
166 | class Import extends queue_base_1.QueueBase {
|
167 | constructor() {
|
168 | super(...arguments);
|
169 | this.queueArn = attrs.queueArn; // arn:aws:sqs:us-east-1:123456789012:queue1
|
170 | this.queueUrl = queueUrl;
|
171 | this.queueName = queueName;
|
172 | this.encryptionMasterKey = attrs.keyArn
|
173 | ? kms.Key.fromKeyArn(this, 'Key', attrs.keyArn)
|
174 | : undefined;
|
175 | this.fifo = this.determineFifo();
|
176 | this.autoCreatePolicy = false;
|
177 | }
|
178 | /**
|
179 | * Determine fifo flag based on queueName and fifo attribute
|
180 | */
|
181 | determineFifo() {
|
182 | if (core_1.Token.isUnresolved(this.queueArn)) {
|
183 | return attrs.fifo || false;
|
184 | }
|
185 | else {
|
186 | if (typeof attrs.fifo !== 'undefined') {
|
187 | if (attrs.fifo && !queueName.endsWith('.fifo')) {
|
188 | throw new Error("FIFO queue names must end in '.fifo'");
|
189 | }
|
190 | if (!attrs.fifo && queueName.endsWith('.fifo')) {
|
191 | throw new Error("Non-FIFO queue name may not end in '.fifo'");
|
192 | }
|
193 | }
|
194 | return queueName.endsWith('.fifo') ? true : false;
|
195 | }
|
196 | }
|
197 | }
|
198 | return new Import(scope, id);
|
199 | }
|
200 | /**
|
201 | * Look at the props, see if the FIFO props agree, and return the correct subset of props
|
202 | */
|
203 | determineFifoProps(props) {
|
204 | // Check if any of the signals that we have say that this is a FIFO queue.
|
205 | let fifoQueue = props.fifo;
|
206 | const queueName = props.queueName;
|
207 | if (typeof fifoQueue === 'undefined' && queueName && !core_1.Token.isUnresolved(queueName) && queueName.endsWith('.fifo')) {
|
208 | fifoQueue = true;
|
209 | }
|
210 | if (typeof fifoQueue === 'undefined' && props.contentBasedDeduplication) {
|
211 | fifoQueue = true;
|
212 | }
|
213 | if (typeof fifoQueue === 'undefined' && props.deduplicationScope) {
|
214 | fifoQueue = true;
|
215 | }
|
216 | if (typeof fifoQueue === 'undefined' && props.fifoThroughputLimit) {
|
217 | fifoQueue = true;
|
218 | }
|
219 | // If we have a name, see that it agrees with the FIFO setting
|
220 | if (typeof queueName === 'string') {
|
221 | if (fifoQueue && !queueName.endsWith('.fifo')) {
|
222 | throw new Error("FIFO queue names must end in '.fifo'");
|
223 | }
|
224 | if (!fifoQueue && queueName.endsWith('.fifo')) {
|
225 | throw new Error("Non-FIFO queue name may not end in '.fifo'");
|
226 | }
|
227 | }
|
228 | if (props.contentBasedDeduplication && !fifoQueue) {
|
229 | throw new Error('Content-based deduplication can only be defined for FIFO queues');
|
230 | }
|
231 | if (props.deduplicationScope && !fifoQueue) {
|
232 | throw new Error('Deduplication scope can only be defined for FIFO queues');
|
233 | }
|
234 | if (props.fifoThroughputLimit && !fifoQueue) {
|
235 | throw new Error('FIFO throughput limit can only be defined for FIFO queues');
|
236 | }
|
237 | return {
|
238 | contentBasedDeduplication: props.contentBasedDeduplication,
|
239 | deduplicationScope: props.deduplicationScope,
|
240 | fifoThroughputLimit: props.fifoThroughputLimit,
|
241 | fifoQueue,
|
242 | };
|
243 | }
|
244 | }
|
245 | exports.Queue = Queue;
|
246 | _a = JSII_RTTI_SYMBOL_1;
|
247 | Queue[_a] = { fqn: "@aws-cdk/aws-sqs.Queue", version: "1.204.0" };
|
248 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue.js","sourceRoot":"","sources":["queue.ts"],"names":[],"mappings":"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","sourcesContent":["import * as kms from '@aws-cdk/aws-kms';\nimport { Duration, RemovalPolicy, Stack, Token, ArnFormat } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { IQueue, QueueAttributes, QueueBase } from './queue-base';\nimport { CfnQueue } from './sqs.generated';\nimport { validateProps } from './validate-props';\n\n/**\n * Properties for creating a new Queue\n */\nexport interface QueueProps {\n  /**\n   * A name for the queue.\n   *\n   * If specified and this is a FIFO queue, must end in the string '.fifo'.\n   *\n   * @default CloudFormation-generated name\n   */\n  readonly queueName?: string;\n\n  /**\n   * The number of seconds that Amazon SQS retains a message.\n   *\n   * You can specify an integer value from 60 seconds (1 minute) to 1209600\n   * seconds (14 days). The default value is 345600 seconds (4 days).\n   *\n   * @default Duration.days(4)\n   */\n  readonly retentionPeriod?: Duration;\n\n  /**\n   * The time in seconds that the delivery of all messages in the queue is delayed.\n   *\n   * You can specify an integer value of 0 to 900 (15 minutes). The default\n   * value is 0.\n   *\n   * @default 0\n   */\n  readonly deliveryDelay?: Duration;\n\n  /**\n   * The limit of how many bytes that a message can contain before Amazon SQS rejects it.\n   *\n   * You can specify an integer value from 1024 bytes (1 KiB) to 262144 bytes\n   * (256 KiB). The default value is 262144 (256 KiB).\n   *\n   * @default 256KiB\n   */\n  readonly maxMessageSizeBytes?: number;\n\n  /**\n   * Default wait time for ReceiveMessage calls.\n   *\n   * Does not wait if set to 0, otherwise waits this amount of seconds\n   * by default for messages to arrive.\n   *\n   * For more information, see Amazon SQS Long Poll.\n   *\n   *  @default 0\n   */\n  readonly receiveMessageWaitTime?: Duration;\n\n  /**\n   * Timeout of processing a single message.\n   *\n   * After dequeuing, the processor has this much time to handle the message\n   * and delete it from the queue before it becomes visible again for dequeueing\n   * by another processor.\n   *\n   * Values must be from 0 to 43200 seconds (12 hours). If you don't specify\n   * a value, AWS CloudFormation uses the default value of 30 seconds.\n   *\n   * @default Duration.seconds(30)\n   */\n  readonly visibilityTimeout?: Duration;\n\n  /**\n   * Send messages to this queue if they were unsuccessfully dequeued a number of times.\n   *\n   * @default no dead-letter queue\n   */\n  readonly deadLetterQueue?: DeadLetterQueue;\n\n  /**\n   * Whether the contents of the queue are encrypted, and by what type of key.\n   *\n   * Be aware that encryption is not available in all regions, please see the docs\n   * for current availability details.\n   *\n   * @default Unencrypted\n   */\n  readonly encryption?: QueueEncryption;\n\n  /**\n   * External KMS master key to use for queue encryption.\n   *\n   * Individual messages will be encrypted using data keys. The data keys in\n   * turn will be encrypted using this key, and reused for a maximum of\n   * `dataKeyReuseSecs` seconds.\n   *\n   * If the 'encryptionMasterKey' property is set, 'encryption' type will be\n   * implicitly set to \"KMS\".\n   *\n   * @default If encryption is set to KMS and not specified, a key will be created.\n   */\n  readonly encryptionMasterKey?: kms.IKey;\n\n  /**\n   * The length of time that Amazon SQS reuses a data key before calling KMS again.\n   *\n   * The value must be an integer between 60 (1 minute) and 86,400 (24\n   * hours). The default is 300 (5 minutes).\n   *\n   * @default Duration.minutes(5)\n   */\n  readonly dataKeyReuse?: Duration;\n\n  /**\n   * Whether this a first-in-first-out (FIFO) queue.\n   *\n   * @default false, unless queueName ends in '.fifo' or 'contentBasedDeduplication' is true.\n   */\n  readonly fifo?: boolean;\n\n  /**\n   * Specifies whether to enable content-based deduplication.\n   *\n   * During the deduplication interval (5 minutes), Amazon SQS treats\n   * messages that are sent with identical content (excluding attributes) as\n   * duplicates and delivers only one copy of the message.\n   *\n   * If you don't enable content-based deduplication and you want to deduplicate\n   * messages, provide an explicit deduplication ID in your SendMessage() call.\n   *\n   * (Only applies to FIFO queues.)\n   *\n   * @default false\n   */\n  readonly contentBasedDeduplication?: boolean;\n\n  /**\n   * For high throughput for FIFO queues, specifies whether message deduplication\n   * occurs at the message group or queue level.\n   *\n   * (Only applies to FIFO queues.)\n   *\n   * @default DeduplicationScope.QUEUE\n   */\n  readonly deduplicationScope?: DeduplicationScope;\n\n  /**\n   * For high throughput for FIFO queues, specifies whether the FIFO queue\n   * throughput quota applies to the entire queue or per message group.\n   *\n   * (Only applies to FIFO queues.)\n   *\n   * @default FifoThroughputLimit.PER_QUEUE\n   */\n  readonly fifoThroughputLimit?: FifoThroughputLimit;\n\n  /**\n   * Policy to apply when the queue is removed from the stack\n   *\n   * Even though queues are technically stateful, their contents are transient and it\n   * is common to add and remove Queues while rearchitecting your application. The\n   * default is therefore `DESTROY`. Change it to `RETAIN` if the messages are so\n   * valuable that accidentally losing them would be unacceptable.\n   *\n   * @default RemovalPolicy.DESTROY\n   */\n  readonly removalPolicy?: RemovalPolicy;\n}\n\n/**\n * Dead letter queue settings\n */\nexport interface DeadLetterQueue {\n  /**\n   * The dead-letter queue to which Amazon SQS moves messages after the value of maxReceiveCount is exceeded.\n   */\n  readonly queue: IQueue;\n\n  /**\n   * The number of times a message can be unsuccesfully dequeued before being moved to the dead-letter queue.\n   */\n  readonly maxReceiveCount: number;\n}\n\n/**\n * What kind of encryption to apply to this queue\n */\nexport enum QueueEncryption {\n  /**\n   * Messages in the queue are not encrypted\n   */\n  UNENCRYPTED = 'NONE',\n\n  /**\n   * Server-side KMS encryption with a master key managed by SQS.\n   */\n  KMS_MANAGED = 'MANAGED',\n\n  /**\n   * Server-side encryption with a KMS key managed by the user.\n   *\n   * If `encryptionKey` is specified, this key will be used, otherwise, one will be defined.\n   */\n  KMS = 'KMS',\n}\n\n/**\n * What kind of deduplication scope to apply\n */\nexport enum DeduplicationScope {\n  /**\n   * Deduplication occurs at the message group level\n   */\n  MESSAGE_GROUP = 'messageGroup',\n  /**\n   * Deduplication occurs at the message queue level\n   */\n  QUEUE = 'queue',\n}\n\n/**\n * Whether the FIFO queue throughput quota applies to the entire queue or per message group\n */\nexport enum FifoThroughputLimit {\n  /**\n   * Throughput quota applies per queue\n   */\n  PER_QUEUE = 'perQueue',\n  /**\n   * Throughput quota applies per message group id\n   */\n  PER_MESSAGE_GROUP_ID = 'perMessageGroupId',\n}\n\n/**\n * A new Amazon SQS queue\n */\nexport class Queue extends QueueBase {\n\n  /**\n   * Import an existing SQS queue provided an ARN\n   *\n   * @param scope The parent creating construct\n   * @param id The construct's name\n   * @param queueArn queue ARN (i.e. arn:aws:sqs:us-east-2:444455556666:queue1)\n   */\n  public static fromQueueArn(scope: Construct, id: string, queueArn: string): IQueue {\n    return Queue.fromQueueAttributes(scope, id, { queueArn });\n  }\n\n  /**\n   * Import an existing queue\n   */\n  public static fromQueueAttributes(scope: Construct, id: string, attrs: QueueAttributes): IQueue {\n    const stack = Stack.of(scope);\n    const parsedArn = stack.splitArn(attrs.queueArn, ArnFormat.NO_RESOURCE_NAME);\n    const queueName = attrs.queueName || parsedArn.resource;\n    const queueUrl = attrs.queueUrl || `https://sqs.${parsedArn.region}.${stack.urlSuffix}/${parsedArn.account}/${queueName}`;\n\n    class Import extends QueueBase {\n      public readonly queueArn = attrs.queueArn; // arn:aws:sqs:us-east-1:123456789012:queue1\n      public readonly queueUrl = queueUrl;\n      public readonly queueName = queueName;\n      public readonly encryptionMasterKey = attrs.keyArn\n        ? kms.Key.fromKeyArn(this, 'Key', attrs.keyArn)\n        : undefined;\n      public readonly fifo: boolean = this.determineFifo();\n\n      protected readonly autoCreatePolicy = false;\n\n      /**\n       * Determine fifo flag based on queueName and fifo attribute\n       */\n      private determineFifo(): boolean {\n        if (Token.isUnresolved(this.queueArn)) {\n          return attrs.fifo || false;\n        } else {\n          if (typeof attrs.fifo !== 'undefined') {\n            if (attrs.fifo && !queueName.endsWith('.fifo')) {\n              throw new Error(\"FIFO queue names must end in '.fifo'\");\n            }\n            if (!attrs.fifo && queueName.endsWith('.fifo')) {\n              throw new Error(\"Non-FIFO queue name may not end in '.fifo'\");\n            }\n          }\n          return queueName.endsWith('.fifo') ? true : false;\n        }\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n  /**\n   * The ARN of this queue\n   */\n  public readonly queueArn: string;\n\n  /**\n   * The name of this queue\n   */\n  public readonly queueName: string;\n\n  /**\n   * The URL of this queue\n   */\n  public readonly queueUrl: string;\n\n  /**\n   * If this queue is encrypted, this is the KMS key.\n   */\n  public readonly encryptionMasterKey?: kms.IKey;\n\n  /**\n   * Whether this queue is an Amazon SQS FIFO queue. If false, this is a standard queue.\n   */\n  public readonly fifo: boolean;\n\n  /**\n   * If this queue is configured with a dead-letter queue, this is the dead-letter queue settings.\n   */\n  public readonly deadLetterQueue?: DeadLetterQueue;\n\n  protected readonly autoCreatePolicy = true;\n\n  constructor(scope: Construct, id: string, props: QueueProps = {}) {\n    super(scope, id, {\n      physicalName: props.queueName,\n    });\n\n    validateProps(props);\n\n    const redrivePolicy = props.deadLetterQueue\n      ? {\n        deadLetterTargetArn: props.deadLetterQueue.queue.queueArn,\n        maxReceiveCount: props.deadLetterQueue.maxReceiveCount,\n      }\n      : undefined;\n\n    const { encryptionMasterKey, encryptionProps } = _determineEncryptionProps.call(this);\n\n    const fifoProps = this.determineFifoProps(props);\n    this.fifo = fifoProps.fifoQueue || false;\n\n    const queue = new CfnQueue(this, 'Resource', {\n      queueName: this.physicalName,\n      ...fifoProps,\n      ...encryptionProps,\n      redrivePolicy,\n      delaySeconds: props.deliveryDelay && props.deliveryDelay.toSeconds(),\n      maximumMessageSize: props.maxMessageSizeBytes,\n      messageRetentionPeriod: props.retentionPeriod && props.retentionPeriod.toSeconds(),\n      receiveMessageWaitTimeSeconds: props.receiveMessageWaitTime && props.receiveMessageWaitTime.toSeconds(),\n      visibilityTimeout: props.visibilityTimeout && props.visibilityTimeout.toSeconds(),\n    });\n    queue.applyRemovalPolicy(props.removalPolicy ?? RemovalPolicy.DESTROY);\n\n    this.queueArn = this.getResourceArnAttribute(queue.attrArn, {\n      service: 'sqs',\n      resource: this.physicalName,\n    });\n    this.queueName = this.getResourceNameAttribute(queue.attrQueueName);\n    this.encryptionMasterKey = encryptionMasterKey;\n    this.queueUrl = queue.ref;\n    this.deadLetterQueue = props.deadLetterQueue;\n\n    function _determineEncryptionProps(this: Queue): { encryptionProps: EncryptionProps, encryptionMasterKey?: kms.IKey } {\n      let encryption = props.encryption || QueueEncryption.UNENCRYPTED;\n\n      if (encryption !== QueueEncryption.KMS && props.encryptionMasterKey) {\n        encryption = QueueEncryption.KMS; // KMS is implied by specifying an encryption key\n      }\n\n      if (encryption === QueueEncryption.UNENCRYPTED) {\n        return { encryptionProps: {} };\n      }\n\n      if (encryption === QueueEncryption.KMS_MANAGED) {\n        return {\n          encryptionProps: {\n            kmsMasterKeyId: 'alias/aws/sqs',\n            kmsDataKeyReusePeriodSeconds: props.dataKeyReuse && props.dataKeyReuse.toSeconds(),\n          },\n        };\n      }\n\n      if (encryption === QueueEncryption.KMS) {\n        const masterKey = props.encryptionMasterKey || new kms.Key(this, 'Key', {\n          description: `Created by ${this.node.path}`,\n        });\n\n        return {\n          encryptionMasterKey: masterKey,\n          encryptionProps: {\n            kmsMasterKeyId: masterKey.keyArn,\n            kmsDataKeyReusePeriodSeconds: props.dataKeyReuse && props.dataKeyReuse.toSeconds(),\n          },\n        };\n      }\n\n      throw new Error(`Unexpected 'encryptionType': ${encryption}`);\n    }\n  }\n\n  /**\n   * Look at the props, see if the FIFO props agree, and return the correct subset of props\n   */\n  private determineFifoProps(props: QueueProps): FifoProps {\n    // Check if any of the signals that we have say that this is a FIFO queue.\n    let fifoQueue = props.fifo;\n    const queueName = props.queueName;\n    if (typeof fifoQueue === 'undefined' && queueName && !Token.isUnresolved(queueName) && queueName.endsWith('.fifo')) { fifoQueue = true; }\n    if (typeof fifoQueue === 'undefined' && props.contentBasedDeduplication) { fifoQueue = true; }\n    if (typeof fifoQueue === 'undefined' && props.deduplicationScope) { fifoQueue = true; }\n    if (typeof fifoQueue === 'undefined' && props.fifoThroughputLimit) { fifoQueue = true; }\n\n    // If we have a name, see that it agrees with the FIFO setting\n    if (typeof queueName === 'string') {\n      if (fifoQueue && !queueName.endsWith('.fifo')) {\n        throw new Error(\"FIFO queue names must end in '.fifo'\");\n      }\n      if (!fifoQueue && queueName.endsWith('.fifo')) {\n        throw new Error(\"Non-FIFO queue name may not end in '.fifo'\");\n      }\n    }\n\n    if (props.contentBasedDeduplication && !fifoQueue) {\n      throw new Error('Content-based deduplication can only be defined for FIFO queues');\n    }\n\n    if (props.deduplicationScope && !fifoQueue) {\n      throw new Error('Deduplication scope can only be defined for FIFO queues');\n    }\n\n    if (props.fifoThroughputLimit && !fifoQueue) {\n      throw new Error('FIFO throughput limit can only be defined for FIFO queues');\n    }\n\n    return {\n      contentBasedDeduplication: props.contentBasedDeduplication,\n      deduplicationScope: props.deduplicationScope,\n      fifoThroughputLimit: props.fifoThroughputLimit,\n      fifoQueue,\n    };\n  }\n}\n\ninterface FifoProps {\n  readonly fifoQueue?: boolean;\n  readonly contentBasedDeduplication?: boolean;\n  readonly deduplicationScope?: DeduplicationScope;\n  readonly fifoThroughputLimit?: FifoThroughputLimit;\n}\n\ninterface EncryptionProps {\n  readonly kmsMasterKeyId?: string;\n  readonly kmsDataKeyReusePeriodSeconds?: number;\n}\n"]} |
\ | No newline at end of file |