UNPKG

16.5 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.QueueBase = void 0;
5const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6const iam = require("@aws-cdk/aws-iam");
7const core_1 = require("@aws-cdk/core");
8const policy_1 = require("./policy");
9/**
10 * Reference to a new or existing Amazon SQS queue
11 */
12class QueueBase extends core_1.Resource {
13 /**
14 * Adds a statement to the IAM resource policy associated with this queue.
15 *
16 * If this queue was created in this stack (`new Queue`), a queue policy
17 * will be automatically created upon the first call to `addToPolicy`. If
18 * the queue is imported (`Queue.import`), then this is a no-op.
19 */
20 addToResourcePolicy(statement) {
21 if (!this.policy && this.autoCreatePolicy) {
22 this.policy = new policy_1.QueuePolicy(this, 'Policy', { queues: [this] });
23 }
24 if (this.policy) {
25 this.policy.document.addStatements(statement);
26 return { statementAdded: true, policyDependable: this.policy };
27 }
28 return { statementAdded: false };
29 }
30 validate() {
31 const errors = super.validate();
32 errors.push(...this.policy?.document.validateForResourcePolicy() || []);
33 return errors;
34 }
35 /**
36 * Grant permissions to consume messages from a queue
37 *
38 * This will grant the following permissions:
39 *
40 * - sqs:ChangeMessageVisibility
41 * - sqs:DeleteMessage
42 * - sqs:ReceiveMessage
43 * - sqs:GetQueueAttributes
44 * - sqs:GetQueueUrl
45 *
46 * @param grantee Principal to grant consume rights to
47 */
48 grantConsumeMessages(grantee) {
49 const ret = this.grant(grantee, 'sqs:ReceiveMessage', 'sqs:ChangeMessageVisibility', 'sqs:GetQueueUrl', 'sqs:DeleteMessage', 'sqs:GetQueueAttributes');
50 if (this.encryptionMasterKey) {
51 this.encryptionMasterKey.grantDecrypt(grantee);
52 }
53 return ret;
54 }
55 /**
56 * Grant access to send messages to a queue to the given identity.
57 *
58 * This will grant the following permissions:
59 *
60 * - sqs:SendMessage
61 * - sqs:GetQueueAttributes
62 * - sqs:GetQueueUrl
63 *
64 * @param grantee Principal to grant send rights to
65 */
66 grantSendMessages(grantee) {
67 const ret = this.grant(grantee, 'sqs:SendMessage', 'sqs:GetQueueAttributes', 'sqs:GetQueueUrl');
68 if (this.encryptionMasterKey) {
69 // kms:Decrypt necessary to execute grantsendMessages to an SSE enabled SQS queue
70 this.encryptionMasterKey.grantEncryptDecrypt(grantee);
71 }
72 return ret;
73 }
74 /**
75 * Grant an IAM principal permissions to purge all messages from the queue.
76 *
77 * This will grant the following permissions:
78 *
79 * - sqs:PurgeQueue
80 * - sqs:GetQueueAttributes
81 * - sqs:GetQueueUrl
82 *
83 * @param grantee Principal to grant send rights to
84 */
85 grantPurge(grantee) {
86 return this.grant(grantee, 'sqs:PurgeQueue', 'sqs:GetQueueAttributes', 'sqs:GetQueueUrl');
87 }
88 /**
89 * Grant the actions defined in queueActions to the identity Principal given
90 * on this SQS queue resource.
91 *
92 * @param grantee Principal to grant right to
93 * @param actions The actions to grant
94 */
95 grant(grantee, ...actions) {
96 return iam.Grant.addToPrincipalOrResource({
97 grantee,
98 actions,
99 resourceArns: [this.queueArn],
100 resource: this,
101 });
102 }
103}
104exports.QueueBase = QueueBase;
105_a = JSII_RTTI_SYMBOL_1;
106QueueBase[_a] = { fqn: "@aws-cdk/aws-sqs.QueueBase", version: "1.204.0" };
107//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"queue-base.js","sourceRoot":"","sources":["queue-base.ts"],"names":[],"mappings":";;;;;AAAA,wCAAwC;AAExC,wCAAoD;AACpD,qCAAuC;AA8FvC;;GAEG;AACH,MAAsB,SAAU,SAAQ,eAAQ;IAoC9C;;;;;;OAMG;IACI,mBAAmB,CAAC,SAA8B;QACvD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzC,IAAI,CAAC,MAAM,GAAG,IAAI,oBAAW,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;SACnE;QAED,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;YAC9C,OAAO,EAAE,cAAc,EAAE,IAAI,EAAE,gBAAgB,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;SAChE;QAED,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,CAAC;KAClC;IAES,QAAQ;QAChB,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;QAChC,MAAM,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,QAAQ,CAAC,yBAAyB,EAAE,IAAI,EAAE,CAAC,CAAC;QACxE,OAAO,MAAM,CAAC;KACf;IAED;;;;;;;;;;;;OAYG;IACI,oBAAoB,CAAC,OAAuB;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAC5B,oBAAoB,EACpB,6BAA6B,EAC7B,iBAAiB,EACjB,mBAAmB,EACnB,wBAAwB,CAAC,CAAC;QAE5B,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;SAChD;QAED,OAAO,GAAG,CAAC;KACZ;IAED;;;;;;;;;;OAUG;IACI,iBAAiB,CAAC,OAAuB;QAC9C,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAC5B,iBAAiB,EACjB,wBAAwB,EACxB,iBAAiB,CAAC,CAAC;QAErB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,iFAAiF;YACjF,IAAI,CAAC,mBAAmB,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;SACvD;QACD,OAAO,GAAG,CAAC;KACZ;IAED;;;;;;;;;;OAUG;IACI,UAAU,CAAC,OAAuB;QACvC,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EACvB,gBAAgB,EAChB,wBAAwB,EACxB,iBAAiB,CAAC,CAAC;KACtB;IAED;;;;;;OAMG;IACI,KAAK,CAAC,OAAuB,EAAE,GAAG,OAAiB;QACxD,OAAO,GAAG,CAAC,KAAK,CAAC,wBAAwB,CAAC;YACxC,OAAO;YACP,OAAO;YACP,YAAY,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC7B,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC;KACJ;;AAlJH,8BAmJC","sourcesContent":["import * as iam from '@aws-cdk/aws-iam';\nimport * as kms from '@aws-cdk/aws-kms';\nimport { IResource, Resource } from '@aws-cdk/core';\nimport { QueuePolicy } from './policy';\n\n/**\n * Represents an SQS queue\n */\nexport interface IQueue extends IResource {\n  /**\n   * The ARN of this queue\n   * @attribute\n   */\n  readonly queueArn: string;\n\n  /**\n   * The URL of this queue\n   * @attribute\n   */\n  readonly queueUrl: string;\n\n  /**\n   * The name of this queue\n   * @attribute\n   */\n  readonly queueName: string;\n\n  /**\n   * If this queue is server-side encrypted, this is the KMS encryption key.\n   */\n  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  readonly fifo: boolean;\n\n  /**\n   * Adds a statement to the IAM resource policy associated with this queue.\n   *\n   * If this queue was created in this stack (`new Queue`), a queue policy\n   * will be automatically created upon the first call to `addToPolicy`. If\n   * the queue is imported (`Queue.import`), then this is a no-op.\n   */\n  addToResourcePolicy(statement: iam.PolicyStatement): iam.AddToResourcePolicyResult;\n\n  /**\n   * Grant permissions to consume messages from a queue\n   *\n   * This will grant the following permissions:\n   *\n   *   - sqs:ChangeMessageVisibility\n   *   - sqs:DeleteMessage\n   *   - sqs:ReceiveMessage\n   *   - sqs:GetQueueAttributes\n   *   - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant consume rights to\n   */\n  grantConsumeMessages(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Grant access to send messages to a queue to the given identity.\n   *\n   * This will grant the following permissions:\n   *\n   *  - sqs:SendMessage\n   *  - sqs:GetQueueAttributes\n   *  - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant send rights to\n   */\n  grantSendMessages(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Grant an IAM principal permissions to purge all messages from the queue.\n   *\n   * This will grant the following permissions:\n   *\n   *  - sqs:PurgeQueue\n   *  - sqs:GetQueueAttributes\n   *  - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant send rights to\n   */\n  grantPurge(grantee: iam.IGrantable): iam.Grant;\n\n  /**\n   * Grant the actions defined in queueActions to the identity Principal given\n   * on this SQS queue resource.\n   *\n   * @param grantee Principal to grant right to\n   * @param queueActions The actions to grant\n   */\n  grant(grantee: iam.IGrantable, ...queueActions: string[]): iam.Grant;\n}\n\n/**\n * Reference to a new or existing Amazon SQS queue\n */\nexport abstract class QueueBase extends Resource implements IQueue {\n\n  /**\n   * The ARN of this queue\n   */\n  public abstract readonly queueArn: string;\n\n  /**\n   * The URL of this queue\n   */\n  public abstract readonly queueUrl: string;\n\n  /**\n   * The name of this queue\n   */\n  public abstract readonly queueName: string;\n\n  /**\n   * If this queue is server-side encrypted, this is the KMS encryption key.\n   */\n  public abstract 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 abstract readonly fifo: boolean;\n\n  /**\n   * Controls automatic creation of policy objects.\n   *\n   * Set by subclasses.\n   */\n  protected abstract readonly autoCreatePolicy: boolean;\n\n  private policy?: QueuePolicy;\n\n  /**\n   * Adds a statement to the IAM resource policy associated with this queue.\n   *\n   * If this queue was created in this stack (`new Queue`), a queue policy\n   * will be automatically created upon the first call to `addToPolicy`. If\n   * the queue is imported (`Queue.import`), then this is a no-op.\n   */\n  public addToResourcePolicy(statement: iam.PolicyStatement): iam.AddToResourcePolicyResult {\n    if (!this.policy && this.autoCreatePolicy) {\n      this.policy = new QueuePolicy(this, 'Policy', { queues: [this] });\n    }\n\n    if (this.policy) {\n      this.policy.document.addStatements(statement);\n      return { statementAdded: true, policyDependable: this.policy };\n    }\n\n    return { statementAdded: false };\n  }\n\n  protected validate(): string[] {\n    const errors = super.validate();\n    errors.push(...this.policy?.document.validateForResourcePolicy() || []);\n    return errors;\n  }\n\n  /**\n   * Grant permissions to consume messages from a queue\n   *\n   * This will grant the following permissions:\n   *\n   *   - sqs:ChangeMessageVisibility\n   *   - sqs:DeleteMessage\n   *   - sqs:ReceiveMessage\n   *   - sqs:GetQueueAttributes\n   *   - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant consume rights to\n   */\n  public grantConsumeMessages(grantee: iam.IGrantable) {\n    const ret = this.grant(grantee,\n      'sqs:ReceiveMessage',\n      'sqs:ChangeMessageVisibility',\n      'sqs:GetQueueUrl',\n      'sqs:DeleteMessage',\n      'sqs:GetQueueAttributes');\n\n    if (this.encryptionMasterKey) {\n      this.encryptionMasterKey.grantDecrypt(grantee);\n    }\n\n    return ret;\n  }\n\n  /**\n   * Grant access to send messages to a queue to the given identity.\n   *\n   * This will grant the following permissions:\n   *\n   *  - sqs:SendMessage\n   *  - sqs:GetQueueAttributes\n   *  - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant send rights to\n   */\n  public grantSendMessages(grantee: iam.IGrantable) {\n    const ret = this.grant(grantee,\n      'sqs:SendMessage',\n      'sqs:GetQueueAttributes',\n      'sqs:GetQueueUrl');\n\n    if (this.encryptionMasterKey) {\n      // kms:Decrypt necessary to execute grantsendMessages to an SSE enabled SQS queue\n      this.encryptionMasterKey.grantEncryptDecrypt(grantee);\n    }\n    return ret;\n  }\n\n  /**\n   * Grant an IAM principal permissions to purge all messages from the queue.\n   *\n   * This will grant the following permissions:\n   *\n   *  - sqs:PurgeQueue\n   *  - sqs:GetQueueAttributes\n   *  - sqs:GetQueueUrl\n   *\n   * @param grantee Principal to grant send rights to\n   */\n  public grantPurge(grantee: iam.IGrantable) {\n    return this.grant(grantee,\n      'sqs:PurgeQueue',\n      'sqs:GetQueueAttributes',\n      'sqs:GetQueueUrl');\n  }\n\n  /**\n   * Grant the actions defined in queueActions to the identity Principal given\n   * on this SQS queue resource.\n   *\n   * @param grantee Principal to grant right to\n   * @param actions The actions to grant\n   */\n  public grant(grantee: iam.IGrantable, ...actions: string[]) {\n    return iam.Grant.addToPrincipalOrResource({\n      grantee,\n      actions,\n      resourceArns: [this.queueArn],\n      resource: this,\n    });\n  }\n}\n/**\n * Reference to a queue\n */\nexport interface QueueAttributes {\n  /**\n   * The ARN of the queue.\n   */\n  readonly queueArn: string;\n\n  /**\n   * The URL of the queue.\n   * @see https://docs.aws.amazon.com/sdk-for-net/v2/developer-guide/QueueURL.html\n   *\n   * @default - 'https://sqs.<region-endpoint>/<account-ID>/<queue-name>'\n   */\n  readonly queueUrl?: string;\n\n  /**\n   * The name of the queue.\n   * @default if queue name is not specified, the name will be derived from the queue ARN\n   */\n  readonly queueName?: string;\n\n  /**\n   * KMS encryption key, if this queue is server-side encrypted by a KMS key.\n   *\n   * @default - None\n   */\n  readonly keyArn?: string;\n\n  /**\n   * Whether this queue is an Amazon SQS FIFO queue. If false, this is a standard queue.\n   *\n   * In case of a FIFO queue which is imported from a token, this value has to be explicitly set to true.\n   *\n   * @default - if fifo is not specified, the property will be determined based on the queue name (not possible for FIFO queues imported from a token)\n   */\n  readonly fifo?: boolean;\n}\n"]}
\No newline at end of file