function.js
1 "use strict"; 2 var _a; 3 Object.defineProperty(exports, "__esModule", { value: true }); 4 exports.verifyCodeConfig = exports.Function = exports.Tracing = void 0; 5 const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); 6 const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); 7 const cloudwatch = require("@aws-cdk/aws-cloudwatch"); 8 const aws_codeguruprofiler_1 = require("@aws-cdk/aws-codeguruprofiler"); 9 const ec2 = require("@aws-cdk/aws-ec2"); 10 const iam = require("@aws-cdk/aws-iam"); 11 const logs = require("@aws-cdk/aws-logs"); 12 const sqs = require("@aws-cdk/aws-sqs"); 13 const core_1 = require("@aws-cdk/core"); 14 const function_base_1 = require("./function-base"); 15 const function_hash_1 = require("./function-hash"); 16 const handler_1 = require("./handler"); 17 const lambda_version_1 = require("./lambda-version"); 18 const lambda_generated_1 = require("./lambda.generated"); 19 const layers_1 = require("./layers"); 20 const runtime_1 = require("./runtime"); 21 /** 22 * X-Ray Tracing Modes (https://docs.aws.amazon.com/lambda/latest/dg/API_TracingConfig.html). 23 * 24 * @stability stable 25 */ 26 var Tracing; 27 (function (Tracing) { 28 Tracing["ACTIVE"] = "Active"; 29 Tracing["PASS_THROUGH"] = "PassThrough"; 30 Tracing["DISABLED"] = "Disabled"; 31 })(Tracing = exports.Tracing || (exports.Tracing = {})); 32 /** 33 * Deploys a file from inside the construct library as a function. 34 * 35 * The supplied file is subject to the 4096 bytes limit of being embedded in a 36 * CloudFormation template. 37 * 38 * The construct includes an associated role with the lambda. 39 * 40 * This construct does not yet reproduce all features from the underlying resource 41 * library. 42 * 43 * @stability stable 44 */ 45 class Function extends function_base_1.FunctionBase { 46 /** 47 * @stability stable 48 */ 49 constructor(scope, id, props) { 50 var _b, _c, _d, _e, _f, _g, _h, _j; 51 super(scope, id, { 52 physicalName: props.functionName, 53 }); 54 /** 55 * The construct node where permissions are attached. 56 * 57 * @stability stable 58 */ 59 this.permissionsNode = this.node; 60 /** 61 * Whether the addPermission() call adds any permissions. 62 * 63 * True for new Lambdas, false for version $LATEST and imported Lambdas 64 * from different accounts. 65 * 66 * @stability stable 67 */ 68 this.canCreatePermissions = true; 69 this.layers = []; 70 /** 71 * Environment variables for this function 72 */ 73 this.environment = {}; 74 jsiiDeprecationWarnings._aws_cdk_aws_lambda_FunctionProps(props); 75 const managedPolicies = new Array(); 76 // the arn is in the form of - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole 77 managedPolicies.push(iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole')); 78 if (props.vpc) { 79 // Policy that will have ENI creation permissions 80 managedPolicies.push(iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole')); 81 } 82 this.role = props.role || new iam.Role(this, 'ServiceRole', { 83 assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'), 84 managedPolicies, 85 }); 86 this.grantPrincipal = this.role; 87 // add additional managed policies when necessary 88 if (props.filesystem) { 89 const config = props.filesystem.config; 90 if (config.policies) { 91 config.policies.forEach(p => { 92 var _b; 93 (_b = this.role) === null || _b === void 0 ? void 0 : _b.addToPrincipalPolicy(p); 94 }); 95 } 96 } 97 for (const statement of (props.initialPolicy || [])) { 98 this.role.addToPrincipalPolicy(statement); 99 } 100 const code = props.code.bind(this); 101 verifyCodeConfig(code, props); 102 let profilingGroupEnvironmentVariables = {}; 103 if (props.profilingGroup && props.profiling !== false) { 104 this.validateProfiling(props); 105 props.profilingGroup.grantPublish(this.role); 106 profilingGroupEnvironmentVariables = { 107 AWS_CODEGURU_PROFILER_GROUP_ARN: core_1.Stack.of(scope).formatArn({ 108 service: 'codeguru-profiler', 109 resource: 'profilingGroup', 110 resourceName: props.profilingGroup.profilingGroupName, 111 }), 112 AWS_CODEGURU_PROFILER_ENABLED: 'TRUE', 113 }; 114 } 115 else if (props.profiling) { 116 this.validateProfiling(props); 117 const profilingGroup = new aws_codeguruprofiler_1.ProfilingGroup(this, 'ProfilingGroup', { 118 computePlatform: aws_codeguruprofiler_1.ComputePlatform.AWS_LAMBDA, 119 }); 120 profilingGroup.grantPublish(this.role); 121 profilingGroupEnvironmentVariables = { 122 AWS_CODEGURU_PROFILER_GROUP_ARN: profilingGroup.profilingGroupArn, 123 AWS_CODEGURU_PROFILER_ENABLED: 'TRUE', 124 }; 125 } 126 const env = { ...profilingGroupEnvironmentVariables, ...props.environment }; 127 for (const [key, value] of Object.entries(env)) { 128 this.addEnvironment(key, value); 129 } 130 this.deadLetterQueue = this.buildDeadLetterQueue(props); 131 let fileSystemConfigs = undefined; 132 if (props.filesystem) { 133 fileSystemConfigs = [{ 134 arn: props.filesystem.config.arn, 135 localMountPath: props.filesystem.config.localMountPath, 136 }]; 137 } 138 if (props.architecture && props.architectures !== undefined) { 139 throw new Error('Either architecture or architectures must be specified but not both.'); 140 } 141 if (props.architectures && props.architectures.length > 1) { 142 throw new Error('Only one architecture must be specified.'); 143 } 144 const architecture = (_b = props.architecture) !== null && _b !== void 0 ? _b : (props.architectures && props.architectures[0]); 145 const resource = new lambda_generated_1.CfnFunction(this, 'Resource', { 146 functionName: this.physicalName, 147 description: props.description, 148 code: { 149 s3Bucket: code.s3Location && code.s3Location.bucketName, 150 s3Key: code.s3Location && code.s3Location.objectKey, 151 s3ObjectVersion: code.s3Location && code.s3Location.objectVersion, 152 zipFile: code.inlineCode, 153 imageUri: (_c = code.image) === null || _c === void 0 ? void 0 : _c.imageUri, 154 }, 155 layers: core_1.Lazy.list({ produce: () => this.layers.map(layer => layer.layerVersionArn) }, { omitEmpty: true }), 156 handler: props.handler === handler_1.Handler.FROM_IMAGE ? undefined : props.handler, 157 timeout: props.timeout && props.timeout.toSeconds(), 158 packageType: props.runtime === runtime_1.Runtime.FROM_IMAGE ? 'Image' : undefined, 159 runtime: props.runtime === runtime_1.Runtime.FROM_IMAGE ? undefined : props.runtime.name, 160 role: this.role.roleArn, 161 // Uncached because calling '_checkEdgeCompatibility', which gets called in the resolve of another 162 // Token, actually *modifies* the 'environment' map. 163 environment: core_1.Lazy.uncachedAny({ produce: () => this.renderEnvironment() }), 164 memorySize: props.memorySize, 165 vpcConfig: this.configureVpc(props), 166 deadLetterConfig: this.buildDeadLetterConfig(this.deadLetterQueue), 167 tracingConfig: this.buildTracingConfig(props), 168 reservedConcurrentExecutions: props.reservedConcurrentExecutions, 169 imageConfig: undefinedIfNoKeys({ 170 command: (_d = code.image) === null || _d === void 0 ? void 0 : _d.cmd, 171 entryPoint: (_e = code.image) === null || _e === void 0 ? void 0 : _e.entrypoint, 172 workingDirectory: (_f = code.image) === null || _f === void 0 ? void 0 : _f.workingDirectory, 173 }), 174 kmsKeyArn: (_g = props.environmentEncryption) === null || _g === void 0 ? void 0 : _g.keyArn, 175 fileSystemConfigs, 176 codeSigningConfigArn: (_h = props.codeSigningConfig) === null || _h === void 0 ? void 0 : _h.codeSigningConfigArn, 177 architectures: architecture ? [architecture.name] : undefined, 178 }); 179 resource.node.addDependency(this.role); 180 this.functionName = this.getResourceNameAttribute(resource.ref); 181 this.functionArn = this.getResourceArnAttribute(resource.attrArn, { 182 service: 'lambda', 183 resource: 'function', 184 resourceName: this.physicalName, 185 arnFormat: core_1.ArnFormat.COLON_RESOURCE_NAME, 186 }); 187 this.runtime = props.runtime; 188 this.architecture = props.architecture; 189 if (props.layers) { 190 if (props.runtime === runtime_1.Runtime.FROM_IMAGE) { 191 throw new Error('Layers are not supported for container image functions'); 192 } 193 this.addLayers(...props.layers); 194 } 195 for (const event of props.events || []) { 196 this.addEventSource(event); 197 } 198 // Log retention 199 if (props.logRetention) { 200 const logRetention = new logs.LogRetention(this, 'LogRetention', { 201 logGroupName: `/aws/lambda/${this.functionName}`, 202 retention: props.logRetention, 203 role: props.logRetentionRole, 204 logRetentionRetryOptions: props.logRetentionRetryOptions, 205 }); 206 this._logGroup = logs.LogGroup.fromLogGroupArn(this, 'LogGroup', logRetention.logGroupArn); 207 } 208 props.code.bindToResource(resource); 209 // Event Invoke Config 210 if (props.onFailure || props.onSuccess || props.maxEventAge || props.retryAttempts !== undefined) { 211 this.configureAsyncInvoke({ 212 onFailure: props.onFailure, 213 onSuccess: props.onSuccess, 214 maxEventAge: props.maxEventAge, 215 retryAttempts: props.retryAttempts, 216 }); 217 } 218 this.currentVersionOptions = props.currentVersionOptions; 219 if (props.filesystem) { 220 if (!props.vpc) { 221 throw new Error('Cannot configure \'filesystem\' without configuring a VPC.'); 222 } 223 const config = props.filesystem.config; 224 if (config.dependency) { 225 this.node.addDependency(...config.dependency); 226 } 227 // There could be a race if the Lambda is used in a CustomResource. It is possible for the Lambda to 228 // fail to attach to a given FileSystem if we do not have a dependency on the SecurityGroup ingress/egress 229 // rules that were created between this Lambda's SG & the Filesystem SG. 230 this.connections.securityGroups.forEach(sg => { 231 sg.node.findAll().forEach(child => { 232 if (child instanceof core_1.CfnResource && child.cfnResourceType === 'AWS::EC2::SecurityGroupEgress') { 233 resource.node.addDependency(child); 234 } 235 }); 236 }); 237 (_j = config.connections) === null || _j === void 0 ? void 0 : _j.securityGroups.forEach(sg => { 238 sg.node.findAll().forEach(child => { 239 if (child instanceof core_1.CfnResource && child.cfnResourceType === 'AWS::EC2::SecurityGroupIngress') { 240 resource.node.addDependency(child); 241 } 242 }); 243 }); 244 } 245 // Configure Lambda insights 246 this.configureLambdaInsights(props); 247 } 248 /** 249 * Returns a `lambda.Version` which represents the current version of this Lambda function. A new version will be created every time the function's configuration changes. 250 * 251 * You can specify options for this version using the `currentVersionOptions` 252 * prop when initializing the `lambda.Function`. 253 * 254 * @stability stable 255 */ 256 get currentVersion() { 257 if (this._currentVersion) { 258 return this._currentVersion; 259 } 260 this._currentVersion = new lambda_version_1.Version(this, 'CurrentVersion', { 261 lambda: this, 262 ...this.currentVersionOptions, 263 }); 264 // override the version's logical ID with a lazy string which includes the 265 // hash of the function itself, so a new version resource is created when 266 // the function configuration changes. 267 const cfn = this._currentVersion.node.defaultChild; 268 const originalLogicalId = this.stack.resolve(cfn.logicalId); 269 cfn.overrideLogicalId(core_1.Lazy.uncachedString({ 270 produce: () => { 271 const hash = function_hash_1.calculateFunctionHash(this); 272 const logicalId = function_hash_1.trimFromStart(originalLogicalId, 255 - 32); 273 return `${logicalId}${hash}`; 274 }, 275 })); 276 return this._currentVersion; 277 } 278 /** 279 * Record whether specific properties in the `AWS::Lambda::Function` resource should also be associated to the Version resource. 280 * 281 * See 'currentVersion' section in the module README for more details. 282 * 283 * @param propertyName The property to classify. 284 * @param locked whether the property should be associated to the version or not. 285 * @stability stable 286 */ 287 static classifyVersionProperty(propertyName, locked) { 288 this._VER_PROPS[propertyName] = locked; 289 } 290 /** 291 * Import a lambda function into the CDK using its ARN. 292 * 293 * @stability stable 294 */ 295 static fromFunctionArn(scope, id, functionArn) { 296 return Function.fromFunctionAttributes(scope, id, { functionArn }); 297 } 298 /** 299 * Creates a Lambda function object which represents a function not defined within this stack. 300 * 301 * @param scope The parent construct. 302 * @param id The name of the lambda construct. 303 * @param attrs the attributes of the function to import. 304 * @stability stable 305 */ 306 static fromFunctionAttributes(scope, id, attrs) { 307 jsiiDeprecationWarnings._aws_cdk_aws_lambda_FunctionAttributes(attrs); 308 const functionArn = attrs.functionArn; 309 const functionName = extractNameFromArn(attrs.functionArn); 310 const role = attrs.role; 311 class Import extends function_base_1.FunctionBase { 312 constructor(s, i) { 313 var _b; 314 super(s, i); 315 this.functionName = functionName; 316 this.functionArn = functionArn; 317 this.role = role; 318 this.permissionsNode = this.node; 319 this.canCreatePermissions = (_b = attrs.sameEnvironment) !== null && _b !== void 0 ? _b : this._isStackAccount(); 320 this.grantPrincipal = role || new iam.UnknownPrincipal({ resource: this }); 321 if (attrs.securityGroup) { 322 this._connections = new ec2.Connections({ 323 securityGroups: [attrs.securityGroup], 324 }); 325 } 326 else if (attrs.securityGroupId) { 327 this._connections = new ec2.Connections({ 328 securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(scope, 'SecurityGroup', attrs.securityGroupId)], 329 }); 330 } 331 } 332 } 333 return new Import(scope, id); 334 } 335 /** 336 * Return the given named metric for this Lambda. 337 * 338 * @stability stable 339 */ 340 static metricAll(metricName, props) { 341 return new cloudwatch.Metric({ 342 namespace: 'AWS/Lambda', 343 metricName, 344 ...props, 345 }); 346 } 347 /** 348 * Metric for the number of Errors executing all Lambdas. 349 * 350 * @default sum over 5 minutes 351 * @stability stable 352 */ 353 static metricAllErrors(props) { 354 return this.metricAll('Errors', { statistic: 'sum', ...props }); 355 } 356 /** 357 * Metric for the Duration executing all Lambdas. 358 * 359 * @default average over 5 minutes 360 * @stability stable 361 */ 362 static metricAllDuration(props) { 363 return this.metricAll('Duration', props); 364 } 365 /** 366 * Metric for the number of invocations of all Lambdas. 367 * 368 * @default sum over 5 minutes 369 * @stability stable 370 */ 371 static metricAllInvocations(props) { 372 return this.metricAll('Invocations', { statistic: 'sum', ...props }); 373 } 374 /** 375 * Metric for the number of throttled invocations of all Lambdas. 376 * 377 * @default sum over 5 minutes 378 * @stability stable 379 */ 380 static metricAllThrottles(props) { 381 return this.metricAll('Throttles', { statistic: 'sum', ...props }); 382 } 383 /** 384 * Metric for the number of concurrent executions across all Lambdas. 385 * 386 * @default max over 5 minutes 387 * @stability stable 388 */ 389 static metricAllConcurrentExecutions(props) { 390 // Mini-FAQ: why max? This metric is a gauge that is emitted every 391 // minute, so either max or avg or a percentile make sense (but sum 392 // doesn't). Max is more sensitive to spiky load changes which is 393 // probably what you're interested in if you're looking at this metric 394 // (Load spikes may lead to concurrent execution errors that would 395 // otherwise not be visible in the avg) 396 return this.metricAll('ConcurrentExecutions', { statistic: 'max', ...props }); 397 } 398 /** 399 * Metric for the number of unreserved concurrent executions across all Lambdas. 400 * 401 * @default max over 5 minutes 402 * @stability stable 403 */ 404 static metricAllUnreservedConcurrentExecutions(props) { 405 return this.metricAll('UnreservedConcurrentExecutions', { statistic: 'max', ...props }); 406 } 407 /** 408 * Adds an environment variable to this Lambda function. 409 * 410 * If this is a ref to a Lambda function, this operation results in a no-op. 411 * 412 * @param key The environment variable key. 413 * @param value The environment variable's value. 414 * @param options Environment variable options. 415 * @stability stable 416 */ 417 addEnvironment(key, value, options) { 418 jsiiDeprecationWarnings._aws_cdk_aws_lambda_EnvironmentOptions(options); 419 this.environment[key] = { value, ...options }; 420 return this; 421 } 422 /** 423 * Adds one or more Lambda Layers to this Lambda function. 424 * 425 * @param layers the layers to be added. 426 * @stability stable 427 * @throws if there are already 5 layers on this function, or the layer is incompatible with this function's runtime. 428 */ 429 addLayers(...layers) { 430 jsiiDeprecationWarnings._aws_cdk_aws_lambda_ILayerVersion(layers); 431 for (const layer of layers) { 432 if (this.layers.length === 5) { 433 throw new Error('Unable to add layer: this lambda function already uses 5 layers.'); 434 } 435 if (layer.compatibleRuntimes && !layer.compatibleRuntimes.find(runtime => runtime.runtimeEquals(this.runtime))) { 436 const runtimes = layer.compatibleRuntimes.map(runtime => runtime.name).join(', '); 437 throw new Error(`This lambda function uses a runtime that is incompatible with this layer (${this.runtime.name} is not in [${runtimes}])`); 438 } 439 // Currently no validations for compatible architectures since Lambda service 440 // allows layers configured with one architecture to be used with a Lambda function 441 // from another architecture. 442 this.layers.push(layer); 443 } 444 } 445 /** 446 * (deprecated) Add a new version for this Lambda. 447 * 448 * If you want to deploy through CloudFormation and use aliases, you need to 449 * add a new version (with a new name) to your Lambda every time you want to 450 * deploy an update. An alias can then refer to the newly created Version. 451 * 452 * All versions should have distinct names, and you should not delete versions 453 * as long as your Alias needs to refer to them. 454 * 455 * @param name A unique name for this version. 456 * @param codeSha256 The SHA-256 hash of the most recently deployed Lambda source code, or omit to skip validation. 457 * @param description A description for this version. 458 * @param provisionedExecutions A provisioned concurrency configuration for a function's version. 459 * @param asyncInvokeConfig configuration for this version when it is invoked asynchronously. 460 * @returns A new Version object. 461 * @deprecated This method will create an AWS::Lambda::Version resource which 462 * snapshots the AWS Lambda function *at the time of its creation* and it 463 * won't get updated when the function changes. Instead, use 464 * `this.currentVersion` to obtain a reference to a version resource that gets 465 * automatically recreated when the function configuration (or code) changes. 466 */ 467 addVersion(name, codeSha256, description, provisionedExecutions, asyncInvokeConfig = {}) { 468 jsiiDeprecationWarnings.print("@aws-cdk/aws-lambda.Function#addVersion", "This method will create an AWS::Lambda::Version resource which\nsnapshots the AWS Lambda function *at the time of its creation* and it\nwon't get updated when the function changes. Instead, use\n`this.currentVersion` to obtain a reference to a version resource that gets\nautomatically recreated when the function configuration (or code) changes."); 469 jsiiDeprecationWarnings._aws_cdk_aws_lambda_EventInvokeConfigOptions(asyncInvokeConfig); 470 return new lambda_version_1.Version(this, 'Version' + name, { 471 lambda: this, 472 codeSha256, 473 description, 474 provisionedConcurrentExecutions: provisionedExecutions, 475 ...asyncInvokeConfig, 476 }); 477 } 478 /** 479 * The LogGroup where the Lambda function's logs are made available. 480 * 481 * If either `logRetention` is set or this property is called, a CloudFormation custom resource is added to the stack that 482 * pre-creates the log group as part of the stack deployment, if it already doesn't exist, and sets the correct log retention 483 * period (never expire, by default). 484 * 485 * Further, if the log group already exists and the `logRetention` is not set, the custom resource will reset the log retention 486 * to never expire even if it was configured with a different value. 487 * 488 * @stability stable 489 */ 490 get logGroup() { 491 if (!this._logGroup) { 492 const logRetention = new logs.LogRetention(this, 'LogRetention', { 493 logGroupName: `/aws/lambda/${this.functionName}`, 494 retention: logs.RetentionDays.INFINITE, 495 }); 496 this._logGroup = logs.LogGroup.fromLogGroupArn(this, `${this.node.id}-LogGroup`, logRetention.logGroupArn); 497 } 498 return this._logGroup; 499 } 500 /** @internal */ 501 _checkEdgeCompatibility() { 502 // Check env vars 503 const envEntries = Object.entries(this.environment); 504 for (const [key, config] of envEntries) { 505 if (config.removeInEdge) { 506 delete this.environment[key]; 507 core_1.Annotations.of(this).addInfo(`Removed ${key} environment variable for Lambda@Edge compatibility`); 508 } 509 } 510 const envKeys = Object.keys(this.environment); 511 if (envKeys.length !== 0) { 512 throw new Error(`The function ${this.node.path} contains environment variables [${envKeys}] and is not compatible with Lambda@Edge. \ 513 Environment variables can be marked for removal when used in Lambda@Edge by setting the \'removeInEdge\' property in the \'addEnvironment()\' API.`); 514 } 515 return; 516 } 517 /** 518 * Configured lambda insights on the function if specified. This is acheived by adding an imported layer which is added to the 519 * list of lambda layers on synthesis. 520 * 521 * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Lambda-Insights-extension-versions.html 522 */ 523 configureLambdaInsights(props) { 524 var _b; 525 if (props.insightsVersion === undefined) { 526 return; 527 } 528 if (props.runtime !== runtime_1.Runtime.FROM_IMAGE) { 529 // Layers cannot be added to Lambda container images. The image should have the insights agent installed. 530 // See https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Lambda-Insights-Getting-Started-docker.html 531 this.addLayers(layers_1.LayerVersion.fromLayerVersionArn(this, 'LambdaInsightsLayer', props.insightsVersion.layerVersionArn)); 532 } 533 (_b = this.role) === null || _b === void 0 ? void 0 : _b.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchLambdaInsightsExecutionRolePolicy')); 534 } 535 renderEnvironment() { 536 if (!this.environment || Object.keys(this.environment).length === 0) { 537 return undefined; 538 } 539 const variables = {}; 540 // Sort environment so the hash of the function used to create 541 // `currentVersion` is not affected by key order (this is how lambda does 542 // it). For backwards compatibility we do not sort environment variables in case 543 // _currentVersion is not defined. Otherwise, this would have invalidated 544 // the template, and for example, may cause unneeded updates for nested 545 // stacks. 546 const keys = this._currentVersion 547 ? Object.keys(this.environment).sort() 548 : Object.keys(this.environment); 549 for (const key of keys) { 550 variables[key] = this.environment[key].value; 551 } 552 return { variables }; 553 } 554 /** 555 * If configured, set up the VPC-related properties 556 * 557 * Returns the VpcConfig that should be added to the 558 * Lambda creation properties. 559 */ 560 configureVpc(props) { 561 var _b; 562 if ((props.securityGroup || props.allowAllOutbound !== undefined) && !props.vpc) { 563 throw new Error('Cannot configure \'securityGroup\' or \'allowAllOutbound\' without configuring a VPC'); 564 } 565 if (!props.vpc) { 566 return undefined; 567 } 568 if (props.securityGroup && props.allowAllOutbound !== undefined) { 569 throw new Error('Configure \'allowAllOutbound\' directly on the supplied SecurityGroup.'); 570 } 571 let securityGroups; 572 if (props.securityGroup && props.securityGroups) { 573 throw new Error('Only one of the function props, securityGroup or securityGroups, is allowed'); 574 } 575 if (props.securityGroups) { 576 securityGroups = props.securityGroups; 577 } 578 else { 579 const securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', { 580 vpc: props.vpc, 581 description: 'Automatic security group for Lambda Function ' + core_1.Names.uniqueId(this), 582 allowAllOutbound: props.allowAllOutbound, 583 }); 584 securityGroups = [securityGroup]; 585 } 586 this._connections = new ec2.Connections({ securityGroups }); 587 if (props.filesystem) { 588 if (props.filesystem.config.connections) { 589 props.filesystem.config.connections.allowDefaultPortFrom(this); 590 } 591 } 592 const allowPublicSubnet = (_b = props.allowPublicSubnet) !== null && _b !== void 0 ? _b : false; 593 const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets); 594 const publicSubnetIds = new Set(props.vpc.publicSubnets.map(s => s.subnetId)); 595 for (const subnetId of subnetIds) { 596 if (publicSubnetIds.has(subnetId) && !allowPublicSubnet) { 597 throw new Error('Lambda Functions in a public subnet can NOT access the internet. ' + 598 'If you are aware of this limitation and would still like to place the function int a public subnet, set `allowPublicSubnet` to true'); 599 } 600 } 601 // List can't be empty here, if we got this far you intended to put your Lambda 602 // in subnets. We're going to guarantee that we get the nice error message by 603 // making VpcNetwork do the selection again. 604 return { 605 subnetIds, 606 securityGroupIds: securityGroups.map(sg => sg.securityGroupId), 607 }; 608 } 609 buildDeadLetterQueue(props) { 610 if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) { 611 throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false'); 612 } 613 if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) { 614 return undefined; 615 } 616 const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', { 617 retentionPeriod: core_1.Duration.days(14), 618 }); 619 this.addToRolePolicy(new iam.PolicyStatement({ 620 actions: ['sqs:SendMessage'], 621 resources: [deadLetterQueue.queueArn], 622 })); 623 return deadLetterQueue; 624 } 625 buildDeadLetterConfig(deadLetterQueue) { 626 if (deadLetterQueue) { 627 return { 628 targetArn: deadLetterQueue.queueArn, 629 }; 630 } 631 else { 632 return undefined; 633 } 634 } 635 buildTracingConfig(props) { 636 if (props.tracing === undefined || props.tracing === Tracing.DISABLED) { 637 return undefined; 638 } 639 this.addToRolePolicy(new iam.PolicyStatement({ 640 actions: ['xray:PutTraceSegments', 'xray:PutTelemetryRecords'], 641 resources: ['*'], 642 })); 643 return { 644 mode: props.tracing, 645 }; 646 } 647 validateProfiling(props) { 648 if (!props.runtime.supportsCodeGuruProfiling) { 649 throw new Error(`CodeGuru profiling is not supported by runtime ${props.runtime.name}`); 650 } 651 if (props.environment && (props.environment.AWS_CODEGURU_PROFILER_GROUP_ARN || props.environment.AWS_CODEGURU_PROFILER_ENABLED)) { 652 throw new Error('AWS_CODEGURU_PROFILER_GROUP_ARN and AWS_CODEGURU_PROFILER_ENABLED must not be set when profiling options enabled'); 653 } 654 } 655 } 656 exports.Function = Function; 657 _a = JSII_RTTI_SYMBOL_1; 658 Function[_a] = { fqn: "@aws-cdk/aws-lambda.Function", version: "1.134.0" }; 659 /** @internal */ 660 Function._VER_PROPS = {}; 661 /** 662 * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function 663 * name from the ARN. 664 * 665 * Function ARNs look like this: 666 * 667 * arn:aws:lambda:region:account-id:function:function-name 668 * 669 * ..which means that in order to extract the `function-name` component from the ARN, we can 670 * split the ARN using ":" and select the component in index 6. 671 * 672 * @returns `FnSelect(6, FnSplit(':', arn))` 673 */ 674 function extractNameFromArn(arn) { 675 return core_1.Fn.select(6, core_1.Fn.split(':', arn)); 676 } 677 function verifyCodeConfig(code, props) { 678 // mutually exclusive 679 const codeType = [code.inlineCode, code.s3Location, code.image]; 680 if (codeType.filter(x => !!x).length !== 1) { 681 throw new Error('lambda.Code must specify exactly one of: "inlineCode", "s3Location", or "image"'); 682 } 683 if (!!code.image === (props.handler !== handler_1.Handler.FROM_IMAGE)) { 684 throw new Error('handler must be `Handler.FROM_IMAGE` when using image asset for Lambda function'); 685 } 686 if (!!code.image === (props.runtime !== runtime_1.Runtime.FROM_IMAGE)) { 687 throw new Error('runtime must be `Runtime.FROM_IMAGE` when using image asset for Lambda function'); 688 } 689 // if this is inline code, check that the runtime supports 690 if (code.inlineCode && !props.runtime.supportsInlineCode) { 691 throw new Error(`Inline source not allowed for ${props.runtime.name}`); 692 } 693 } 694 exports.verifyCodeConfig = verifyCodeConfig; 695 function undefinedIfNoKeys(struct) { 696 const allUndefined = Object.values(struct).every(val => val === undefined); 697 return allUndefined ? undefined : struct; 698 } 699 //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"function.js","sourceRoot":"","sources":["function.ts"],"names":[],"mappings":";;;;;;AAAA,sDAAsD;AACtD,wEAAiG;AACjG,wCAAwC;AACxC,wCAAwC;AAExC,0CAA0C;AAC1C,wCAAwC;AACxC,wCAAsG;AAQtG,mDAA8E;AAC9E,mDAAuE;AACvE,uCAAoC;AAEpC,qDAA2D;AAC3D,yDAAiD;AACjD,qCAAuD;AACvD,uCAAoC;;;;;;AAOpC,IAAY,OAOX;AAPD,WAAY,OAAO;IAEjB,4BAAiB,CAAA;IAEjB,uCAA4B,CAAA;IAE5B,gCAAqB,CAAA;AACvB,CAAC,EAPW,OAAO,GAAP,eAAO,KAAP,eAAO,QAOlB;;;;;;;;;;;;;;AA8GD,MAAa,QAAS,SAAQ,4BAAY;;;;IA+JxC,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAoB;;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,CAAC,YAAY;SACjC,CAAC,CAAC;;;;;;QApBW,oBAAe,GAAG,IAAI,CAAC,IAAI,CAAC;;;;;;;;;QAGzB,yBAAoB,GAAG,IAAI,CAAC;QAE9B,WAAM,GAAoB,EAAE,CAAC;QAI9C;;WAEG;QACK,gBAAW,GAAyC,EAAE,CAAC;;QAU7D,MAAM,eAAe,GAAG,IAAI,KAAK,EAAsB,CAAC;QAExD,+FAA+F;QAC/F,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,0CAA0C,CAAC,CAAC,CAAC;QAE7G,IAAI,KAAK,CAAC,GAAG,EAAE;YACb,iDAAiD;YACjD,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,8CAA8C,CAAC,CAAC,CAAC;SAClH;QAED,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,aAAa,EAAE;YAC1D,SAAS,EAAE,IAAI,GAAG,CAAC,gBAAgB,CAAC,sBAAsB,CAAC;YAC3D,eAAe;SAChB,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC;QAEhC,iDAAiD;QACjD,IAAI,KAAK,CAAC,UAAU,EAAE;YACpB,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;YACvC,IAAI,MAAM,CAAC,QAAQ,EAAE;gBACnB,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;;oBAC1B,MAAA,IAAI,CAAC,IAAI,0CAAE,oBAAoB,CAAC,CAAC,EAAE;gBACrC,CAAC,CAAC,CAAC;aACJ;SACF;QAED,KAAK,MAAM,SAAS,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,EAAE,CAAC,EAAE;YACnD,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;SAC3C;QAED,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnC,gBAAgB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAE9B,IAAI,kCAAkC,GAA8B,EAAE,CAAC;QACvE,IAAI,KAAK,CAAC,cAAc,IAAI,KAAK,CAAC,SAAS,KAAK,KAAK,EAAE;YACrD,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAC9B,KAAK,CAAC,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC7C,kCAAkC,GAAG;gBACnC,+BAA+B,EAAE,YAAK,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC;oBACzD,OAAO,EAAE,mBAAmB;oBAC5B,QAAQ,EAAE,gBAAgB;oBAC1B,YAAY,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB;iBACtD,CAAC;gBACF,6BAA6B,EAAE,MAAM;aACtC,CAAC;SACH;aAAM,IAAI,KAAK,CAAC,SAAS,EAAE;YAC1B,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;YAC9B,MAAM,cAAc,GAAG,IAAI,qCAAc,CAAC,IAAI,EAAE,gBAAgB,EAAE;gBAChE,eAAe,EAAE,sCAAe,CAAC,UAAU;aAC5C,CAAC,CAAC;YACH,cAAc,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACvC,kCAAkC,GAAG;gBACnC,+BAA+B,EAAE,cAAc,CAAC,iBAAiB;gBACjE,6BAA6B,EAAE,MAAM;aACtC,CAAC;SACH;QAED,MAAM,GAAG,GAAG,EAAE,GAAG,kCAAkC,EAAE,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;QAC5E,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YAC9C,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACjC;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAExD,IAAI,iBAAiB,GAAuD,SAAS,CAAC;QACtF,IAAI,KAAK,CAAC,UAAU,EAAE;YACpB,iBAAiB,GAAG,CAAC;oBACnB,GAAG,EAAE,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG;oBAChC,cAAc,EAAE,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,cAAc;iBACvD,CAAC,CAAC;SACJ;QAED,IAAI,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,EAAE;YAC3D,MAAM,IAAI,KAAK,CAAC,sEAAsE,CAAC,CAAC;SACzF;QACD,IAAI,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACzD,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;SAC7D;QACD,MAAM,YAAY,SAAG,KAAK,CAAC,YAAY,mCAAI,CAAC,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3F,MAAM,QAAQ,GAAgB,IAAI,8BAAW,CAAC,IAAI,EAAE,UAAU,EAAE;YAC9D,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,WAAW,EAAE,KAAK,CAAC,WAAW;YAC9B,IAAI,EAAE;gBACJ,QAAQ,EAAE,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU;gBACvD,KAAK,EAAE,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS;gBACnD,eAAe,EAAE,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa;gBACjE,OAAO,EAAE,IAAI,CAAC,UAAU;gBACxB,QAAQ,QAAE,IAAI,CAAC,KAAK,0CAAE,QAAQ;aAC/B;YACD,MAAM,EAAE,WAAI,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,eAAe,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;YAC1G,OAAO,EAAE,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO;YACzE,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,EAAE;YACnD,WAAW,EAAE,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;YACvE,OAAO,EAAE,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI;YAC9E,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,OAAO;YACvB,kGAAkG;YAClG,oDAAoD;YACpD,WAAW,EAAE,WAAI,CAAC,WAAW,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;YAC1E,UAAU,EAAE,KAAK,CAAC,UAAU;YAC5B,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC;YACnC,gBAAgB,EAAE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,eAAe,CAAC;YAClE,aAAa,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC;YAC7C,4BAA4B,EAAE,KAAK,CAAC,4BAA4B;YAChE,WAAW,EAAE,iBAAiB,CAAC;gBAC7B,OAAO,QAAE,IAAI,CAAC,KAAK,0CAAE,GAAG;gBACxB,UAAU,QAAE,IAAI,CAAC,KAAK,0CAAE,UAAU;gBAClC,gBAAgB,QAAE,IAAI,CAAC,KAAK,0CAAE,gBAAgB;aAC/C,CAAC;YACF,SAAS,QAAE,KAAK,CAAC,qBAAqB,0CAAE,MAAM;YAC9C,iBAAiB;YACjB,oBAAoB,QAAE,KAAK,CAAC,iBAAiB,0CAAE,oBAAoB;YACnE,aAAa,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;SAC9D,CAAC,CAAC;QAEH,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAEvC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAChE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,uBAAuB,CAAC,QAAQ,CAAC,OAAO,EAAE;YAChE,OAAO,EAAE,QAAQ;YACjB,QAAQ,EAAE,UAAU;YACpB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,SAAS,EAAE,gBAAS,CAAC,mBAAmB;SACzC,CAAC,CAAC;QAEH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAE7B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;QAEvC,IAAI,KAAK,CAAC,MAAM,EAAE;YAChB,IAAI,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,EAAE;gBACxC,MAAM,IAAI,KAAK,CAAC,wDAAwD,CAAC,CAAC;aAC3E;YAED,IAAI,CAAC,SAAS,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC;SACjC;QAED,KAAK,MAAM,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,EAAE,EAAE;YACtC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SAC5B;QAED,gBAAgB;QAChB,IAAI,KAAK,CAAC,YAAY,EAAE;YACtB,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,cAAc,EAAE;gBAC/D,YAAY,EAAE,eAAe,IAAI,CAAC,YAAY,EAAE;gBAChD,SAAS,EAAE,KAAK,CAAC,YAAY;gBAC7B,IAAI,EAAE,KAAK,CAAC,gBAAgB;gBAC5B,wBAAwB,EAAE,KAAK,CAAC,wBAAyD;aAC1F,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC;SAC5F;QAED,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAEpC,sBAAsB;QACtB,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,aAAa,KAAK,SAAS,EAAE;YAChG,IAAI,CAAC,oBAAoB,CAAC;gBACxB,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,aAAa,EAAE,KAAK,CAAC,aAAa;aACnC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC,qBAAqB,CAAC;QAEzD,IAAI,KAAK,CAAC,UAAU,EAAE;YACpB,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE;gBACd,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;aAC/E;YACD,MAAM,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC;YACvC,IAAI,MAAM,CAAC,UAAU,EAAE;gBACrB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;aAC/C;YACD,oGAAoG;YACpG,0GAA0G;YAC1G,wEAAwE;YACxE,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAC3C,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBAChC,IAAI,KAAK,YAAY,kBAAW,IAAI,KAAK,CAAC,eAAe,KAAK,+BAA+B,EAAE;wBAC7F,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;qBACpC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,MAAA,MAAM,CAAC,WAAW,0CAAE,cAAc,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;gBAC9C,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBAChC,IAAI,KAAK,YAAY,kBAAW,IAAI,KAAK,CAAC,eAAe,KAAK,gCAAgC,EAAE;wBAC9F,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;qBACpC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,EAAE;SACJ;QAED,4BAA4B;QAC5B,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;KACrC;;;;;;;;;IApWD,IAAW,cAAc;QACvB,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,OAAO,IAAI,CAAC,eAAe,CAAC;SAC7B;QAED,IAAI,CAAC,eAAe,GAAG,IAAI,wBAAO,CAAC,IAAI,EAAE,gBAAgB,EAAE;YACzD,MAAM,EAAE,IAAI;YACZ,GAAG,IAAI,CAAC,qBAAqB;SAC9B,CAAC,CAAC;QAEH,0EAA0E;QAC1E,yEAAyE;QACzE,sCAAsC;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAA2B,CAAC;QAClE,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAW,CAAC;QAEtE,GAAG,CAAC,iBAAiB,CAAC,WAAI,CAAC,cAAc,CAAC;YACxC,OAAO,EAAE,GAAG,EAAE;gBACZ,MAAM,IAAI,GAAG,qCAAqB,CAAC,IAAI,CAAC,CAAC;gBACzC,MAAM,SAAS,GAAG,6BAAa,CAAC,iBAAiB,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC;gBAC7D,OAAO,GAAG,SAAS,GAAG,IAAI,EAAE,CAAC;YAC/B,CAAC;SACF,CAAC,CAAC,CAAC;QAEJ,OAAO,IAAI,CAAC,eAAe,CAAC;KAC7B;;;;;;;;;;IAMM,MAAM,CAAC,uBAAuB,CAAC,YAAoB,EAAE,MAAe;QACzE,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,GAAG,MAAM,CAAC;KACxC;;;;;;IAGM,MAAM,CAAC,eAAe,CAAC,KAAgB,EAAE,EAAU,EAAE,WAAmB;QAC7E,OAAO,QAAQ,CAAC,sBAAsB,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;KACpE;;;;;;;;;IAGM,MAAM,CAAC,sBAAsB,CAAC,KAAgB,EAAE,EAAU,EAAE,KAAyB;;QAC1F,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACtC,MAAM,YAAY,GAAG,kBAAkB,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;QAC3D,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QAExB,MAAM,MAAO,SAAQ,4BAAY;YAS/B,YAAY,CAAY,EAAE,CAAS;;gBACjC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;gBATE,iBAAY,GAAG,YAAY,CAAC;gBAC5B,gBAAW,GAAG,WAAW,CAAC;gBAE1B,SAAI,GAAG,IAAI,CAAC;gBACZ,oBAAe,GAAG,IAAI,CAAC,IAAI,CAAC;gBAEzB,yBAAoB,SAAG,KAAK,CAAC,eAAe,mCAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBAKxF,IAAI,CAAC,cAAc,GAAG,IAAI,IAAI,IAAI,GAAG,CAAC,gBAAgB,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;gBAE3E,IAAI,KAAK,CAAC,aAAa,EAAE;oBACvB,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC;wBACtC,cAAc,EAAE,CAAC,KAAK,CAAC,aAAa,CAAC;qBACtC,CAAC,CAAC;iBACJ;qBAAM,IAAI,KAAK,CAAC,eAAe,EAAE;oBAChC,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC;wBACtC,cAAc,EAAE,CAAC,GAAG,CAAC,aAAa,CAAC,mBAAmB,CAAC,KAAK,EAAE,eAAe,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC;qBACvG,CAAC,CAAC;iBACJ;YACH,CAAC;SACF;QAED,OAAO,IAAI,MAAM,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KAC9B;;;;;;IAGM,MAAM,CAAC,SAAS,CAAC,UAAkB,EAAE,KAAgC;QAC1E,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC;YAC3B,SAAS,EAAE,YAAY;YACvB,UAAU;YACV,GAAG,KAAK;SACT,CAAC,CAAC;KACJ;;;;;;;IAEM,MAAM,CAAC,eAAe,CAAC,KAAgC;QAC5D,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;KACjE;;;;;;;IAGM,MAAM,CAAC,iBAAiB,CAAC,KAAgC;QAC9D,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC;KAC1C;;;;;;;IAGM,MAAM,CAAC,oBAAoB,CAAC,KAAgC;QACjE,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;KACtE;;;;;;;IAGM,MAAM,CAAC,kBAAkB,CAAC,KAAgC;QAC/D,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;KACpE;;;;;;;IAGM,MAAM,CAAC,6BAA6B,CAAC,KAAgC;QAC1E,kEAAkE;QAClE,mEAAmE;QACnE,iEAAiE;QACjE,sEAAsE;QACtE,kEAAkE;QAClE,uCAAuC;QACvC,OAAO,IAAI,CAAC,SAAS,CAAC,sBAAsB,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;KAC/E;;;;;;;IAGM,MAAM,CAAC,uCAAuC,CAAC,KAAgC;QACpF,OAAO,IAAI,CAAC,SAAS,CAAC,gCAAgC,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,CAAC,CAAC;KACzF;;;;;;;;;;;IAkPM,cAAc,CAAC,GAAW,EAAE,KAAa,EAAE,OAA4B;;QAC5E,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC;QAC9C,OAAO,IAAI,CAAC;KACb;;;;;;;;IAGM,SAAS,CAAC,GAAG,MAAuB;;QACzC,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;YAC1B,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC5B,MAAM,IAAI,KAAK,CAAC,kEAAkE,CAAC,CAAC;aACrF;YACD,IAAI,KAAK,CAAC,kBAAkB,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EAAE;gBAC9G,MAAM,QAAQ,GAAG,KAAK,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClF,MAAM,IAAI,KAAK,CAAC,6EAA6E,IAAI,CAAC,OAAO,CAAC,IAAI,eAAe,QAAQ,IAAI,CAAC,CAAC;aAC5I;YAED,6EAA6E;YAC7E,mFAAmF;YACnF,6BAA6B;YAE7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACzB;KACF;;;;;;;;;;;;;;;;;;;;;;;IAGM,UAAU,CACf,IAAY,EACZ,UAAmB,EACnB,WAAoB,EACpB,qBAA8B,EAC9B,oBAA8C,EAAE;;;QAEhD,OAAO,IAAI,wBAAO,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,EAAE;YACzC,MAAM,EAAE,IAAI;YACZ,UAAU;YACV,WAAW;YACX,+BAA+B,EAAE,qBAAqB;YACtD,GAAG,iBAAiB;SACrB,CAAC,CAAC;KACJ;;;;;;;;;;;;;IAGD,IAAW,QAAQ;QACjB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,cAAc,EAAE;gBAC/D,YAAY,EAAE,eAAe,IAAI,CAAC,YAAY,EAAE;gBAChD,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;aACvC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,YAAY,CAAC,WAAW,CAAC,CAAC;SAC5G;QACD,OAAO,IAAI,CAAC,SAAS,CAAC;KACvB;IAED,gBAAgB;IACT,uBAAuB;QAC5B,iBAAiB;QACjB,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpD,KAAK,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,IAAI,UAAU,EAAE;YACtC,IAAI,MAAM,CAAC,YAAY,EAAE;gBACvB,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;gBAC7B,kBAAW,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,qDAAqD,CAAC,CAAC;aACnG;SACF;QACD,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC9C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,IAAI,oCAAoC,OAAO;mJACoD,CAAC,CAAC;SAChJ;QAED,OAAO;KACR;IAED;;;;;OAKG;IACK,uBAAuB,CAAC,KAAoB;;QAClD,IAAI,KAAK,CAAC,eAAe,KAAK,SAAS,EAAE;YACvC,OAAO;SACR;QACD,IAAI,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,EAAE;YACxC,yGAAyG;YACzG,iHAAiH;YACjH,IAAI,CAAC,SAAS,CAAC,qBAAY,CAAC,mBAAmB,CAAC,IAAI,EAAE,qBAAqB,EAAE,KAAK,CAAC,eAAe,CAAC,eAAe,CAAC,CAAC,CAAC;SACtH;QACD,MAAA,IAAI,CAAC,IAAI,0CAAE,gBAAgB,CAAC,GAAG,CAAC,aAAa,CAAC,wBAAwB,CAAC,6CAA6C,CAAC,EAAE;KACxH;IAEO,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;YACnE,OAAO,SAAS,CAAC;SAClB;QAED,MAAM,SAAS,GAA8B,EAAE,CAAC;QAChD,8DAA8D;QAC9D,yEAAyE;QACzE,gFAAgF;QAChF,yEAAyE;QACzE,uEAAuE;QACvE,UAAU;QACV,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe;YAC/B,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE;YACtC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAElC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE;YACtB,SAAS,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;SAC9C;QAED,OAAO,EAAE,SAAS,EAAE,CAAC;KACtB;IAED;;;;;OAKG;IACK,YAAY,CAAC,KAAoB;;QACvC,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,gBAAgB,KAAK,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE;YAC/E,MAAM,IAAI,KAAK,CAAC,sFAAsF,CAAC,CAAC;SACzG;QAED,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE;YAAE,OAAO,SAAS,CAAC;SAAE;QAErC,IAAI,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,gBAAgB,KAAK,SAAS,EAAE;YAC/D,MAAM,IAAI,KAAK,CAAC,wEAAwE,CAAC,CAAC;SAC3F;QAED,IAAI,cAAoC,CAAC;QAEzC,IAAI,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,cAAc,EAAE;YAC/C,MAAM,IAAI,KAAK,CAAC,6EAA6E,CAAC,CAAC;SAChG;QAED,IAAI,KAAK,CAAC,cAAc,EAAE;YACxB,cAAc,GAAG,KAAK,CAAC,cAAc,CAAC;SACvC;aAAM;YACL,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,IAAI,IAAI,GAAG,CAAC,aAAa,CAAC,IAAI,EAAE,eAAe,EAAE;gBACxF,GAAG,EAAE,KAAK,CAAC,GAAG;gBACd,WAAW,EAAE,+CAA+C,GAAG,YAAK,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACnF,gBAAgB,EAAE,KAAK,CAAC,gBAAgB;aACzC,CAAC,CAAC;YACH,cAAc,GAAG,CAAC,aAAa,CAAC,CAAC;SAClC;QAED,IAAI,CAAC,YAAY,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,EAAE,cAAc,EAAE,CAAC,CAAC;QAE5D,IAAI,KAAK,CAAC,UAAU,EAAE;YACpB,IAAI,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,EAAE;gBACvC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,WAAW,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;aAChE;SACF;QAED,MAAM,iBAAiB,SAAG,KAAK,CAAC,iBAAiB,mCAAI,KAAK,CAAC;QAC3D,MAAM,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAChE,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC9E,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;YAChC,IAAI,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBACvD,MAAM,IAAI,KAAK,CAAC,mEAAmE;oBACjF,qIAAqI,CAAC,CAAC;aAC1I;SACF;QAED,+EAA+E;QAC/E,6EAA6E;QAC7E,4CAA4C;QAE5C,OAAO;YACL,SAAS;YACT,gBAAgB,EAAE,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,eAAe,CAAC;SAC/D,CAAC;KACH;IAEO,oBAAoB,CAAC,KAAoB;QAC/C,IAAI,KAAK,CAAC,eAAe,IAAI,KAAK,CAAC,sBAAsB,KAAK,KAAK,EAAE;YACnE,MAAM,KAAK,CAAC,4EAA4E,CAAC,CAAC;SAC3F;QAED,IAAI,CAAC,KAAK,CAAC,eAAe,IAAI,CAAC,KAAK,CAAC,sBAAsB,EAAE;YAC3D,OAAO,SAAS,CAAC;SAClB;QAED,MAAM,eAAe,GAAG,KAAK,CAAC,eAAe,IAAI,IAAI,GAAG,CAAC,KAAK,CAAC,IAAI,EAAE,iBAAiB,EAAE;YACtF,eAAe,EAAE,eAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;SACnC,CAAC,CAAC;QAEH,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC;YAC3C,OAAO,EAAE,CAAC,iBAAiB,CAAC;YAC5B,SAAS,EAAE,CAAC,eAAe,CAAC,QAAQ,CAAC;SACtC,CAAC,CAAC,CAAC;QAEJ,OAAO,eAAe,CAAC;KACxB;IAEO,qBAAqB,CAAC,eAA4B;QACxD,IAAI,eAAe,EAAE;YACnB,OAAO;gBACL,SAAS,EAAE,eAAe,CAAC,QAAQ;aACpC,CAAC;SACH;aAAM;YACL,OAAO,SAAS,CAAC;SAClB;KACF;IAEO,kBAAkB,CAAC,KAAoB;QAC7C,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,CAAC,QAAQ,EAAE;YACrE,OAAO,SAAS,CAAC;SAClB;QAED,IAAI,CAAC,eAAe,CAAC,IAAI,GAAG,CAAC,eAAe,CAAC;YAC3C,OAAO,EAAE,CAAC,uBAAuB,EAAE,0BAA0B,CAAC;YAC9D,SAAS,EAAE,CAAC,GAAG,CAAC;SACjB,CAAC,CAAC,CAAC;QAEJ,OAAO;YACL,IAAI,EAAE,KAAK,CAAC,OAAO;SACpB,CAAC;KACH;IAEO,iBAAiB,CAAC,KAAoB;QAC5C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,yBAAyB,EAAE;YAC5C,MAAM,IAAI,KAAK,CAAC,kDAAkD,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;SACzF;QACD,IAAI,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,+BAA+B,IAAI,KAAK,CAAC,WAAW,CAAC,6BAA6B,CAAC,EAAE;YAC/H,MAAM,IAAI,KAAK,CAAC,kHAAkH,CAAC,CAAC;SACrI;KACF;;AA9kBH,4BA+kBC;;;AAjjBC,gBAAgB;AACF,mBAAU,GAA+B,EAAE,CAAC;AA+jB5D;;;;;;;;;;;;GAYG;AACH,SAAS,kBAAkB,CAAC,GAAW;IACrC,OAAO,SAAE,CAAC,MAAM,CAAC,CAAC,EAAE,SAAE,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAC1C,CAAC;AAED,SAAgB,gBAAgB,CAAC,IAAgB,EAAE,KAAoB;IACrE,qBAAqB;IACrB,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAEhE,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,EAAE;QAC1C,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;KACpG;IAED,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,CAAC,EAAE;QAC3D,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;KACpG;IAED,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,OAAO,KAAK,iBAAO,CAAC,UAAU,CAAC,EAAE;QAC3D,MAAM,IAAI,KAAK,CAAC,iFAAiF,CAAC,CAAC;KACpG;IAED,0DAA0D;IAC1D,IAAI,IAAI,CAAC,UAAU,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,kBAAkB,EAAE;QACxD,MAAM,IAAI,KAAK,CAAC,iCAAiC,KAAK,CAAC,OAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;KACzE;AACH,CAAC;AApBD,4CAoBC;AAED,SAAS,iBAAiB,CAAI,MAAS;IACrC,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC;IAC3E,OAAO,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC;AAC3C,CAAC","sourcesContent":["import * as cloudwatch from '@aws-cdk/aws-cloudwatch';\nimport { IProfilingGroup, ProfilingGroup, ComputePlatform } from '@aws-cdk/aws-codeguruprofiler';\nimport * as ec2 from '@aws-cdk/aws-ec2';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as kms from '@aws-cdk/aws-kms';\nimport * as logs from '@aws-cdk/aws-logs';\nimport * as sqs from '@aws-cdk/aws-sqs';\nimport { Annotations, ArnFormat, CfnResource, Duration, Fn, Lazy, Names, Stack } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { Architecture } from './architecture';\nimport { Code, CodeConfig } from './code';\nimport { ICodeSigningConfig } from './code-signing-config';\nimport { EventInvokeConfigOptions } from './event-invoke-config';\nimport { IEventSource } from './event-source';\nimport { FileSystem } from './filesystem';\nimport { FunctionAttributes, FunctionBase, IFunction } from './function-base';\nimport { calculateFunctionHash, trimFromStart } from './function-hash';\nimport { Handler } from './handler';\nimport { LambdaInsightsVersion } from './lambda-insights';\nimport { Version, VersionOptions } from './lambda-version';\nimport { CfnFunction } from './lambda.generated';\nimport { LayerVersion, ILayerVersion } from './layers';\nimport { Runtime } from './runtime';\n\n// keep this import separate from other imports to reduce chance for merge conflicts with v2-main\n// eslint-disable-next-line\nimport { LogRetentionRetryOptions } from './log-retention';\n\n                                                                                                    \nexport enum Tracing {\n                                                                                                                                                                                   \n  ACTIVE = 'Active',\n                                                                                                                                  \n  PASS_THROUGH = 'PassThrough',\n                                                   \n  DISABLED = 'Disabled'\n}\n\n                              \nexport interface FunctionOptions extends EventInvokeConfigOptions {\n                                                                                    \n  readonly description?: string;\n\n                                                                                                                                                                                                                                                               \n  readonly timeout?: Duration;\n\n                                                                                                                                                                                                                                                                                                                                     \n  readonly environment?: { [key: string]: string };\n\n                                                                                                                                                                                                    \n  readonly functionName?: string;\n\n                                                                                                                                                                                                                                                                                     \n  readonly memorySize?: number;\n\n                                                                                                                                                                                                                                                             \n  readonly initialPolicy?: iam.PolicyStatement[];\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            \n  readonly role?: iam.IRole;\n\n                                                                                                                                                                                                           \n  readonly vpc?: ec2.IVpc;\n\n                                                                                                                                                                                                                                                                                        \n  readonly vpcSubnets?: ec2.SubnetSelection;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \n  readonly securityGroup?: ec2.ISecurityGroup;\n\n                                                                                                                                                                                                                                                                                                                                                          \n  readonly securityGroups?: ec2.ISecurityGroup[];\n\n                                                                                                                                                                                                                           \n  readonly allowAllOutbound?: boolean;\n\n                                                                                                                                                                                                                                    \n  readonly deadLetterQueueEnabled?: boolean;\n\n                                                                                                                                                          \n  readonly deadLetterQueue?: sqs.IQueue;\n\n                                                                                                  \n  readonly tracing?: Tracing;\n\n                                                                                                                                                              \n  readonly profiling?: boolean;\n\n                                                                                                                                                                                                            \n  readonly profilingGroup?: IProfilingGroup;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               \n  readonly insightsVersion?: LambdaInsightsVersion;\n\n                                                                                                                                                                                                                                                                                                                                         \n  readonly layers?: ILayerVersion[];\n\n                                                                                                                                                                                                                                     \n  readonly reservedConcurrentExecutions?: number;\n\n                                                                                                                                                         \n  readonly events?: IEventSource[];\n\n                                                                                                                                                                                                                                                                                    \n  readonly logRetention?: logs.RetentionDays;\n\n                                                                                                                                                                          \n  readonly logRetentionRole?: iam.IRole;\n\n                                                                                                                                                                                                                                                       \n  readonly logRetentionRetryOptions?: LogRetentionRetryOptions;\n\n                                                                                                                                                                                         \n  readonly currentVersionOptions?: VersionOptions;\n\n                                                                                                                        \n  readonly filesystem?: FileSystem;\n\n                                                                                                                                                                                                                                                                                                                                                                         \n  readonly allowPublicSubnet?: boolean;\n\n                                                                                                                                                                                         \n  readonly environmentEncryption?: kms.IKey;\n\n                                                                                                         \n  readonly codeSigningConfig?: ICodeSigningConfig;\n\n                                                                                                   \n  readonly architectures?: Architecture[];\n\n                                                                                                                 \n  readonly architecture?: Architecture;\n}\n\nexport interface FunctionProps extends FunctionOptions {\n                                                                                                                                                                                                                                                                      \n  readonly runtime: Runtime;\n\n                                                                                                                                                                                              \n  readonly code: Code;\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      \n  readonly handler: string;\n}\n\n                                                                                                                                                                                                                                                                                                                                                           \nexport class Function extends FunctionBase {\n\n                                                                                                                                                                                                                                                                                                                                          \n  public get currentVersion(): Version {\n    if (this._currentVersion) {\n      return this._currentVersion;\n    }\n\n    this._currentVersion = new Version(this, 'CurrentVersion', {\n      lambda: this,\n      ...this.currentVersionOptions,\n    });\n\n    // override the version's logical ID with a lazy string which includes the\n    // hash of the function itself, so a new version resource is created when\n    // the function configuration changes.\n    const cfn = this._currentVersion.node.defaultChild as CfnResource;\n    const originalLogicalId = this.stack.resolve(cfn.logicalId) as string;\n\n    cfn.overrideLogicalId(Lazy.uncachedString({\n      produce: () => {\n        const hash = calculateFunctionHash(this);\n        const logicalId = trimFromStart(originalLogicalId, 255 - 32);\n        return `${logicalId}${hash}`;\n      },\n    }));\n\n    return this._currentVersion;\n  }\n\n  /** @internal */\n  public static _VER_PROPS: { [key: string]: boolean } = {};\n\n                                                                                                                                                                                                                                                                                                                                                                  \n  public static classifyVersionProperty(propertyName: string, locked: boolean) {\n    this._VER_PROPS[propertyName] = locked;\n  }\n\n                                                                    \n  public static fromFunctionArn(scope: Construct, id: string, functionArn: string): IFunction {\n    return Function.fromFunctionAttributes(scope, id, { functionArn });\n  }\n\n                                                                                                                                                                                                                                                                        \n  public static fromFunctionAttributes(scope: Construct, id: string, attrs: FunctionAttributes): IFunction {\n    const functionArn = attrs.functionArn;\n    const functionName = extractNameFromArn(attrs.functionArn);\n    const role = attrs.role;\n\n    class Import extends FunctionBase {\n      public readonly functionName = functionName;\n      public readonly functionArn = functionArn;\n      public readonly grantPrincipal: iam.IPrincipal;\n      public readonly role = role;\n      public readonly permissionsNode = this.node;\n\n      protected readonly canCreatePermissions = attrs.sameEnvironment ?? this._isStackAccount();\n\n      constructor(s: Construct, i: string) {\n        super(s, i);\n\n        this.grantPrincipal = role || new iam.UnknownPrincipal({ resource: this });\n\n        if (attrs.securityGroup) {\n          this._connections = new ec2.Connections({\n            securityGroups: [attrs.securityGroup],\n          });\n        } else if (attrs.securityGroupId) {\n          this._connections = new ec2.Connections({\n            securityGroups: [ec2.SecurityGroup.fromSecurityGroupId(scope, 'SecurityGroup', attrs.securityGroupId)],\n          });\n        }\n      }\n    }\n\n    return new Import(scope, id);\n  }\n\n                                                              \n  public static metricAll(metricName: string, props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return new cloudwatch.Metric({\n      namespace: 'AWS/Lambda',\n      metricName,\n      ...props,\n    });\n  }\n                                                                                                            \n  public static metricAllErrors(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metricAll('Errors', { statistic: 'sum', ...props });\n  }\n\n                                                                                                        \n  public static metricAllDuration(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metricAll('Duration', props);\n  }\n\n                                                                                                          \n  public static metricAllInvocations(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metricAll('Invocations', { statistic: 'sum', ...props });\n  }\n\n                                                                                                                    \n  public static metricAllThrottles(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metricAll('Throttles', { statistic: 'sum', ...props });\n  }\n\n                                                                                                                        \n  public static metricAllConcurrentExecutions(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    // Mini-FAQ: why max? This metric is a gauge that is emitted every\n    // minute, so either max or avg or a percentile make sense (but sum\n    // doesn't). Max is more sensitive to spiky load changes which is\n    // probably what you're interested in if you're looking at this metric\n    // (Load spikes may lead to concurrent execution errors that would\n    // otherwise not be visible in the avg)\n    return this.metricAll('ConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n                                                                                                                                   \n  public static metricAllUnreservedConcurrentExecutions(props?: cloudwatch.MetricOptions): cloudwatch.Metric {\n    return this.metricAll('UnreservedConcurrentExecutions', { statistic: 'max', ...props });\n  }\n\n                                      \n  public readonly functionName: string;\n\n                                     \n  public readonly functionArn: string;\n\n                                                             \n  public readonly role?: iam.IRole;\n\n                                                        \n  public readonly runtime: Runtime;\n\n                                                                 \n  public readonly grantPrincipal: iam.IPrincipal;\n\n                                                                                              \n  public readonly deadLetterQueue?: sqs.IQueue;\n\n                                                                                                                 \n  public readonly architecture?: Architecture;\n  public readonly permissionsNode = this.node;\n\n\n  protected readonly canCreatePermissions = true;\n\n  private readonly layers: ILayerVersion[] = [];\n\n  private _logGroup?: logs.ILogGroup;\n\n  /**\n   * Environment variables for this function\n   */\n  private environment: { [key: string]: EnvironmentConfig } = {};\n\n  private readonly currentVersionOptions?: VersionOptions;\n  private _currentVersion?: Version;\n\n  constructor(scope: Construct, id: string, props: FunctionProps) {\n    super(scope, id, {\n      physicalName: props.functionName,\n    });\n\n    const managedPolicies = new Array<iam.IManagedPolicy>();\n\n    // the arn is in the form of - arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole\n    managedPolicies.push(iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaBasicExecutionRole'));\n\n    if (props.vpc) {\n      // Policy that will have ENI creation permissions\n      managedPolicies.push(iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSLambdaVPCAccessExecutionRole'));\n    }\n\n    this.role = props.role || new iam.Role(this, 'ServiceRole', {\n      assumedBy: new iam.ServicePrincipal('lambda.amazonaws.com'),\n      managedPolicies,\n    });\n    this.grantPrincipal = this.role;\n\n    // add additional managed policies when necessary\n    if (props.filesystem) {\n      const config = props.filesystem.config;\n      if (config.policies) {\n        config.policies.forEach(p => {\n          this.role?.addToPrincipalPolicy(p);\n        });\n      }\n    }\n\n    for (const statement of (props.initialPolicy || [])) {\n      this.role.addToPrincipalPolicy(statement);\n    }\n\n    const code = props.code.bind(this);\n    verifyCodeConfig(code, props);\n\n    let profilingGroupEnvironmentVariables: { [key: string]: string } = {};\n    if (props.profilingGroup && props.profiling !== false) {\n      this.validateProfiling(props);\n      props.profilingGroup.grantPublish(this.role);\n      profilingGroupEnvironmentVariables = {\n        AWS_CODEGURU_PROFILER_GROUP_ARN: Stack.of(scope).formatArn({\n          service: 'codeguru-profiler',\n          resource: 'profilingGroup',\n          resourceName: props.profilingGroup.profilingGroupName,\n        }),\n        AWS_CODEGURU_PROFILER_ENABLED: 'TRUE',\n      };\n    } else if (props.profiling) {\n      this.validateProfiling(props);\n      const profilingGroup = new ProfilingGroup(this, 'ProfilingGroup', {\n        computePlatform: ComputePlatform.AWS_LAMBDA,\n      });\n      profilingGroup.grantPublish(this.role);\n      profilingGroupEnvironmentVariables = {\n        AWS_CODEGURU_PROFILER_GROUP_ARN: profilingGroup.profilingGroupArn,\n        AWS_CODEGURU_PROFILER_ENABLED: 'TRUE',\n      };\n    }\n\n    const env = { ...profilingGroupEnvironmentVariables, ...props.environment };\n    for (const [key, value] of Object.entries(env)) {\n      this.addEnvironment(key, value);\n    }\n\n    this.deadLetterQueue = this.buildDeadLetterQueue(props);\n\n    let fileSystemConfigs: CfnFunction.FileSystemConfigProperty[] | undefined = undefined;\n    if (props.filesystem) {\n      fileSystemConfigs = [{\n        arn: props.filesystem.config.arn,\n        localMountPath: props.filesystem.config.localMountPath,\n      }];\n    }\n\n    if (props.architecture && props.architectures !== undefined) {\n      throw new Error('Either architecture or architectures must be specified but not both.');\n    }\n    if (props.architectures && props.architectures.length > 1) {\n      throw new Error('Only one architecture must be specified.');\n    }\n    const architecture = props.architecture ?? (props.architectures && props.architectures[0]);\n\n    const resource: CfnFunction = new CfnFunction(this, 'Resource', {\n      functionName: this.physicalName,\n      description: props.description,\n      code: {\n        s3Bucket: code.s3Location && code.s3Location.bucketName,\n        s3Key: code.s3Location && code.s3Location.objectKey,\n        s3ObjectVersion: code.s3Location && code.s3Location.objectVersion,\n        zipFile: code.inlineCode,\n        imageUri: code.image?.imageUri,\n      },\n      layers: Lazy.list({ produce: () => this.layers.map(layer => layer.layerVersionArn) }, { omitEmpty: true }), // Evaluated on synthesis\n      handler: props.handler === Handler.FROM_IMAGE ? undefined : props.handler,\n      timeout: props.timeout && props.timeout.toSeconds(),\n      packageType: props.runtime === Runtime.FROM_IMAGE ? 'Image' : undefined,\n      runtime: props.runtime === Runtime.FROM_IMAGE ? undefined : props.runtime.name,\n      role: this.role.roleArn,\n      // Uncached because calling '_checkEdgeCompatibility', which gets called in the resolve of another\n      // Token, actually *modifies* the 'environment' map.\n      environment: Lazy.uncachedAny({ produce: () => this.renderEnvironment() }),\n      memorySize: props.memorySize,\n      vpcConfig: this.configureVpc(props),\n      deadLetterConfig: this.buildDeadLetterConfig(this.deadLetterQueue),\n      tracingConfig: this.buildTracingConfig(props),\n      reservedConcurrentExecutions: props.reservedConcurrentExecutions,\n      imageConfig: undefinedIfNoKeys({\n        command: code.image?.cmd,\n        entryPoint: code.image?.entrypoint,\n        workingDirectory: code.image?.workingDirectory,\n      }),\n      kmsKeyArn: props.environmentEncryption?.keyArn,\n      fileSystemConfigs,\n      codeSigningConfigArn: props.codeSigningConfig?.codeSigningConfigArn,\n      architectures: architecture ? [architecture.name] : undefined,\n    });\n\n    resource.node.addDependency(this.role);\n\n    this.functionName = this.getResourceNameAttribute(resource.ref);\n    this.functionArn = this.getResourceArnAttribute(resource.attrArn, {\n      service: 'lambda',\n      resource: 'function',\n      resourceName: this.physicalName,\n      arnFormat: ArnFormat.COLON_RESOURCE_NAME,\n    });\n\n    this.runtime = props.runtime;\n\n    this.architecture = props.architecture;\n\n    if (props.layers) {\n      if (props.runtime === Runtime.FROM_IMAGE) {\n        throw new Error('Layers are not supported for container image functions');\n      }\n\n      this.addLayers(...props.layers);\n    }\n\n    for (const event of props.events || []) {\n      this.addEventSource(event);\n    }\n\n    // Log retention\n    if (props.logRetention) {\n      const logRetention = new logs.LogRetention(this, 'LogRetention', {\n        logGroupName: `/aws/lambda/${this.functionName}`,\n        retention: props.logRetention,\n        role: props.logRetentionRole,\n        logRetentionRetryOptions: props.logRetentionRetryOptions as logs.LogRetentionRetryOptions,\n      });\n      this._logGroup = logs.LogGroup.fromLogGroupArn(this, 'LogGroup', logRetention.logGroupArn);\n    }\n\n    props.code.bindToResource(resource);\n\n    // Event Invoke Config\n    if (props.onFailure || props.onSuccess || props.maxEventAge || props.retryAttempts !== undefined) {\n      this.configureAsyncInvoke({\n        onFailure: props.onFailure,\n        onSuccess: props.onSuccess,\n        maxEventAge: props.maxEventAge,\n        retryAttempts: props.retryAttempts,\n      });\n    }\n\n    this.currentVersionOptions = props.currentVersionOptions;\n\n    if (props.filesystem) {\n      if (!props.vpc) {\n        throw new Error('Cannot configure \\'filesystem\\' without configuring a VPC.');\n      }\n      const config = props.filesystem.config;\n      if (config.dependency) {\n        this.node.addDependency(...config.dependency);\n      }\n      // There could be a race if the Lambda is used in a CustomResource. It is possible for the Lambda to\n      // fail to attach to a given FileSystem if we do not have a dependency on the SecurityGroup ingress/egress\n      // rules that were created between this Lambda's SG & the Filesystem SG.\n      this.connections.securityGroups.forEach(sg => {\n        sg.node.findAll().forEach(child => {\n          if (child instanceof CfnResource && child.cfnResourceType === 'AWS::EC2::SecurityGroupEgress') {\n            resource.node.addDependency(child);\n          }\n        });\n      });\n      config.connections?.securityGroups.forEach(sg => {\n        sg.node.findAll().forEach(child => {\n          if (child instanceof CfnResource && child.cfnResourceType === 'AWS::EC2::SecurityGroupIngress') {\n            resource.node.addDependency(child);\n          }\n        });\n      });\n    }\n\n    // Configure Lambda insights\n    this.configureLambdaInsights(props);\n  }\n\n                                                                                                                                                                                                                                                                                                         \n  public addEnvironment(key: string, value: string, options?: EnvironmentOptions): this {\n    this.environment[key] = { value, ...options };\n    return this;\n  }\n\n                                                                                                                                                                                                                                                     \n  public addLayers(...layers: ILayerVersion[]): void {\n    for (const layer of layers) {\n      if (this.layers.length === 5) {\n        throw new Error('Unable to add layer: this lambda function already uses 5 layers.');\n      }\n      if (layer.compatibleRuntimes && !layer.compatibleRuntimes.find(runtime => runtime.runtimeEquals(this.runtime))) {\n        const runtimes = layer.compatibleRuntimes.map(runtime => runtime.name).join(', ');\n        throw new Error(`This lambda function uses a runtime that is incompatible with this layer (${this.runtime.name} is not in [${runtimes}])`);\n      }\n\n      // Currently no validations for compatible architectures since Lambda service\n      // allows layers configured with one architecture to be used with a Lambda function\n      // from another architecture.\n\n      this.layers.push(layer);\n    }\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        \n  public addVersion(\n    name: string,\n    codeSha256?: string,\n    description?: string,\n    provisionedExecutions?: number,\n    asyncInvokeConfig: EventInvokeConfigOptions = {}): Version {\n\n    return new Version(this, 'Version' + name, {\n      lambda: this,\n      codeSha256,\n      description,\n      provisionedConcurrentExecutions: provisionedExecutions,\n      ...asyncInvokeConfig,\n    });\n  }\n\n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          \n  public get logGroup(): logs.ILogGroup {\n    if (!this._logGroup) {\n      const logRetention = new logs.LogRetention(this, 'LogRetention', {\n        logGroupName: `/aws/lambda/${this.functionName}`,\n        retention: logs.RetentionDays.INFINITE,\n      });\n      this._logGroup = logs.LogGroup.fromLogGroupArn(this, `${this.node.id}-LogGroup`, logRetention.logGroupArn);\n    }\n    return this._logGroup;\n  }\n\n  /** @internal */\n  public _checkEdgeCompatibility(): void {\n    // Check env vars\n    const envEntries = Object.entries(this.environment);\n    for (const [key, config] of envEntries) {\n      if (config.removeInEdge) {\n        delete this.environment[key];\n        Annotations.of(this).addInfo(`Removed ${key} environment variable for Lambda@Edge compatibility`);\n      }\n    }\n    const envKeys = Object.keys(this.environment);\n    if (envKeys.length !== 0) {\n      throw new Error(`The function ${this.node.path} contains environment variables [${envKeys}] and is not compatible with Lambda@Edge. \\\nEnvironment variables can be marked for removal when used in Lambda@Edge by setting the \\'removeInEdge\\' property in the \\'addEnvironment()\\' API.`);\n    }\n\n    return;\n  }\n\n  /**\n   * Configured lambda insights on the function if specified. This is acheived by adding an imported layer which is added to the\n   * list of lambda layers on synthesis.\n   *\n   * https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Lambda-Insights-extension-versions.html\n   */\n  private configureLambdaInsights(props: FunctionProps): void {\n    if (props.insightsVersion === undefined) {\n      return;\n    }\n    if (props.runtime !== Runtime.FROM_IMAGE) {\n      // Layers cannot be added to Lambda container images. The image should have the insights agent installed.\n      // See https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/Lambda-Insights-Getting-Started-docker.html\n      this.addLayers(LayerVersion.fromLayerVersionArn(this, 'LambdaInsightsLayer', props.insightsVersion.layerVersionArn));\n    }\n    this.role?.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('CloudWatchLambdaInsightsExecutionRolePolicy'));\n  }\n\n  private renderEnvironment() {\n    if (!this.environment || Object.keys(this.environment).length === 0) {\n      return undefined;\n    }\n\n    const variables: { [key: string]: string } = {};\n    // Sort environment so the hash of the function used to create\n    // `currentVersion` is not affected by key order (this is how lambda does\n    // it). For backwards compatibility we do not sort environment variables in case\n    // _currentVersion is not defined. Otherwise, this would have invalidated\n    // the template, and for example, may cause unneeded updates for nested\n    // stacks.\n    const keys = this._currentVersion\n      ? Object.keys(this.environment).sort()\n      : Object.keys(this.environment);\n\n    for (const key of keys) {\n      variables[key] = this.environment[key].value;\n    }\n\n    return { variables };\n  }\n\n  /**\n   * If configured, set up the VPC-related properties\n   *\n   * Returns the VpcConfig that should be added to the\n   * Lambda creation properties.\n   */\n  private configureVpc(props: FunctionProps): CfnFunction.VpcConfigProperty | undefined {\n    if ((props.securityGroup || props.allowAllOutbound !== undefined) && !props.vpc) {\n      throw new Error('Cannot configure \\'securityGroup\\' or \\'allowAllOutbound\\' without configuring a VPC');\n    }\n\n    if (!props.vpc) { return undefined; }\n\n    if (props.securityGroup && props.allowAllOutbound !== undefined) {\n      throw new Error('Configure \\'allowAllOutbound\\' directly on the supplied SecurityGroup.');\n    }\n\n    let securityGroups: ec2.ISecurityGroup[];\n\n    if (props.securityGroup && props.securityGroups) {\n      throw new Error('Only one of the function props, securityGroup or securityGroups, is allowed');\n    }\n\n    if (props.securityGroups) {\n      securityGroups = props.securityGroups;\n    } else {\n      const securityGroup = props.securityGroup || new ec2.SecurityGroup(this, 'SecurityGroup', {\n        vpc: props.vpc,\n        description: 'Automatic security group for Lambda Function ' + Names.uniqueId(this),\n        allowAllOutbound: props.allowAllOutbound,\n      });\n      securityGroups = [securityGroup];\n    }\n\n    this._connections = new ec2.Connections({ securityGroups });\n\n    if (props.filesystem) {\n      if (props.filesystem.config.connections) {\n        props.filesystem.config.connections.allowDefaultPortFrom(this);\n      }\n    }\n\n    const allowPublicSubnet = props.allowPublicSubnet ?? false;\n    const { subnetIds } = props.vpc.selectSubnets(props.vpcSubnets);\n    const publicSubnetIds = new Set(props.vpc.publicSubnets.map(s => s.subnetId));\n    for (const subnetId of subnetIds) {\n      if (publicSubnetIds.has(subnetId) && !allowPublicSubnet) {\n        throw new Error('Lambda Functions in a public subnet can NOT access the internet. ' +\n          'If you are aware of this limitation and would still like to place the function int a public subnet, set `allowPublicSubnet` to true');\n      }\n    }\n\n    // List can't be empty here, if we got this far you intended to put your Lambda\n    // in subnets. We're going to guarantee that we get the nice error message by\n    // making VpcNetwork do the selection again.\n\n    return {\n      subnetIds,\n      securityGroupIds: securityGroups.map(sg => sg.securityGroupId),\n    };\n  }\n\n  private buildDeadLetterQueue(props: FunctionProps) {\n    if (props.deadLetterQueue && props.deadLetterQueueEnabled === false) {\n      throw Error('deadLetterQueue defined but deadLetterQueueEnabled explicitly set to false');\n    }\n\n    if (!props.deadLetterQueue && !props.deadLetterQueueEnabled) {\n      return undefined;\n    }\n\n    const deadLetterQueue = props.deadLetterQueue || new sqs.Queue(this, 'DeadLetterQueue', {\n      retentionPeriod: Duration.days(14),\n    });\n\n    this.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['sqs:SendMessage'],\n      resources: [deadLetterQueue.queueArn],\n    }));\n\n    return deadLetterQueue;\n  }\n\n  private buildDeadLetterConfig(deadLetterQueue?: sqs.IQueue) {\n    if (deadLetterQueue) {\n      return {\n        targetArn: deadLetterQueue.queueArn,\n      };\n    } else {\n      return undefined;\n    }\n  }\n\n  private buildTracingConfig(props: FunctionProps) {\n    if (props.tracing === undefined || props.tracing === Tracing.DISABLED) {\n      return undefined;\n    }\n\n    this.addToRolePolicy(new iam.PolicyStatement({\n      actions: ['xray:PutTraceSegments', 'xray:PutTelemetryRecords'],\n      resources: ['*'],\n    }));\n\n    return {\n      mode: props.tracing,\n    };\n  }\n\n  private validateProfiling(props: FunctionProps) {\n    if (!props.runtime.supportsCodeGuruProfiling) {\n      throw new Error(`CodeGuru profiling is not supported by runtime ${props.runtime.name}`);\n    }\n    if (props.environment && (props.environment.AWS_CODEGURU_PROFILER_GROUP_ARN || props.environment.AWS_CODEGURU_PROFILER_ENABLED)) {\n      throw new Error('AWS_CODEGURU_PROFILER_GROUP_ARN and AWS_CODEGURU_PROFILER_ENABLED must not be set when profiling options enabled');\n    }\n  }\n}\n\n                                        \nexport interface EnvironmentOptions {\n                                                                                                                                                                                                                                                                                                                                                                                          \n  readonly removeInEdge?: boolean\n}\n\n/**\n * Configuration for an environment variable\n */\ninterface EnvironmentConfig extends EnvironmentOptions {\n  readonly value: string;\n}\n\n/**\n * Given an opaque (token) ARN, returns a CloudFormation expression that extracts the function\n * name from the ARN.\n *\n * Function ARNs look like this:\n *\n *   arn:aws:lambda:region:account-id:function:function-name\n *\n * ..which means that in order to extract the `function-name` component from the ARN, we can\n * split the ARN using \":\" and select the component in index 6.\n *\n * @returns `FnSelect(6, FnSplit(':', arn))`\n */\nfunction extractNameFromArn(arn: string) {\n  return Fn.select(6, Fn.split(':', arn));\n}\n\nexport function verifyCodeConfig(code: CodeConfig, props: FunctionProps) {\n  // mutually exclusive\n  const codeType = [code.inlineCode, code.s3Location, code.image];\n\n  if (codeType.filter(x => !!x).length !== 1) {\n    throw new Error('lambda.Code must specify exactly one of: \"inlineCode\", \"s3Location\", or \"image\"');\n  }\n\n  if (!!code.image === (props.handler !== Handler.FROM_IMAGE)) {\n    throw new Error('handler must be `Handler.FROM_IMAGE` when using image asset for Lambda function');\n  }\n\n  if (!!code.image === (props.runtime !== Runtime.FROM_IMAGE)) {\n    throw new Error('runtime must be `Runtime.FROM_IMAGE` when using image asset for Lambda function');\n  }\n\n  // if this is inline code, check that the runtime supports\n  if (code.inlineCode && !props.runtime.supportsInlineCode) {\n    throw new Error(`Inline source not allowed for ${props.runtime!.name}`);\n  }\n}\n\nfunction undefinedIfNoKeys<A>(struct: A): A | undefined {\n  const allUndefined = Object.values(struct).every(val => val === undefined);\n  return allUndefined ? undefined : struct;\n}\n"]}