UNPKG

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
"use strict"; 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":";;;;;AAAA,mCAAmC;AACnC,yDAAyD;AAEzD,iEAAiE;AACjE,2CAA2C;AAC3C,iDAAiD;AACjD,6EAA6E;AAC7E,2CAA2C;AAE3C,8CAA+D;AA6E/D;;GAEG;AACH,MAAa,gBAAiB,SAAQ,iBAAS;IAQ7C;;;;;OAKG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA4B;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,MAAM,WAAW,GAAG,GAAG,EAAE,eAAe,CAAC;QACzC,MAAM,eAAe,GAAG,GAAG,EAAE,aAAa,CAAC;QAE3C,IAAI,KAAK,CAAC,cAAc,EAAE;YACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,cAAc,CAAC;SACtC;aAAM,IAAI,KAAK,CAAC,mBAAmB,EAAE;YACpC,MAAM,aAAa,GAAkC,KAAK,CAAC,mBAAmB,CAAC;YAE/E,IAAI,CAAC,QAAQ,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,kBAAkB,EAAE;gBAC5D,OAAO,EAAE,aAAa,CAAC,OAAO,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;gBAC3D,UAAU,EAAE,aAAa,CAAC,UAAU,IAAI,GAAG;gBAC3C,WAAW,EAAE;oBACX,YAAY,EAAE,WAAW;oBACzB,iBAAiB,EAAE,eAAe;oBAClC,GAAG,CAAC,aAAa,CAAC,WAAW,IAAI,EAAE,CAAC;iBACrC;gBACD,GAAG,aAAa;aACjB,CAAC,CAAC;SACJ;aAAM;YACL,MAAM,SAAS,CAAC,iFAAiF,CAAC,CAAC;SACpG;QAED,gEAAgE;QAChE,IAAI,CAAC,QAAQ,CAAC,eAAe,CAC3B,IAAI,GAAG,CAAC,eAAe,CAAC;YACtB,OAAO,EAAE,CAAC,kBAAkB,CAAC;YAC7B,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CACH,CAAC;QAEF,MAAM,UAAU,GAAG,KAAK,CAAC,UAAU,IAAI,KAAK,CAAC;QAC7C,IAAI,UAAU,IAAI,IAAI,EAAE;YACtB,IAAI,CAAC,eAAe,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,mBAAmB,EAAE;gBAC9D,IAAI,EAAE,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,SAAS;aACxE,CAAC,CAAC;SACJ;QAED,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAC;SAC7B;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,EAAE;gBACxC,iBAAiB,EAAE,KAAK,CAAC,aAAa,EAAE,iBAAiB,IAAI,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC;gBACpF,eAAe,EAAE,IAAI,CAAC,eAAe;oBACnC,CAAC,CAAC;wBACE,KAAK,EAAE,IAAI,CAAC,eAAe;wBAC3B,eAAe,EAAE,KAAK,CAAC,eAAe,IAAI,CAAC;qBAC5C;oBACH,CAAC,CAAC,SAAS;gBACb,IAAI,EAAE,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,CAAC,SAAS;gBACvE,GAAG,KAAK,CAAC,aAAa;aACvB,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,QAAQ,CAAC,cAAc,CAC1B,IAAI,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,EAAE;YAClD,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;SAC3C,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,QAAQ,CAAC,yBAAyB,EAAE;YACvC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE;YACpC,SAAS,EAAE,KAAK,CAAC,mBAAmB,EAAE,oBAAoB,IAAI,CAAC;YAC/D,iBAAiB,EAAE,KAAK,CAAC,mBAAmB,EAAE,uBAAuB,IAAI,CAAC;YAC1E,kBAAkB,EAChB,KAAK,CAAC,mBAAmB,EAAE,wBAAwB,IAAI,UAAU,CAAC,kBAAkB,CAAC,sBAAsB;SAC9G,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,GAAG;YAClB,MAAM,EAAE,CAAC,WAAW,CAAC;YACrB,UAAU,EAAE,CAAC,eAAe,CAAC;SAC9B,CAAC;QAEF,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE;YAC5C,MAAM,SAAS,CAAC,6DAA6D,CAAC,CAAC;SAChF;QAED,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI;YAC5B,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,cAAc,EAAE,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC;YACrF,CAAC,CAAC,CAAC,IAAI,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAChD,CAAC;;AAjGH,4CAkGC","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"]}