aws-ddk-core
Version:
The AWS DataOps Development Kit is an open source development framework for customers that build data workflows and modern data architecture on AWS.
99 lines • 17.1 kB
JavaScript
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.SqsToLambdaStage = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const cdk = require("aws-cdk-lib");
const cloudwatch = require("aws-cdk-lib/aws-cloudwatch");
const events_targets = require("aws-cdk-lib/aws-events-targets");
const iam = require("aws-cdk-lib/aws-iam");
const lambda = require("aws-cdk-lib/aws-lambda");
const lambda_event_sources = require("aws-cdk-lib/aws-lambda-event-sources");
const sqs = require("aws-cdk-lib/aws-sqs");
const stage_1 = require("../pipelines/stage");
/**
* Stage implements an Amazon SQS queue connected to an AWS Lambda function, with an optional DLQ.
*/
class SqsToLambdaStage extends stage_1.DataStage {
/**
* Constructs `SqsToLambdaStage`.
* @param scope Scope within which this construct is defined.
* @param id Identifier of the stage.
* @param props Properties for the stage.
*/
constructor(scope, id, props) {
super(scope, id, props);
const eventSource = `${id}-event-source`;
const eventDetailType = `${id}-event-type`;
if (props.lambdaFunction) {
this.function = props.lambdaFunction;
}
else if (props.lambdaFunctionProps) {
const functionProps = props.lambdaFunctionProps;
this.function = new lambda.Function(this, "Process Function", {
timeout: functionProps.timeout ?? cdk.Duration.seconds(120),
memorySize: functionProps.memorySize ?? 256,
environment: {
EVENT_SOURCE: eventSource,
EVENT_DETAIL_TYPE: eventDetailType,
...(functionProps.environment ?? {}),
},
...functionProps,
});
}
else {
throw TypeError("'lambdaFunction' or 'lambdaFunctionProps' must be set to instantiate this stage");
}
// Enable the function to publish events to the default EventBus
this.function.addToRolePolicy(new iam.PolicyStatement({
actions: ["events:PutEvents"],
resources: ["*"],
}));
const dlqEnabled = props.dlqEnabled ?? false;
if (dlqEnabled == true) {
this.deadLetterQueue = new sqs.Queue(this, "Dead Letter Queue", {
fifo: props.sqsQueueProps?.fifo ? props.sqsQueueProps?.fifo : undefined,
});
}
if (props.sqsQueue) {
this.queue = props.sqsQueue;
}
else {
this.queue = new sqs.Queue(this, "Queue", {
visibilityTimeout: props.sqsQueueProps?.visibilityTimeout ?? cdk.Duration.minutes(2),
deadLetterQueue: this.deadLetterQueue
? {
queue: this.deadLetterQueue,
maxReceiveCount: props.maxReceiveCount ?? 1,
}
: undefined,
fifo: props.sqsQueueProps?.fifo ? props.sqsQueueProps?.fifo : undefined,
...props.sqsQueueProps,
});
}
this.function.addEventSource(new lambda_event_sources.SqsEventSource(this.queue, {
batchSize: props.batchSize,
maxBatchingWindow: props.maxBatchingWindow,
}));
this.addAlarm("Process Function Errors", {
metric: this.function.metricErrors(),
threshold: props.lambdaFunctionProps?.errorsAlarmThreshold ?? 5,
evaluationPeriods: props.lambdaFunctionProps?.errorsEvaluationPeriods ?? 1,
comparisonOperator: props.lambdaFunctionProps?.errorsComparisonOperator ?? cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,
});
this.eventPattern = {
source: [eventSource],
detailType: [eventDetailType],
};
if (this.queue.fifo && !props.messageGroupId) {
throw TypeError("'messageGroupId' must be set to when target is a fifo queue");
}
this.targets = this.queue.fifo
? [new events_targets.SqsQueue(this.queue, { messageGroupId: props.messageGroupId })]
: [new events_targets.SqsQueue(this.queue)];
}
}
exports.SqsToLambdaStage = SqsToLambdaStage;
_a = JSII_RTTI_SYMBOL_1;
SqsToLambdaStage[_a] = { fqn: "aws-ddk-core.SqsToLambdaStage", version: "1.4.1" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sqs-lambda.js","sourceRoot":"","sources":["../../src/stages/sqs-lambda.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from \"aws-cdk-lib\";\nimport * as cloudwatch from \"aws-cdk-lib/aws-cloudwatch\";\nimport * as events from \"aws-cdk-lib/aws-events\";\nimport * as events_targets from \"aws-cdk-lib/aws-events-targets\";\nimport * as iam from \"aws-cdk-lib/aws-iam\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport * as lambda_event_sources from \"aws-cdk-lib/aws-lambda-event-sources\";\nimport * as sqs from \"aws-cdk-lib/aws-sqs\";\nimport { Construct } from \"constructs\";\nimport { DataStage, DataStageProps } from \"../pipelines/stage\";\n\n/**\n * Properties for the Lambda Function created by `SqsToLambdaStage`.\n */\nexport interface SqsToLambdaStageFunctionProps extends lambda.FunctionProps {\n  /**\n   * Amount of errored function invocations before triggering CloudWatch alarm.\n   * @default 5\n   */\n  readonly errorsAlarmThreshold?: number;\n  /**\n   * The number of periods over which data is compared to the specified threshold.\n   * @default 1\n   */\n  readonly errorsEvaluationPeriods?: number;\n  /**\n   * Comparison operator for evaluating alarms.\n   * @default cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD\n   */\n  readonly errorsComparisonOperator?: cloudwatch.ComparisonOperator;\n}\n\n/**\n * Properties for `SqsToLambdaStage`.\n */\nexport interface SqsToLambdaStageProps extends DataStageProps {\n  /**\n   * Preexisting Lambda Function to use in stage.\n   * If not provided, a new function will be created.\n   */\n  readonly lambdaFunction?: lambda.IFunction;\n  /**\n   * Properties for the Lambda Function that will be created by this construct\n   * (if `lambdaFunction` is not provided).\n   */\n  readonly lambdaFunctionProps?: SqsToLambdaStageFunctionProps;\n  /**\n   * Preexisting SQS Queue to use in stage.\n   * If not provided, a new queue will be created.\n   */\n  readonly sqsQueue?: sqs.IQueue;\n  /**\n   * Properties for the SQS Queue that will be created by this construct\n   * (if `sqsQueue` is not provided).\n   */\n  readonly sqsQueueProps?: sqs.QueueProps;\n\n  /**\n   * The maximum number of records retrieved from the event source at the function invocation time.\n   * @default 10\n   */\n  readonly batchSize?: number;\n  /**\n   * The maximum amount of time to gather records before invoking the function.\n   * Valid Range: Minimum value of 0 minutes, maximum value of 5 minutes.\n   * Default: - no batching window.\n   */\n  readonly maxBatchingWindow?: cdk.Duration;\n  /**\n   * Determines if DLQ is enabled.\n   * @default false\n   */\n  readonly dlqEnabled?: boolean;\n  /**\n   * The number of times a message can be unsuccessfully dequeued before\n   * being moved to the dead-letter queue.\n   * @default 1\n   */\n  readonly maxReceiveCount?: number;\n  /**\n   * Message Group ID for messages sent to this queue.\n   * Required for FIFO queues.\n   */\n  readonly messageGroupId?: string;\n}\n\n/**\n * Stage implements an Amazon SQS queue connected to an AWS Lambda function, with an optional DLQ.\n */\nexport class SqsToLambdaStage extends DataStage {\n  readonly targets?: events.IRuleTarget[];\n  readonly eventPattern?: events.EventPattern;\n\n  readonly function: lambda.IFunction;\n  readonly queue: sqs.IQueue;\n  readonly deadLetterQueue?: sqs.Queue;\n\n  /**\n   * Constructs `SqsToLambdaStage`.\n   * @param scope Scope within which this construct is defined.\n   * @param id Identifier of the stage.\n   * @param props Properties for the stage.\n   */\n  constructor(scope: Construct, id: string, props: SqsToLambdaStageProps) {\n    super(scope, id, props);\n\n    const eventSource = `${id}-event-source`;\n    const eventDetailType = `${id}-event-type`;\n\n    if (props.lambdaFunction) {\n      this.function = props.lambdaFunction;\n    } else if (props.lambdaFunctionProps) {\n      const functionProps: SqsToLambdaStageFunctionProps = props.lambdaFunctionProps;\n\n      this.function = new lambda.Function(this, \"Process Function\", {\n        timeout: functionProps.timeout ?? cdk.Duration.seconds(120),\n        memorySize: functionProps.memorySize ?? 256,\n        environment: {\n          EVENT_SOURCE: eventSource,\n          EVENT_DETAIL_TYPE: eventDetailType,\n          ...(functionProps.environment ?? {}),\n        },\n        ...functionProps,\n      });\n    } else {\n      throw TypeError(\"'lambdaFunction' or 'lambdaFunctionProps' must be set to instantiate this stage\");\n    }\n\n    // Enable the function to publish events to the default EventBus\n    this.function.addToRolePolicy(\n      new iam.PolicyStatement({\n        actions: [\"events:PutEvents\"],\n        resources: [\"*\"],\n      }),\n    );\n\n    const dlqEnabled = props.dlqEnabled ?? false;\n    if (dlqEnabled == true) {\n      this.deadLetterQueue = new sqs.Queue(this, \"Dead Letter Queue\", {\n        fifo: props.sqsQueueProps?.fifo ? props.sqsQueueProps?.fifo : undefined,\n      });\n    }\n\n    if (props.sqsQueue) {\n      this.queue = props.sqsQueue;\n    } else {\n      this.queue = new sqs.Queue(this, \"Queue\", {\n        visibilityTimeout: props.sqsQueueProps?.visibilityTimeout ?? cdk.Duration.minutes(2),\n        deadLetterQueue: this.deadLetterQueue\n          ? {\n              queue: this.deadLetterQueue,\n              maxReceiveCount: props.maxReceiveCount ?? 1,\n            }\n          : undefined,\n        fifo: props.sqsQueueProps?.fifo ? props.sqsQueueProps?.fifo : undefined,\n        ...props.sqsQueueProps,\n      });\n    }\n\n    this.function.addEventSource(\n      new lambda_event_sources.SqsEventSource(this.queue, {\n        batchSize: props.batchSize,\n        maxBatchingWindow: props.maxBatchingWindow,\n      }),\n    );\n\n    this.addAlarm(\"Process Function Errors\", {\n      metric: this.function.metricErrors(),\n      threshold: props.lambdaFunctionProps?.errorsAlarmThreshold ?? 5,\n      evaluationPeriods: props.lambdaFunctionProps?.errorsEvaluationPeriods ?? 1,\n      comparisonOperator:\n        props.lambdaFunctionProps?.errorsComparisonOperator ?? cloudwatch.ComparisonOperator.GREATER_THAN_THRESHOLD,\n    });\n\n    this.eventPattern = {\n      source: [eventSource],\n      detailType: [eventDetailType],\n    };\n\n    if (this.queue.fifo && !props.messageGroupId) {\n      throw TypeError(\"'messageGroupId' must be set to when target is a fifo queue\");\n    }\n\n    this.targets = this.queue.fifo\n      ? [new events_targets.SqsQueue(this.queue, { messageGroupId: props.messageGroupId })]\n      : [new events_targets.SqsQueue(this.queue)];\n  }\n}\n"]}
;