@aws-cdk/aws-sns
Version:
The CDK Construct Library for AWS::SNS
136 lines • 16.7 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.SubscriptionProtocol = exports.Subscription = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_iam_1 = require("@aws-cdk/aws-iam");
const core_1 = require("@aws-cdk/core");
const sns_generated_1 = require("./sns.generated");
/**
* A new subscription.
*
* Prefer to use the `ITopic.addSubscription()` methods to create instances of
* this class.
*/
class Subscription extends core_1.Resource {
constructor(scope, id, props) {
super(scope, id);
try {
jsiiDeprecationWarnings._aws_cdk_aws_sns_SubscriptionProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, Subscription);
}
throw error;
}
if (props.rawMessageDelivery &&
[
SubscriptionProtocol.HTTP,
SubscriptionProtocol.HTTPS,
SubscriptionProtocol.SQS,
SubscriptionProtocol.FIREHOSE,
]
.indexOf(props.protocol) < 0) {
throw new Error('Raw message delivery can only be enabled for HTTP, HTTPS, SQS, and Firehose subscriptions.');
}
if (props.filterPolicy) {
if (Object.keys(props.filterPolicy).length > 5) {
throw new Error('A filter policy can have a maximum of 5 attribute names.');
}
this.filterPolicy = Object.entries(props.filterPolicy)
.reduce((acc, [k, v]) => ({ ...acc, [k]: v.conditions }), {});
let total = 1;
Object.values(this.filterPolicy).forEach(filter => { total *= filter.length; });
if (total > 100) {
throw new Error(`The total combination of values (${total}) must not exceed 100.`);
}
}
if (props.protocol === SubscriptionProtocol.FIREHOSE && !props.subscriptionRoleArn) {
throw new Error('Subscription role arn is required field for subscriptions with a firehose protocol.');
}
this.deadLetterQueue = this.buildDeadLetterQueue(props);
new sns_generated_1.CfnSubscription(this, 'Resource', {
endpoint: props.endpoint,
protocol: props.protocol,
topicArn: props.topic.topicArn,
rawMessageDelivery: props.rawMessageDelivery,
filterPolicy: this.filterPolicy,
region: props.region,
redrivePolicy: this.buildDeadLetterConfig(this.deadLetterQueue),
subscriptionRoleArn: props.subscriptionRoleArn,
});
}
buildDeadLetterQueue(props) {
if (!props.deadLetterQueue) {
return undefined;
}
const deadLetterQueue = props.deadLetterQueue;
deadLetterQueue.addToResourcePolicy(new aws_iam_1.PolicyStatement({
resources: [deadLetterQueue.queueArn],
actions: ['sqs:SendMessage'],
principals: [new aws_iam_1.ServicePrincipal('sns.amazonaws.com')],
conditions: {
ArnEquals: { 'aws:SourceArn': props.topic.topicArn },
},
}));
return deadLetterQueue;
}
buildDeadLetterConfig(deadLetterQueue) {
if (deadLetterQueue) {
return {
deadLetterTargetArn: deadLetterQueue.queueArn,
};
}
else {
return undefined;
}
}
}
exports.Subscription = Subscription;
_a = JSII_RTTI_SYMBOL_1;
Subscription[_a] = { fqn: "@aws-cdk/aws-sns.Subscription", version: "1.204.0" };
/**
* The type of subscription, controlling the type of the endpoint parameter.
*/
var SubscriptionProtocol;
(function (SubscriptionProtocol) {
/**
* JSON-encoded message is POSTED to an HTTP url.
*/
SubscriptionProtocol["HTTP"] = "http";
/**
* JSON-encoded message is POSTed to an HTTPS url.
*/
SubscriptionProtocol["HTTPS"] = "https";
/**
* Notifications are sent via email.
*/
SubscriptionProtocol["EMAIL"] = "email";
/**
* Notifications are JSON-encoded and sent via mail.
*/
SubscriptionProtocol["EMAIL_JSON"] = "email-json";
/**
* Notification is delivered by SMS
*/
SubscriptionProtocol["SMS"] = "sms";
/**
* Notifications are enqueued into an SQS queue.
*/
SubscriptionProtocol["SQS"] = "sqs";
/**
* JSON-encoded notifications are sent to a mobile app endpoint.
*/
SubscriptionProtocol["APPLICATION"] = "application";
/**
* Notifications trigger a Lambda function.
*/
SubscriptionProtocol["LAMBDA"] = "lambda";
/**
* Notifications put records into a firehose delivery stream.
*/
SubscriptionProtocol["FIREHOSE"] = "firehose";
})(SubscriptionProtocol = exports.SubscriptionProtocol || (exports.SubscriptionProtocol = {}));
//# 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"]}