UNPKG

16.7 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.SubscriptionProtocol = exports.Subscription = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const aws_iam_1 = require("@aws-cdk/aws-iam");
8const core_1 = require("@aws-cdk/core");
9const sns_generated_1 = require("./sns.generated");
10/**
11 * A new subscription.
12 *
13 * Prefer to use the `ITopic.addSubscription()` methods to create instances of
14 * this class.
15 */
16class Subscription extends core_1.Resource {
17 constructor(scope, id, props) {
18 super(scope, id);
19 try {
20 jsiiDeprecationWarnings._aws_cdk_aws_sns_SubscriptionProps(props);
21 }
22 catch (error) {
23 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
24 Error.captureStackTrace(error, Subscription);
25 }
26 throw error;
27 }
28 if (props.rawMessageDelivery &&
29 [
30 SubscriptionProtocol.HTTP,
31 SubscriptionProtocol.HTTPS,
32 SubscriptionProtocol.SQS,
33 SubscriptionProtocol.FIREHOSE,
34 ]
35 .indexOf(props.protocol) < 0) {
36 throw new Error('Raw message delivery can only be enabled for HTTP, HTTPS, SQS, and Firehose subscriptions.');
37 }
38 if (props.filterPolicy) {
39 if (Object.keys(props.filterPolicy).length > 5) {
40 throw new Error('A filter policy can have a maximum of 5 attribute names.');
41 }
42 this.filterPolicy = Object.entries(props.filterPolicy)
43 .reduce((acc, [k, v]) => ({ ...acc, [k]: v.conditions }), {});
44 let total = 1;
45 Object.values(this.filterPolicy).forEach(filter => { total *= filter.length; });
46 if (total > 100) {
47 throw new Error(`The total combination of values (${total}) must not exceed 100.`);
48 }
49 }
50 if (props.protocol === SubscriptionProtocol.FIREHOSE && !props.subscriptionRoleArn) {
51 throw new Error('Subscription role arn is required field for subscriptions with a firehose protocol.');
52 }
53 this.deadLetterQueue = this.buildDeadLetterQueue(props);
54 new sns_generated_1.CfnSubscription(this, 'Resource', {
55 endpoint: props.endpoint,
56 protocol: props.protocol,
57 topicArn: props.topic.topicArn,
58 rawMessageDelivery: props.rawMessageDelivery,
59 filterPolicy: this.filterPolicy,
60 region: props.region,
61 redrivePolicy: this.buildDeadLetterConfig(this.deadLetterQueue),
62 subscriptionRoleArn: props.subscriptionRoleArn,
63 });
64 }
65 buildDeadLetterQueue(props) {
66 if (!props.deadLetterQueue) {
67 return undefined;
68 }
69 const deadLetterQueue = props.deadLetterQueue;
70 deadLetterQueue.addToResourcePolicy(new aws_iam_1.PolicyStatement({
71 resources: [deadLetterQueue.queueArn],
72 actions: ['sqs:SendMessage'],
73 principals: [new aws_iam_1.ServicePrincipal('sns.amazonaws.com')],
74 conditions: {
75 ArnEquals: { 'aws:SourceArn': props.topic.topicArn },
76 },
77 }));
78 return deadLetterQueue;
79 }
80 buildDeadLetterConfig(deadLetterQueue) {
81 if (deadLetterQueue) {
82 return {
83 deadLetterTargetArn: deadLetterQueue.queueArn,
84 };
85 }
86 else {
87 return undefined;
88 }
89 }
90}
91exports.Subscription = Subscription;
92_a = JSII_RTTI_SYMBOL_1;
93Subscription[_a] = { fqn: "@aws-cdk/aws-sns.Subscription", version: "1.172.0" };
94/**
95 * The type of subscription, controlling the type of the endpoint parameter.
96 */
97var SubscriptionProtocol;
98(function (SubscriptionProtocol) {
99 /**
100 * JSON-encoded message is POSTED to an HTTP url.
101 */
102 SubscriptionProtocol["HTTP"] = "http";
103 /**
104 * JSON-encoded message is POSTed to an HTTPS url.
105 */
106 SubscriptionProtocol["HTTPS"] = "https";
107 /**
108 * Notifications are sent via email.
109 */
110 SubscriptionProtocol["EMAIL"] = "email";
111 /**
112 * Notifications are JSON-encoded and sent via mail.
113 */
114 SubscriptionProtocol["EMAIL_JSON"] = "email-json";
115 /**
116 * Notification is delivered by SMS
117 */
118 SubscriptionProtocol["SMS"] = "sms";
119 /**
120 * Notifications are enqueued into an SQS queue.
121 */
122 SubscriptionProtocol["SQS"] = "sqs";
123 /**
124 * JSON-encoded notifications are sent to a mobile app endpoint.
125 */
126 SubscriptionProtocol["APPLICATION"] = "application";
127 /**
128 * Notifications trigger a Lambda function.
129 */
130 SubscriptionProtocol["LAMBDA"] = "lambda";
131 /**
132 * Notifications put records into a firehose delivery stream.
133 */
134 SubscriptionProtocol["FIREHOSE"] = "firehose";
135})(SubscriptionProtocol = exports.SubscriptionProtocol || (exports.SubscriptionProtocol = {}));
136//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscription.js","sourceRoot":"","sources":["subscription.ts"],"names":[],"mappings":"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","sourcesContent":["import { PolicyStatement, ServicePrincipal } from '@aws-cdk/aws-iam';\nimport { IQueue } from '@aws-cdk/aws-sqs';\nimport { Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnSubscription } from './sns.generated';\nimport { SubscriptionFilter } from './subscription-filter';\nimport { ITopic } from './topic-base';\n\n/**\n * Options for creating a new subscription\n */\nexport interface SubscriptionOptions {\n  /**\n   * What type of subscription to add.\n   */\n  readonly protocol: SubscriptionProtocol;\n\n  /**\n   * The subscription endpoint.\n   *\n   * The meaning of this value depends on the value for 'protocol'.\n   */\n  readonly endpoint: string;\n\n  /**\n   * true if raw message delivery is enabled for the subscription. Raw messages are free of JSON formatting and can be\n   * sent to HTTP/S and Amazon SQS endpoints. For more information, see GetSubscriptionAttributes in the Amazon Simple\n   * Notification Service API Reference.\n   *\n   * @default false\n   */\n  readonly rawMessageDelivery?: boolean;\n\n  /**\n   * The filter policy.\n   *\n   * @default - all messages are delivered\n   */\n  readonly filterPolicy?: { [attribute: string]: SubscriptionFilter };\n\n  /**\n   * The region where the topic resides, in the case of cross-region subscriptions\n   * @link https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-sns-subscription.html#cfn-sns-subscription-region\n   * @default - the region where the CloudFormation stack is being deployed.\n   */\n  readonly region?: string;\n\n  /**\n   * Queue to be used as dead letter queue.\n   * If not passed no dead letter queue is enabled.\n   *\n   * @default - No dead letter queue enabled.\n   */\n  readonly deadLetterQueue?: IQueue;\n\n  /**\n   * Arn of role allowing access to firehose delivery stream.\n   * Required for a firehose subscription protocol.\n   * @default - No subscription role is provided\n   */\n  readonly subscriptionRoleArn?: string;\n}\n/**\n * Properties for creating a new subscription\n */\nexport interface SubscriptionProps extends SubscriptionOptions {\n  /**\n   * The topic to subscribe to.\n   */\n  readonly topic: ITopic;\n}\n\n/**\n * A new subscription.\n *\n * Prefer to use the `ITopic.addSubscription()` methods to create instances of\n * this class.\n */\nexport class Subscription extends Resource {\n\n  /**\n   * The DLQ associated with this subscription if present.\n   */\n  public readonly deadLetterQueue?: IQueue;\n\n  private readonly filterPolicy?: { [attribute: string]: any[] };\n\n  constructor(scope: Construct, id: string, props: SubscriptionProps) {\n    super(scope, id);\n\n    if (props.rawMessageDelivery &&\n      [\n        SubscriptionProtocol.HTTP,\n        SubscriptionProtocol.HTTPS,\n        SubscriptionProtocol.SQS,\n        SubscriptionProtocol.FIREHOSE,\n      ]\n        .indexOf(props.protocol) < 0) {\n      throw new Error('Raw message delivery can only be enabled for HTTP, HTTPS, SQS, and Firehose subscriptions.');\n    }\n\n    if (props.filterPolicy) {\n      if (Object.keys(props.filterPolicy).length > 5) {\n        throw new Error('A filter policy can have a maximum of 5 attribute names.');\n      }\n\n      this.filterPolicy = Object.entries(props.filterPolicy)\n        .reduce(\n          (acc, [k, v]) => ({ ...acc, [k]: v.conditions }),\n          {},\n        );\n\n      let total = 1;\n      Object.values(this.filterPolicy).forEach(filter => { total *= filter.length; });\n      if (total > 100) {\n        throw new Error(`The total combination of values (${total}) must not exceed 100.`);\n      }\n    }\n\n    if (props.protocol === SubscriptionProtocol.FIREHOSE && !props.subscriptionRoleArn) {\n      throw new Error('Subscription role arn is required field for subscriptions with a firehose protocol.');\n    }\n\n    this.deadLetterQueue = this.buildDeadLetterQueue(props);\n\n    new CfnSubscription(this, 'Resource', {\n      endpoint: props.endpoint,\n      protocol: props.protocol,\n      topicArn: props.topic.topicArn,\n      rawMessageDelivery: props.rawMessageDelivery,\n      filterPolicy: this.filterPolicy,\n      region: props.region,\n      redrivePolicy: this.buildDeadLetterConfig(this.deadLetterQueue),\n      subscriptionRoleArn: props.subscriptionRoleArn,\n    });\n\n  }\n\n  private buildDeadLetterQueue(props: SubscriptionProps) {\n    if (!props.deadLetterQueue) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue;\n\n    deadLetterQueue.addToResourcePolicy(new PolicyStatement({\n      resources: [deadLetterQueue.queueArn],\n      actions: ['sqs:SendMessage'],\n      principals: [new ServicePrincipal('sns.amazonaws.com')],\n      conditions: {\n        ArnEquals: { 'aws:SourceArn': props.topic.topicArn },\n      },\n    }));\n\n    return deadLetterQueue;\n  }\n\n  private buildDeadLetterConfig(deadLetterQueue?: IQueue) {\n    if (deadLetterQueue) {\n      return {\n        deadLetterTargetArn: deadLetterQueue.queueArn,\n      };\n    } else {\n      return undefined;\n    }\n  }\n}\n\n/**\n * The type of subscription, controlling the type of the endpoint parameter.\n */\nexport enum SubscriptionProtocol {\n  /**\n   * JSON-encoded message is POSTED to an HTTP url.\n   */\n  HTTP = 'http',\n\n  /**\n   * JSON-encoded message is POSTed to an HTTPS url.\n   */\n  HTTPS = 'https',\n\n  /**\n   * Notifications are sent via email.\n   */\n  EMAIL = 'email',\n\n  /**\n   * Notifications are JSON-encoded and sent via mail.\n   */\n  EMAIL_JSON = 'email-json',\n\n  /**\n   * Notification is delivered by SMS\n   */\n  SMS = 'sms',\n\n  /**\n   * Notifications are enqueued into an SQS queue.\n   */\n  SQS = 'sqs',\n\n  /**\n   * JSON-encoded notifications are sent to a mobile app endpoint.\n   */\n  APPLICATION = 'application',\n\n  /**\n   * Notifications trigger a Lambda function.\n   */\n  LAMBDA = 'lambda',\n\n  /**\n   * Notifications put records into a firehose delivery stream.\n   */\n  FIREHOSE = 'firehose'\n}\n"]}
\No newline at end of file