/ cloudformation-templates / node_modules / @aws-cdk / aws-lambda / lib / event-source-mapping.js
event-source-mapping.js
  1  "use strict";
  2  var _a, _b;
  3  Object.defineProperty(exports, "__esModule", { value: true });
  4  exports.StartingPosition = exports.EventSourceMapping = exports.SourceAccessConfigurationType = void 0;
  5  const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
  6  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
  7  const cdk = require("@aws-cdk/core");
  8  const lambda_generated_1 = require("./lambda.generated");
  9  /**
 10   * The type of authentication protocol or the VPC components for your event source's SourceAccessConfiguration.
 11   *
 12   * @see https://docs.aws.amazon.com/lambda/latest/dg/API_SourceAccessConfiguration.html#SSS-Type-SourceAccessConfiguration-Type
 13   * @stability stable
 14   */
 15  class SourceAccessConfigurationType {
 16      constructor(type) {
 17          this.type = type;
 18      }
 19      /**
 20       * A custom source access configuration property.
 21       *
 22       * @stability stable
 23       */
 24      static of(name) {
 25          return new SourceAccessConfigurationType(name);
 26      }
 27  }
 28  exports.SourceAccessConfigurationType = SourceAccessConfigurationType;
 29  _a = JSII_RTTI_SYMBOL_1;
 30  SourceAccessConfigurationType[_a] = { fqn: "@aws-cdk/aws-lambda.SourceAccessConfigurationType", version: "1.134.0" };
 31  /**
 32   * (MQ) The Secrets Manager secret that stores your broker credentials.
 33   *
 34   * @stability stable
 35   */
 36  SourceAccessConfigurationType.BASIC_AUTH = new SourceAccessConfigurationType('BASIC_AUTH');
 37  /**
 38   * The subnets associated with your VPC.
 39   *
 40   * Lambda connects to these subnets to fetch data from your Self-Managed Apache Kafka cluster.
 41   *
 42   * @stability stable
 43   */
 44  SourceAccessConfigurationType.VPC_SUBNET = new SourceAccessConfigurationType('VPC_SUBNET');
 45  /**
 46   * The VPC security group used to manage access to your Self-Managed Apache Kafka brokers.
 47   *
 48   * @stability stable
 49   */
 50  SourceAccessConfigurationType.VPC_SECURITY_GROUP = new SourceAccessConfigurationType('VPC_SECURITY_GROUP');
 51  /**
 52   * The Secrets Manager ARN of your secret key used for SASL SCRAM-256 authentication of your Self-Managed Apache Kafka brokers.
 53   *
 54   * @stability stable
 55   */
 56  SourceAccessConfigurationType.SASL_SCRAM_256_AUTH = new SourceAccessConfigurationType('SASL_SCRAM_256_AUTH');
 57  /**
 58   * The Secrets Manager ARN of your secret key used for SASL SCRAM-512 authentication of your Self-Managed Apache Kafka brokers.
 59   *
 60   * @stability stable
 61   */
 62  SourceAccessConfigurationType.SASL_SCRAM_512_AUTH = new SourceAccessConfigurationType('SASL_SCRAM_512_AUTH');
 63  /**
 64   * Defines a Lambda EventSourceMapping resource.
 65   *
 66   * Usually, you won't need to define the mapping yourself. This will usually be done by
 67   * event sources. For example, to add an SQS event source to a function:
 68   *
 69   *     import { SqsEventSource } from '@aws-cdk/aws-lambda-event-sources';
 70   *     lambda.addEventSource(new SqsEventSource(sqs));
 71   *
 72   * The `SqsEventSource` class will automatically create the mapping, and will also
 73   * modify the Lambda's execution role so it can consume messages from the queue.
 74   *
 75   * @stability stable
 76   */
 77  class EventSourceMapping extends cdk.Resource {
 78      /**
 79       * @stability stable
 80       */
 81      constructor(scope, id, props) {
 82          var _c, _d, _e, _f, _g;
 83          super(scope, id);
 84          jsiiDeprecationWarnings._aws_cdk_aws_lambda_EventSourceMappingProps(props);
 85          if (props.eventSourceArn == undefined && props.kafkaBootstrapServers == undefined) {
 86              throw new Error('Either eventSourceArn or kafkaBootstrapServers must be set');
 87          }
 88          if (props.eventSourceArn !== undefined && props.kafkaBootstrapServers !== undefined) {
 89              throw new Error('eventSourceArn and kafkaBootstrapServers are mutually exclusive');
 90          }
 91          if (props.kafkaBootstrapServers && (((_c = props.kafkaBootstrapServers) === null || _c === void 0 ? void 0 : _c.length) < 1)) {
 92              throw new Error('kafkaBootStrapServers must not be empty if set');
 93          }
 94          if (props.maxBatchingWindow && props.maxBatchingWindow.toSeconds() > 300) {
 95              throw new Error(`maxBatchingWindow cannot be over 300 seconds, got ${props.maxBatchingWindow.toSeconds()}`);
 96          }
 97          if (props.maxRecordAge && (props.maxRecordAge.toSeconds() < 60 || props.maxRecordAge.toDays({ integral: false }) > 7)) {
 98              throw new Error('maxRecordAge must be between 60 seconds and 7 days inclusive');
 99          }
100          props.retryAttempts !== undefined && cdk.withResolved(props.retryAttempts, (attempts) => {
101              if (attempts < 0 || attempts > 10000) {
102                  throw new Error(`retryAttempts must be between 0 and 10000 inclusive, got ${attempts}`);
103              }
104          });
105          props.parallelizationFactor !== undefined && cdk.withResolved(props.parallelizationFactor, (factor) => {
106              if (factor < 1 || factor > 10) {
107                  throw new Error(`parallelizationFactor must be between 1 and 10 inclusive, got ${factor}`);
108              }
109          });
110          if (props.tumblingWindow && !cdk.Token.isUnresolved(props.tumblingWindow) && props.tumblingWindow.toSeconds() > 900) {
111              throw new Error(`tumblingWindow cannot be over 900 seconds, got ${props.tumblingWindow.toSeconds()}`);
112          }
113          let destinationConfig;
114          if (props.onFailure) {
115              destinationConfig = {
116                  onFailure: props.onFailure.bind(this, props.target),
117              };
118          }
119          let selfManagedEventSource;
120          if (props.kafkaBootstrapServers) {
121              selfManagedEventSource = { endpoints: { kafkaBootstrapServers: props.kafkaBootstrapServers } };
122          }
123          const cfnEventSourceMapping = new lambda_generated_1.CfnEventSourceMapping(this, 'Resource', {
124              batchSize: props.batchSize,
125              bisectBatchOnFunctionError: props.bisectBatchOnError,
126              destinationConfig,
127              enabled: props.enabled,
128              eventSourceArn: props.eventSourceArn,
129              functionName: props.target.functionName,
130              startingPosition: props.startingPosition,
131              functionResponseTypes: props.reportBatchItemFailures ? ['ReportBatchItemFailures'] : undefined,
132              maximumBatchingWindowInSeconds: (_d = props.maxBatchingWindow) === null || _d === void 0 ? void 0 : _d.toSeconds(),
133              maximumRecordAgeInSeconds: (_e = props.maxRecordAge) === null || _e === void 0 ? void 0 : _e.toSeconds(),
134              maximumRetryAttempts: props.retryAttempts,
135              parallelizationFactor: props.parallelizationFactor,
136              topics: props.kafkaTopic !== undefined ? [props.kafkaTopic] : undefined,
137              tumblingWindowInSeconds: (_f = props.tumblingWindow) === null || _f === void 0 ? void 0 : _f.toSeconds(),
138              sourceAccessConfigurations: (_g = props.sourceAccessConfigurations) === null || _g === void 0 ? void 0 : _g.map((o) => { return { type: o.type.type, uri: o.uri }; }),
139              selfManagedEventSource,
140          });
141          this.eventSourceMappingId = cfnEventSourceMapping.ref;
142      }
143      /**
144       * Import an event source into this stack from its event source id.
145       *
146       * @stability stable
147       */
148      static fromEventSourceMappingId(scope, id, eventSourceMappingId) {
149          class Import extends cdk.Resource {
150              constructor() {
151                  super(...arguments);
152                  this.eventSourceMappingId = eventSourceMappingId;
153              }
154          }
155          return new Import(scope, id);
156      }
157  }
158  exports.EventSourceMapping = EventSourceMapping;
159  _b = JSII_RTTI_SYMBOL_1;
160  EventSourceMapping[_b] = { fqn: "@aws-cdk/aws-lambda.EventSourceMapping", version: "1.134.0" };
161  /**
162   * The position in the DynamoDB, Kinesis or MSK stream where AWS Lambda should start reading.
163   *
164   * @stability stable
165   */
166  var StartingPosition;
167  (function (StartingPosition) {
168      StartingPosition["TRIM_HORIZON"] = "TRIM_HORIZON";
169      StartingPosition["LATEST"] = "LATEST";
170  })(StartingPosition = exports.StartingPosition || (exports.StartingPosition = {}));
171  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event-source-mapping.js","sourceRoot":"","sources":["event-source-mapping.ts"],"names":[],"mappings":"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","sourcesContent":["import * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { IEventSourceDlq } from './dlq';\nimport { IFunction } from './function-base';\nimport { CfnEventSourceMapping } from './lambda.generated';\n\n                                                                                                                                                                                                                                                      \nexport class SourceAccessConfigurationType {\n\n                                                                                     \n  public static readonly BASIC_AUTH = new SourceAccessConfigurationType('BASIC_AUTH');\n\n                                                                                                                                                  \n  public static readonly VPC_SUBNET = new SourceAccessConfigurationType('VPC_SUBNET');\n\n                                                                                                        \n  public static readonly VPC_SECURITY_GROUP = new SourceAccessConfigurationType('VPC_SECURITY_GROUP');\n\n                                                                                                                                             \n  public static readonly SASL_SCRAM_256_AUTH = new SourceAccessConfigurationType('SASL_SCRAM_256_AUTH');\n\n                                                                                                                                             \n  public static readonly SASL_SCRAM_512_AUTH = new SourceAccessConfigurationType('SASL_SCRAM_512_AUTH');\n\n                                                      \n  public static of(name: string): SourceAccessConfigurationType {\n    return new SourceAccessConfigurationType(name);\n  }\n\n                                                                                                                                                                                                                                                                                                                    \n  public readonly type: string;\n\n  private constructor(type: string) {\n    this.type = type;\n  }\n}\n\n                                                                                                                          \nexport interface SourceAccessConfiguration {\n                                                                                                                                     \n  readonly type: SourceAccessConfigurationType,\n                                                                                                                                                                                                                                                       \n  readonly uri: string\n}\n\nexport interface EventSourceMappingOptions {\n                                                                                                                                                                                                                                       \n  readonly eventSourceArn?: string;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                              \n  readonly batchSize?: number;\n\n                                                                                                             \n  readonly bisectBatchOnError?: boolean;\n\n                                                                                                                                            \n  readonly onFailure?: IEventSourceDlq;\n\n                                                                                                \n  readonly enabled?: boolean;\n\n                                                                                                                                                                                                                                                                                                                                                                       \n  readonly startingPosition?: StartingPosition;\n\n                                                                                                                                                                                                                                       \n  readonly reportBatchItemFailures?: boolean;\n\n                                                                                                                                                                      \n  readonly maxBatchingWindow?: cdk.Duration;\n\n                                                                                                                                                                                                                                           \n  readonly maxRecordAge?: cdk.Duration;\n\n                                                                                                                                                                                                                                                                                                                                            \n  readonly retryAttempts?: number;\n\n                                                                                                                                                                           \n  readonly parallelizationFactor?: number;\n\n                                                                           \n  readonly kafkaTopic?: string;\n\n                                                                                                                                                                                                                                                             \n  readonly tumblingWindow?: cdk.Duration;\n\n                                                                                                                                                                                                                                                                                        \n  readonly kafkaBootstrapServers?: string[]\n\n                                                                                                                                                                                                                                                                                                           \n  readonly sourceAccessConfigurations?: SourceAccessConfiguration[]\n}\n\n                                                               \nexport interface EventSourceMappingProps extends EventSourceMappingOptions {\n                                                \n  readonly target: IFunction;\n}\n\n                                                                                                                                                            \nexport interface IEventSourceMapping extends cdk.IResource {\n                                                                           \n  readonly eventSourceMappingId: string;\n}\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \nexport class EventSourceMapping extends cdk.Resource implements IEventSourceMapping {\n\n                                                                                 \n  public static fromEventSourceMappingId(scope: Construct, id: string, eventSourceMappingId: string): IEventSourceMapping {\n    class Import extends cdk.Resource implements IEventSourceMapping {\n      public readonly eventSourceMappingId = eventSourceMappingId;\n    }\n    return new Import(scope, id);\n  }\n\n  public readonly eventSourceMappingId: string;\n\n  constructor(scope: Construct, id: string, props: EventSourceMappingProps) {\n    super(scope, id);\n\n    if (props.eventSourceArn == undefined && props.kafkaBootstrapServers == undefined) {\n      throw new Error('Either eventSourceArn or kafkaBootstrapServers must be set');\n    }\n\n    if (props.eventSourceArn !== undefined && props.kafkaBootstrapServers !== undefined) {\n      throw new Error('eventSourceArn and kafkaBootstrapServers are mutually exclusive');\n    }\n\n    if (props.kafkaBootstrapServers && (props.kafkaBootstrapServers?.length < 1)) {\n      throw new Error('kafkaBootStrapServers must not be empty if set');\n    }\n\n    if (props.maxBatchingWindow && props.maxBatchingWindow.toSeconds() > 300) {\n      throw new Error(`maxBatchingWindow cannot be over 300 seconds, got ${props.maxBatchingWindow.toSeconds()}`);\n    }\n\n    if (props.maxRecordAge && (props.maxRecordAge.toSeconds() < 60 || props.maxRecordAge.toDays({ integral: false }) > 7)) {\n      throw new Error('maxRecordAge must be between 60 seconds and 7 days inclusive');\n    }\n\n    props.retryAttempts !== undefined && cdk.withResolved(props.retryAttempts, (attempts) => {\n      if (attempts < 0 || attempts > 10000) {\n        throw new Error(`retryAttempts must be between 0 and 10000 inclusive, got ${attempts}`);\n      }\n    });\n\n    props.parallelizationFactor !== undefined && cdk.withResolved(props.parallelizationFactor, (factor) => {\n      if (factor < 1 || factor > 10) {\n        throw new Error(`parallelizationFactor must be between 1 and 10 inclusive, got ${factor}`);\n      }\n    });\n\n    if (props.tumblingWindow && !cdk.Token.isUnresolved(props.tumblingWindow) && props.tumblingWindow.toSeconds() > 900) {\n      throw new Error(`tumblingWindow cannot be over 900 seconds, got ${props.tumblingWindow.toSeconds()}`);\n    }\n\n\n    let destinationConfig;\n\n    if (props.onFailure) {\n      destinationConfig = {\n        onFailure: props.onFailure.bind(this, props.target),\n      };\n    }\n\n    let selfManagedEventSource;\n    if (props.kafkaBootstrapServers) {\n      selfManagedEventSource = { endpoints: { kafkaBootstrapServers: props.kafkaBootstrapServers } };\n    }\n\n    const cfnEventSourceMapping = new CfnEventSourceMapping(this, 'Resource', {\n      batchSize: props.batchSize,\n      bisectBatchOnFunctionError: props.bisectBatchOnError,\n      destinationConfig,\n      enabled: props.enabled,\n      eventSourceArn: props.eventSourceArn,\n      functionName: props.target.functionName,\n      startingPosition: props.startingPosition,\n      functionResponseTypes: props.reportBatchItemFailures ? ['ReportBatchItemFailures'] : undefined,\n      maximumBatchingWindowInSeconds: props.maxBatchingWindow?.toSeconds(),\n      maximumRecordAgeInSeconds: props.maxRecordAge?.toSeconds(),\n      maximumRetryAttempts: props.retryAttempts,\n      parallelizationFactor: props.parallelizationFactor,\n      topics: props.kafkaTopic !== undefined ? [props.kafkaTopic] : undefined,\n      tumblingWindowInSeconds: props.tumblingWindow?.toSeconds(),\n      sourceAccessConfigurations: props.sourceAccessConfigurations?.map((o) => {return { type: o.type.type, uri: o.uri };}),\n      selfManagedEventSource,\n    });\n    this.eventSourceMappingId = cfnEventSourceMapping.ref;\n  }\n}\n\n                                                                                                        \nexport enum StartingPosition {\n                                                                                                                                          \n  TRIM_HORIZON = 'TRIM_HORIZON',\n\n                                                                                                                                             \n  LATEST = 'LATEST',\n}\n"]}