@aws-solutions-constructs/aws-lambda-secretsmanager 2.35.0 → 2.37.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/.jsii CHANGED
@@ -8,8 +8,8 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/core": "2.35.0",
12
- "aws-cdk-lib": "^2.68.0",
11
+ "@aws-solutions-constructs/core": "2.37.0",
12
+ "aws-cdk-lib": "^2.73.0",
13
13
  "constructs": "^10.0.0"
14
14
  },
15
15
  "dependencyClosure": {
@@ -807,6 +807,19 @@
807
807
  }
808
808
  }
809
809
  },
810
+ "aws-cdk-lib.aws_comprehend": {
811
+ "targets": {
812
+ "dotnet": {
813
+ "namespace": "Amazon.CDK.AWS.Comprehend"
814
+ },
815
+ "java": {
816
+ "package": "software.amazon.awscdk.services.comprehend"
817
+ },
818
+ "python": {
819
+ "module": "aws_cdk.aws_comprehend"
820
+ }
821
+ }
822
+ },
810
823
  "aws-cdk-lib.aws_config": {
811
824
  "targets": {
812
825
  "dotnet": {
@@ -1600,6 +1613,19 @@
1600
1613
  }
1601
1614
  }
1602
1615
  },
1616
+ "aws-cdk-lib.aws_internetmonitor": {
1617
+ "targets": {
1618
+ "dotnet": {
1619
+ "namespace": "Amazon.CDK.AWS.InternetMonitor"
1620
+ },
1621
+ "java": {
1622
+ "package": "software.amazon.awscdk.services.internetmonitor"
1623
+ },
1624
+ "python": {
1625
+ "module": "aws_cdk.aws_internetmonitor"
1626
+ }
1627
+ }
1628
+ },
1603
1629
  "aws-cdk-lib.aws_iot": {
1604
1630
  "targets": {
1605
1631
  "dotnet": {
@@ -1756,6 +1782,19 @@
1756
1782
  }
1757
1783
  }
1758
1784
  },
1785
+ "aws-cdk-lib.aws_ivschat": {
1786
+ "targets": {
1787
+ "dotnet": {
1788
+ "namespace": "Amazon.CDK.AWS.IVSChat"
1789
+ },
1790
+ "java": {
1791
+ "package": "software.amazon.awscdk.services.ivschat"
1792
+ },
1793
+ "python": {
1794
+ "module": "aws_cdk.aws_ivschat"
1795
+ }
1796
+ }
1797
+ },
1759
1798
  "aws-cdk-lib.aws_kafkaconnect": {
1760
1799
  "targets": {
1761
1800
  "dotnet": {
@@ -3069,6 +3108,19 @@
3069
3108
  }
3070
3109
  }
3071
3110
  },
3111
+ "aws-cdk-lib.aws_systemsmanagersap": {
3112
+ "targets": {
3113
+ "dotnet": {
3114
+ "namespace": "Amazon.CDK.AWS.SystemsManagerSAP"
3115
+ },
3116
+ "java": {
3117
+ "package": "software.amazon.awscdk.services.systemsmanagersap"
3118
+ },
3119
+ "python": {
3120
+ "module": "aws_cdk.aws_systemsmanagersap"
3121
+ }
3122
+ }
3123
+ },
3072
3124
  "aws-cdk-lib.aws_timestream": {
3073
3125
  "targets": {
3074
3126
  "dotnet": {
@@ -3108,6 +3160,19 @@
3108
3160
  }
3109
3161
  }
3110
3162
  },
3163
+ "aws-cdk-lib.aws_vpclattice": {
3164
+ "targets": {
3165
+ "dotnet": {
3166
+ "namespace": "Amazon.CDK.AWS.VpcLattice"
3167
+ },
3168
+ "java": {
3169
+ "package": "software.amazon.awscdk.services.vpclattice"
3170
+ },
3171
+ "python": {
3172
+ "module": "aws_cdk.aws_vpclattice"
3173
+ }
3174
+ }
3175
+ },
3111
3176
  "aws-cdk-lib.aws_waf": {
3112
3177
  "targets": {
3113
3178
  "dotnet": {
@@ -3371,7 +3436,7 @@
3371
3436
  },
3372
3437
  "description": "CDK constructs for defining an interaction between an AWS Lambda function and AWS Secrets Manager.",
3373
3438
  "homepage": "https://github.com/awslabs/aws-solutions-constructs.git",
3374
- "jsiiVersion": "1.79.0 (build b22f628)",
3439
+ "jsiiVersion": "1.80.0 (build bce6a1d)",
3375
3440
  "keywords": [
3376
3441
  "aws",
3377
3442
  "cdk",
@@ -3390,7 +3455,7 @@
3390
3455
  },
3391
3456
  "name": "@aws-solutions-constructs/aws-lambda-secretsmanager",
3392
3457
  "readme": {
3393
- "markdown": "# aws-lambda-secretsmanager module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n![Stability: Experimental](https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge)\n\n> All classes are under active development and subject to non-backward compatible changes or removal in any\n> future version. These are not subject to the [Semantic Versioning](https://semver.org/) model.\n> This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.\n\n---\n<!--END STABILITY BANNER-->\n\n| **Reference Documentation**:| <span style=\"font-weight: normal\">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|\n|:-------------|:-------------|\n<div style=\"height:8px\"></div>\n\n| **Language** | **Package** |\n|:-------------|-----------------|\n|![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_lambda_secretsmanager`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-lambda-secretsmanager`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.lambdasecretsmanager`|\n\n## Overview\nThis AWS Solutions Construct implements the AWS Lambda function and AWS Secrets Manager secret with the least privileged permissions.\n\nHere is a minimal deployable pattern definition:\n\nTypescript\n``` typescript\nimport { Construct } from 'constructs';\nimport { Stack, StackProps } from 'aws-cdk-lib';\nimport { LambdaToSecretsmanagerProps, LambdaToSecretsmanager } from '@aws-solutions-constructs/aws-lambda-secretsmanager';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\n\nconst constructProps: LambdaToSecretsmanagerProps = {\n lambdaFunctionProps: {\n runtime: lambda.Runtime.NODEJS_14_X,\n code: lambda.Code.fromAsset(`lambda`),\n handler: 'index.handler'\n },\n};\n\nnew LambdaToSecretsmanager(this, 'test-lambda-secretsmanager-stack', constructProps);\n```\n\nPython\n``` python\nfrom aws_solutions_constructs.aws_lambda_secretsmanager import LambdaToSecretsmanagerProps, LambdaToSecretsmanager\nfrom aws_cdk import (\n aws_lambda as _lambda,\n Stack\n)\nfrom constructs import Construct\n\n\nLambdaToSecretsmanager(\n self, 'test-lambda-secretsmanager-stack',\n lambda_function_props=_lambda.FunctionProps(\n code=_lambda.Code.from_asset('lambda'),\n runtime=_lambda.Runtime.PYTHON_3_9,\n handler='index.handler'\n )\n)\n```\n\nJava\n``` java\nimport software.constructs.Construct;\n\nimport software.amazon.awscdk.Stack;\nimport software.amazon.awscdk.StackProps;\nimport software.amazon.awscdk.services.lambda.*;\nimport software.amazon.awscdk.services.lambda.Runtime;\nimport software.amazon.awsconstructs.services.lambdasecretsmanager.*;\n\nnew LambdaToSecretsmanager(this, \"test-lambda-secretsmanager-stack\", new LambdaToSecretsmanagerProps.Builder()\n .lambdaFunctionProps(new FunctionProps.Builder()\n .runtime(Runtime.NODEJS_14_X)\n .code(Code.fromAsset(\"lambda\"))\n .handler(\"index.handler\")\n .build())\n .build());\n```\n## Pattern Construct Props\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|existingLambdaObj?|[`lambda.Function`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Existing instance of Lambda Function object, providing both this and `lambdaFunctionProps` will cause an error.|\n|lambdaFunctionProps?|[`lambda.FunctionProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.FunctionProps.html)|User provided props to override the default props for the Lambda function.|\n|secretProps?|[`secretsmanager.SecretProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.SecretProps.html)|Optional user provided props to override the default props for Secrets Manager|\n|existingSecretObj?|[`secretsmanager.Secret`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html)|Existing instance of Secrets Manager Secret object, If this is set then the secretProps is ignored|\n|grantWriteAccess?|`string`|Optional Access granted to the Lambda function for the secret. 'Read' or 'ReadWrite\". Default is \"Read\"\n|secretEnvironmentVariableName?|`string`|Optional Name for the Lambda function environment variable set to the ARN of the secret. Default: SECRET_ARN. |\n|existingVpc?|[`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html)|An optional, existing VPC into which this pattern should be deployed. When deployed in a VPC, the Lambda function will use ENIs in the VPC to access network resources and an Interface Endpoint will be created in the VPC for AWS Secrets Manager. If an existing VPC is provided, the `deployVpc` property cannot be `true`. This uses `ec2.IVpc` to allow clients to supply VPCs that exist outside the stack using the [`ec2.Vpc.fromLookup()`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.Vpc.html#static-fromwbrlookupscope-id-options) method.|\n|vpcProps?|[`ec2.VpcProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.VpcProps.html)|Optional user-provided properties to override the default properties for the new VPC. `enableDnsHostnames`, `enableDnsSupport`, `natGateways` and `subnetConfiguration` are set by the pattern, so any values for those properties supplied here will be overrriden. If `deployVpc` is not `true` then this property will be ignored.|\n|deployVpc?|`boolean`|Whether to create a new VPC based on `vpcProps` into which to deploy this pattern. Setting this to true will deploy the minimal, most private VPC to run the pattern:<ul><li> One isolated subnet in each Availability Zone used by the CDK program</li><li>`enableDnsHostnames` and `enableDnsSupport` will both be set to true</li></ul>If this property is `true` then `existingVpc` cannot be specified. Defaults to `false`.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|lambdaFunction|[`lambda.Function`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Returns an instance of lambda.Function created by the construct|\n|secret|[`secretsmanager.Secret`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html)|Returns an instance of secretsmanager.Secret created by the construct|\n|vpc?|[`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html)|Returns an interface on the VPC used by the pattern (if any). This may be a VPC created by the pattern or the VPC supplied to the pattern constructor.|\n\n## Default settings\n\nOut of the box implementation of the Construct without any override will set the following defaults:\n\n### AWS Lambda Function\n* Configure limited privilege access IAM role for Lambda function\n* Enable reusing connections with Keep-Alive for NodeJs Lambda function\n* Enable X-Ray Tracing\n* Set Environment Variables\n * (default) SECRET_ARN containing the ARN of the secret as return by CDK [secretArn property](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html#secretarn).\n * AWS_NODEJS_CONNECTION_REUSE_ENABLED (for Node 10.x and higher functions)\n\n### Amazon SecretsManager Secret\n* Enable read-only access for the associated AWS Lambda Function\n* Creates a new Secret\n * (default) random name\n * (default) random value\n* Retain the Secret when deleting the CloudFormation stack\n\n## Architecture\n![Architecture Diagram](architecture.png)\n\n***\n&copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
3458
+ "markdown": "# aws-lambda-secretsmanager module\n<!--BEGIN STABILITY BANNER-->\n\n---\n\n![Stability: Experimental](https://img.shields.io/badge/stability-Experimental-important.svg?style=for-the-badge)\n\n> All classes are under active development and subject to non-backward compatible changes or removal in any\n> future version. These are not subject to the [Semantic Versioning](https://semver.org/) model.\n> This means that while you may use them, you may need to update your source code when upgrading to a newer version of this package.\n\n---\n<!--END STABILITY BANNER-->\n\n| **Reference Documentation**:| <span style=\"font-weight: normal\">https://docs.aws.amazon.com/solutions/latest/constructs/</span>|\n|:-------------|:-------------|\n<div style=\"height:8px\"></div>\n\n| **Language** | **Package** |\n|:-------------|-----------------|\n|![Python Logo](https://docs.aws.amazon.com/cdk/api/latest/img/python32.png) Python|`aws_solutions_constructs.aws_lambda_secretsmanager`|\n|![Typescript Logo](https://docs.aws.amazon.com/cdk/api/latest/img/typescript32.png) Typescript|`@aws-solutions-constructs/aws-lambda-secretsmanager`|\n|![Java Logo](https://docs.aws.amazon.com/cdk/api/latest/img/java32.png) Java|`software.amazon.awsconstructs.services.lambdasecretsmanager`|\n\n## Overview\nThis AWS Solutions Construct implements the AWS Lambda function and AWS Secrets Manager secret with the least privileged permissions.\n\nHere is a minimal deployable pattern definition:\n\nTypescript\n``` typescript\nimport { Construct } from 'constructs';\nimport { Stack, StackProps } from 'aws-cdk-lib';\nimport { LambdaToSecretsmanagerProps, LambdaToSecretsmanager } from '@aws-solutions-constructs/aws-lambda-secretsmanager';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\n\nconst constructProps: LambdaToSecretsmanagerProps = {\n lambdaFunctionProps: {\n runtime: lambda.Runtime.NODEJS_16_X,\n code: lambda.Code.fromAsset(`lambda`),\n handler: 'index.handler'\n },\n};\n\nnew LambdaToSecretsmanager(this, 'test-lambda-secretsmanager-stack', constructProps);\n```\n\nPython\n``` python\nfrom aws_solutions_constructs.aws_lambda_secretsmanager import LambdaToSecretsmanagerProps, LambdaToSecretsmanager\nfrom aws_cdk import (\n aws_lambda as _lambda,\n Stack\n)\nfrom constructs import Construct\n\n\nLambdaToSecretsmanager(\n self, 'test-lambda-secretsmanager-stack',\n lambda_function_props=_lambda.FunctionProps(\n code=_lambda.Code.from_asset('lambda'),\n runtime=_lambda.Runtime.PYTHON_3_9,\n handler='index.handler'\n )\n)\n```\n\nJava\n``` java\nimport software.constructs.Construct;\n\nimport software.amazon.awscdk.Stack;\nimport software.amazon.awscdk.StackProps;\nimport software.amazon.awscdk.services.lambda.*;\nimport software.amazon.awscdk.services.lambda.Runtime;\nimport software.amazon.awsconstructs.services.lambdasecretsmanager.*;\n\nnew LambdaToSecretsmanager(this, \"test-lambda-secretsmanager-stack\", new LambdaToSecretsmanagerProps.Builder()\n .lambdaFunctionProps(new FunctionProps.Builder()\n .runtime(Runtime.NODEJS_16_X)\n .code(Code.fromAsset(\"lambda\"))\n .handler(\"index.handler\")\n .build())\n .build());\n```\n## Pattern Construct Props\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|existingLambdaObj?|[`lambda.Function`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Existing instance of Lambda Function object, providing both this and `lambdaFunctionProps` will cause an error.|\n|lambdaFunctionProps?|[`lambda.FunctionProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.FunctionProps.html)|User provided props to override the default props for the Lambda function.|\n|secretProps?|[`secretsmanager.SecretProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.SecretProps.html)|Optional user provided props to override the default props for Secrets Manager|\n|existingSecretObj?|[`secretsmanager.Secret`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html)|Existing instance of Secrets Manager Secret object, If this is set then the secretProps is ignored|\n|grantWriteAccess?|`string`|Optional Access granted to the Lambda function for the secret. 'Read' or 'ReadWrite\". Default is \"Read\"\n|secretEnvironmentVariableName?|`string`|Optional Name for the Lambda function environment variable set to the ARN of the secret. Default: SECRET_ARN. |\n|existingVpc?|[`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html)|An optional, existing VPC into which this pattern should be deployed. When deployed in a VPC, the Lambda function will use ENIs in the VPC to access network resources and an Interface Endpoint will be created in the VPC for AWS Secrets Manager. If an existing VPC is provided, the `deployVpc` property cannot be `true`. This uses `ec2.IVpc` to allow clients to supply VPCs that exist outside the stack using the [`ec2.Vpc.fromLookup()`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.Vpc.html#static-fromwbrlookupscope-id-options) method.|\n|vpcProps?|[`ec2.VpcProps`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.VpcProps.html)|Optional user-provided properties to override the default properties for the new VPC. `enableDnsHostnames`, `enableDnsSupport`, `natGateways` and `subnetConfiguration` are set by the pattern, so any values for those properties supplied here will be overrriden. If `deployVpc` is not `true` then this property will be ignored.|\n|deployVpc?|`boolean`|Whether to create a new VPC based on `vpcProps` into which to deploy this pattern. Setting this to true will deploy the minimal, most private VPC to run the pattern:<ul><li> One isolated subnet in each Availability Zone used by the CDK program</li><li>`enableDnsHostnames` and `enableDnsSupport` will both be set to true</li></ul>If this property is `true` then `existingVpc` cannot be specified. Defaults to `false`.|\n\n## Pattern Properties\n\n| **Name** | **Type** | **Description** |\n|:-------------|:----------------|-----------------|\n|lambdaFunction|[`lambda.Function`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_lambda.Function.html)|Returns an instance of lambda.Function created by the construct|\n|secret|[`secretsmanager.Secret`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html)|Returns an instance of secretsmanager.Secret created by the construct|\n|vpc?|[`ec2.IVpc`](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_ec2.IVpc.html)|Returns an interface on the VPC used by the pattern (if any). This may be a VPC created by the pattern or the VPC supplied to the pattern constructor.|\n\n## Default settings\n\nOut of the box implementation of the Construct without any override will set the following defaults:\n\n### AWS Lambda Function\n* Configure limited privilege access IAM role for Lambda function\n* Enable reusing connections with Keep-Alive for NodeJs Lambda function\n* Enable X-Ray Tracing\n* Set Environment Variables\n * (default) SECRET_ARN containing the ARN of the secret as return by CDK [secretArn property](https://docs.aws.amazon.com/cdk/api/v2/docs/aws-cdk-lib.aws_secretsmanager.Secret.html#secretarn).\n * AWS_NODEJS_CONNECTION_REUSE_ENABLED (for Node 10.x and higher functions)\n\n### Amazon SecretsManager Secret\n* Enable read-only access for the associated AWS Lambda Function\n* Creates a new Secret\n * (default) random name\n * (default) random value\n* Retain the Secret when deleting the CloudFormation stack\n\n## Architecture\n![Architecture Diagram](architecture.png)\n\n***\n&copy; Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n"
3394
3459
  },
3395
3460
  "repository": {
3396
3461
  "directory": "source/patterns/@aws-solutions-constructs/aws-lambda-secretsmanager",
@@ -3687,6 +3752,6 @@
3687
3752
  "symbolId": "lib/index:LambdaToSecretsmanagerProps"
3688
3753
  }
3689
3754
  },
3690
- "version": "2.35.0",
3691
- "fingerprint": "CW+Q3sARRGItIqlk789mNvNz74SQNAaUDTpvk9maEw4="
3755
+ "version": "2.37.0",
3756
+ "fingerprint": "cjMohrbZQjJDG4SS2W0JD4cvn5F+Ompa+dWveCFIfeQ="
3692
3757
  }
package/README.md CHANGED
@@ -36,7 +36,7 @@ import * as lambda from 'aws-cdk-lib/aws-lambda';
36
36
 
37
37
  const constructProps: LambdaToSecretsmanagerProps = {
38
38
  lambdaFunctionProps: {
39
- runtime: lambda.Runtime.NODEJS_14_X,
39
+ runtime: lambda.Runtime.NODEJS_16_X,
40
40
  code: lambda.Code.fromAsset(`lambda`),
41
41
  handler: 'index.handler'
42
42
  },
@@ -77,7 +77,7 @@ import software.amazon.awsconstructs.services.lambdasecretsmanager.*;
77
77
 
78
78
  new LambdaToSecretsmanager(this, "test-lambda-secretsmanager-stack", new LambdaToSecretsmanagerProps.Builder()
79
79
  .lambdaFunctionProps(new FunctionProps.Builder()
80
- .runtime(Runtime.NODEJS_14_X)
80
+ .runtime(Runtime.NODEJS_16_X)
81
81
  .code(Code.fromAsset("lambda"))
82
82
  .handler("index.handler")
83
83
  .build())
package/lib/index.js CHANGED
@@ -72,5 +72,5 @@ class LambdaToSecretsmanager extends constructs_1.Construct {
72
72
  }
73
73
  exports.LambdaToSecretsmanager = LambdaToSecretsmanager;
74
74
  _a = JSII_RTTI_SYMBOL_1;
75
- LambdaToSecretsmanager[_a] = { fqn: "@aws-solutions-constructs/aws-lambda-secretsmanager.LambdaToSecretsmanager", version: "2.35.0" };
75
+ LambdaToSecretsmanager[_a] = { fqn: "@aws-solutions-constructs/aws-lambda-secretsmanager.LambdaToSecretsmanager", version: "2.37.0" };
76
76
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;GAWG;AAEH,UAAU;AACV,2DAA2D;AAI3D,2CAAuC;AA2DvC;;GAEG;AACH,MAAa,sBAAuB,SAAQ,sBAAS;IAKjD;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAkC;QAC1E,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QAE3B,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,WAAW,EAAE;YACxC,IAAI,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,WAAW,EAAE;gBACxC,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;aAChE;YAED,IAAI,CAAC,GAAG,GAAG,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE;gBAClC,eAAe,EAAE,QAAQ,CAAC,uBAAuB,EAAE;gBACnD,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,YAAY,EAAE,KAAK,CAAC,QAAQ;gBAC5B,iBAAiB,EAAE;oBACjB,kBAAkB,EAAE,IAAI;oBACxB,gBAAgB,EAAE,IAAI;iBACvB;aACF,CAAC,CAAC;YAEH,QAAQ,CAAC,qBAAqB,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,oBAAoB,CAAC,eAAe,CAAC,CAAC;SAChG;QAED,4BAA4B;QAC5B,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE;YACvD,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;YAC1C,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;YAC9C,GAAG,EAAE,IAAI,CAAC,GAAG;SACd,CAAC,CAAC;QAEH,mBAAmB;QACnB,IAAI,KAAK,CAAC,iBAAiB,EAAE;YAC3B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,iBAAiB,CAAC;SACvC;aAAM;YACL,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,yBAAyB,CAAC,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,WAAW,CAAC,CAAC;SACrF;QAED,kCAAkC;QAClC,MAAM,6BAA6B,GAAG,KAAK,CAAC,6BAA6B,IAAI,YAAY,CAAC;QAC1F,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,6BAA6B,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAEzF,6DAA6D;QAC7D,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAE3C,IAAI,KAAK,CAAC,gBAAgB,KAAK,WAAW,EAAE;YAC1C,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAC7C;IACH,CAAC;;AA1DL,wDA2DC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport * as defaults from \"@aws-solutions-constructs/core\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport * as secretsmanager from \"aws-cdk-lib/aws-secretsmanager\";\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { Construct } from \"constructs\";\n\n/**\n * @summary The properties for the LambdaToSecretsmanager class.\n */\nexport interface LambdaToSecretsmanagerProps {\n  /**\n   * Existing instance of Lambda Function object, providing both this and `lambdaFunctionProps` will cause an error.\n   *\n   * @default - None\n   */\n  readonly existingLambdaObj?: lambda.Function;\n  /**\n   * User provided props to override the default props for the Lambda function.\n   *\n   * @default - Default properties are used.\n   */\n  readonly lambdaFunctionProps?: lambda.FunctionProps;\n  /**\n   * Existing instance of Secret object, providing both this and secretProps will cause an error.\n   *\n   * @default - Default props are used\n   */\n  readonly existingSecretObj?: secretsmanager.Secret;\n  /**\n   * Optional user-provided props to override the default props for the Secret.\n   *\n   * @default - Default props are used\n   */\n  readonly secretProps?: secretsmanager.SecretProps;\n  /**\n   * An existing VPC for the construct to use (construct will NOT create a new VPC in this case)\n   */\n  readonly existingVpc?: ec2.IVpc;\n  /**\n   * Properties to override default properties if deployVpc is true\n   */\n  readonly vpcProps?: ec2.VpcProps;\n  /**\n   * Whether to deploy a new VPC\n   *\n   * @default - false\n   */\n  readonly deployVpc?: boolean;\n  /**\n   * Optional Name for the Lambda function environment variable set to the ARN of the secret.\n   *\n   * @default - SECRET_ARN\n   */\n  readonly secretEnvironmentVariableName?: string;\n  /**\n   * Optional secret permissions to grant to the Lambda function.\n   * One of the following may be specified: \"Read\" or \"ReadWrite\".\n   *\n   * @default - Read only acess is given to the Lambda function if no value is specified.\n   */\n  readonly grantWriteAccess?: string;\n}\n\n/**\n * @summary The LambdaToSecretsmanager class.\n */\nexport class LambdaToSecretsmanager extends Construct {\n    public readonly lambdaFunction: lambda.Function;\n    public readonly secret: secretsmanager.Secret;\n    public readonly vpc?: ec2.IVpc;\n\n    /**\n     * @summary Constructs a new instance of the LambdaToSecretsmanager class.\n     * @param {cdk.App} scope - represents the scope for all the resources.\n     * @param {string} id - this is a a scope-unique id.\n     * @param {LambdaToSecretsmanagerProps} props - user provided props for the construct.\n     * @access public\n     */\n    constructor(scope: Construct, id: string, props: LambdaToSecretsmanagerProps) {\n      super(scope, id);\n      defaults.CheckProps(props);\n\n      if (props.deployVpc || props.existingVpc) {\n        if (props.deployVpc && props.existingVpc) {\n          throw new Error(\"More than 1 VPC specified in the properties\");\n        }\n\n        this.vpc = defaults.buildVpc(scope, {\n          defaultVpcProps: defaults.DefaultIsolatedVpcProps(),\n          existingVpc: props.existingVpc,\n          userVpcProps: props.vpcProps,\n          constructVpcProps: {\n            enableDnsHostnames: true,\n            enableDnsSupport: true,\n          },\n        });\n\n        defaults.AddAwsServiceEndpoint(scope, this.vpc, defaults.ServiceEndpointTypes.SECRETS_MANAGER);\n      }\n\n      // Setup the Lambda function\n      this.lambdaFunction = defaults.buildLambdaFunction(this, {\n        existingLambdaObj: props.existingLambdaObj,\n        lambdaFunctionProps: props.lambdaFunctionProps,\n        vpc: this.vpc,\n      });\n\n      // Setup the Secret\n      if (props.existingSecretObj) {\n        this.secret = props.existingSecretObj;\n      } else {\n        this.secret = defaults.buildSecretsManagerSecret(this, 'secret', props.secretProps);\n      }\n\n      // Configure environment variables\n      const secretEnvironmentVariableName = props.secretEnvironmentVariableName || 'SECRET_ARN';\n      this.lambdaFunction.addEnvironment(secretEnvironmentVariableName, this.secret.secretArn);\n\n      // Enable read permissions for the Lambda function by default\n      this.secret.grantRead(this.lambdaFunction);\n\n      if (props.grantWriteAccess === 'ReadWrite') {\n        this.secret.grantWrite(this.lambdaFunction);\n      }\n    }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-lambda-secretsmanager",
3
- "version": "2.35.0",
3
+ "version": "2.37.0",
4
4
  "description": "CDK constructs for defining an interaction between an AWS Lambda function and AWS Secrets Manager.",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -53,13 +53,12 @@
53
53
  }
54
54
  },
55
55
  "dependencies": {
56
- "@aws-solutions-constructs/core": "2.35.0"
56
+ "@aws-solutions-constructs/core": "2.37.0"
57
57
  },
58
58
  "devDependencies": {
59
- "@aws-cdk/assert": "2.68.0",
60
59
  "@types/jest": "^24.0.23",
61
60
  "@types/node": "^10.3.0",
62
- "aws-cdk-lib": "2.68.0",
61
+ "aws-cdk-lib": "2.73.0",
63
62
  "constructs": "^10.0.0"
64
63
  },
65
64
  "jest": {
@@ -68,8 +67,8 @@
68
67
  ]
69
68
  },
70
69
  "peerDependencies": {
71
- "@aws-solutions-constructs/core": "2.35.0",
72
- "aws-cdk-lib": "^2.68.0",
70
+ "@aws-solutions-constructs/core": "2.37.0",
71
+ "aws-cdk-lib": "^2.73.0",
73
72
  "constructs": "^10.0.0"
74
73
  },
75
74
  "keywords": [
@@ -124,7 +124,7 @@
124
124
  }
125
125
  },
126
126
  "Handler": "index.handler",
127
- "Runtime": "nodejs14.x",
127
+ "Runtime": "nodejs16.x",
128
128
  "TracingConfig": {
129
129
  "Mode": "Active"
130
130
  }
@@ -24,7 +24,7 @@ stack.templateOptions.description = 'Integration Test for aws-lambda-secretsmana
24
24
  // Definitions
25
25
  const props = {
26
26
  lambdaFunctionProps: {
27
- runtime: lambda.Runtime.NODEJS_14_X,
27
+ runtime: lambda.Runtime.NODEJS_16_X,
28
28
  handler: 'index.handler',
29
29
  code: lambda.Code.fromAsset(`${__dirname}/lambda`)
30
30
  },
@@ -35,4 +35,4 @@ const props = {
35
35
  new lib_1.LambdaToSecretsmanager(stack, 'test-lambda-secretsmanager', props);
36
36
  // Synth
37
37
  app.synth();
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5kZXBsb3lGdW5jdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsVUFBVTtBQUNWLDZDQUFzRDtBQUN0RCxnQ0FBMkU7QUFDM0UsaURBQWlEO0FBQ2pELHlEQUF3RTtBQUV4RSxRQUFRO0FBQ1IsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSw2QkFBc0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0FBQ2pFLEtBQUssQ0FBQyxlQUFlLENBQUMsV0FBVyxHQUFHLGdEQUFnRCxDQUFDO0FBRXJGLGNBQWM7QUFDZCxNQUFNLEtBQUssR0FBZ0M7SUFDekMsbUJBQW1CLEVBQUU7UUFDbkIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVztRQUNuQyxPQUFPLEVBQUUsZUFBZTtRQUN4QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLFNBQVMsQ0FBQztLQUNuRDtJQUNELFdBQVcsRUFBRTtRQUNYLGFBQWEsRUFBRSwyQkFBYSxDQUFDLE9BQU87S0FDckM7Q0FDRixDQUFDO0FBRUYsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsNEJBQTRCLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFdkUsUUFBUTtBQUNSLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCB7QXBwLCBSZW1vdmFsUG9saWN5LCBTdGFja30gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQge0xhbWJkYVRvU2VjcmV0c21hbmFnZXIsIExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wc30gZnJvbSAnLi4vbGliJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9ICdJbnRlZ3JhdGlvbiBUZXN0IGZvciBhd3MtbGFtYmRhLXNlY3JldHNtYW5hZ2VyJztcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IHByb3BzOiBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMgPSB7XG4gIGxhbWJkYUZ1bmN0aW9uUHJvcHM6IHtcbiAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5OT0RFSlNfMTRfWCxcbiAgICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcicsXG4gICAgY29kZTogbGFtYmRhLkNvZGUuZnJvbUFzc2V0KGAke19fZGlybmFtZX0vbGFtYmRhYClcbiAgfSxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfVxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssICd0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlcicsIHByb3BzKTtcblxuLy8gU3ludGhcbmFwcC5zeW50aCgpO1xuIl19
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5kZXBsb3lGdW5jdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsVUFBVTtBQUNWLDZDQUFzRDtBQUN0RCxnQ0FBMkU7QUFDM0UsaURBQWlEO0FBQ2pELHlEQUF3RTtBQUV4RSxRQUFRO0FBQ1IsTUFBTSxHQUFHLEdBQUcsSUFBSSxpQkFBRyxFQUFFLENBQUM7QUFDdEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxtQkFBSyxDQUFDLEdBQUcsRUFBRSw2QkFBc0IsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0FBQ2pFLEtBQUssQ0FBQyxlQUFlLENBQUMsV0FBVyxHQUFHLGdEQUFnRCxDQUFDO0FBRXJGLGNBQWM7QUFDZCxNQUFNLEtBQUssR0FBZ0M7SUFDekMsbUJBQW1CLEVBQUU7UUFDbkIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVztRQUNuQyxPQUFPLEVBQUUsZUFBZTtRQUN4QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLFNBQVMsQ0FBQztLQUNuRDtJQUNELFdBQVcsRUFBRTtRQUNYLGFBQWEsRUFBRSwyQkFBYSxDQUFDLE9BQU87S0FDckM7Q0FDRixDQUFDO0FBRUYsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsNEJBQTRCLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFdkUsUUFBUTtBQUNSLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCB7QXBwLCBSZW1vdmFsUG9saWN5LCBTdGFja30gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQge0xhbWJkYVRvU2VjcmV0c21hbmFnZXIsIExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wc30gZnJvbSAnLi4vbGliJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9ICdJbnRlZ3JhdGlvbiBUZXN0IGZvciBhd3MtbGFtYmRhLXNlY3JldHNtYW5hZ2VyJztcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IHByb3BzOiBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMgPSB7XG4gIGxhbWJkYUZ1bmN0aW9uUHJvcHM6IHtcbiAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5OT0RFSlNfMTZfWCxcbiAgICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcicsXG4gICAgY29kZTogbGFtYmRhLkNvZGUuZnJvbUFzc2V0KGAke19fZGlybmFtZX0vbGFtYmRhYClcbiAgfSxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfVxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssICd0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlcicsIHByb3BzKTtcblxuLy8gU3ludGhcbmFwcC5zeW50aCgpO1xuIl19
@@ -875,7 +875,7 @@
875
875
  }
876
876
  },
877
877
  "Handler": "index.handler",
878
- "Runtime": "nodejs14.x",
878
+ "Runtime": "nodejs16.x",
879
879
  "TracingConfig": {
880
880
  "Mode": "Active"
881
881
  },
@@ -33,7 +33,7 @@ const vpc = defaults.buildVpc(stack, {
33
33
  // Definitions
34
34
  const props = {
35
35
  lambdaFunctionProps: {
36
- runtime: lambda.Runtime.NODEJS_14_X,
36
+ runtime: lambda.Runtime.NODEJS_16_X,
37
37
  handler: "index.handler",
38
38
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
39
39
  },
@@ -45,4 +45,4 @@ const props = {
45
45
  new lib_1.LambdaToSecretsmanager(stack, "test-lambda-secretsmanager-stack", props);
46
46
  // Synth
47
47
  app.synth();
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoRXhpc3RpbmdWcGMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5kZXBsb3lGdW5jdGlvbldpdGhFeGlzdGluZ1ZwYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsVUFBVTtBQUNWLDZDQUFzRDtBQUN0RCxnQ0FBNkU7QUFDN0UsaURBQWlEO0FBQ2pELDJEQUEyRDtBQUMzRCx5REFBd0U7QUFFeEUsUUFBUTtBQUNSLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsNkJBQXNCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUNqRSxLQUFLLENBQUMsZUFBZSxDQUFDLFdBQVcsR0FBRyxnREFBZ0QsQ0FBQztBQUVyRixhQUFhO0FBQ2IsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUU7SUFDbkMsZUFBZSxFQUFFLFFBQVEsQ0FBQyw0QkFBNEIsRUFBRTtJQUN4RCxpQkFBaUIsRUFBRTtRQUNqQixrQkFBa0IsRUFBRSxJQUFJO1FBQ3hCLGdCQUFnQixFQUFFLElBQUk7S0FDdkI7Q0FDRixDQUFDLENBQUM7QUFFSCxjQUFjO0FBQ2QsTUFBTSxLQUFLLEdBQWdDO0lBQ3pDLG1CQUFtQixFQUFFO1FBQ25CLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVc7UUFDbkMsT0FBTyxFQUFFLGVBQWU7UUFDeEIsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsU0FBUyxTQUFTLENBQUM7S0FDbkQ7SUFDRCxXQUFXLEVBQUU7UUFDWCxhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO0tBQ3JDO0lBQ0QsV0FBVyxFQUFFLEdBQUc7Q0FDakIsQ0FBQztBQUVGLElBQUksNEJBQXNCLENBQUMsS0FBSyxFQUFFLGtDQUFrQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBRTdFLFFBQVE7QUFDUixHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqICBDb3B5cmlnaHQgQW1hem9uLmNvbSwgSW5jLiBvciBpdHMgYWZmaWxpYXRlcy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiAgTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKS4gWW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuICogIHdpdGggdGhlIExpY2Vuc2UuIEEgY29weSBvZiB0aGUgTGljZW5zZSBpcyBsb2NhdGVkIGF0XG4gKlxuICogICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiAgb3IgaW4gdGhlICdsaWNlbnNlJyBmaWxlIGFjY29tcGFueWluZyB0aGlzIGZpbGUuIFRoaXMgZmlsZSBpcyBkaXN0cmlidXRlZCBvbiBhbiAnQVMgSVMnIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVNcbiAqICBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBleHByZXNzIG9yIGltcGxpZWQuIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9uc1xuICogIGFuZCBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG4vLyBJbXBvcnRzXG5pbXBvcnQge0FwcCwgUmVtb3ZhbFBvbGljeSwgU3RhY2t9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHsgTGFtYmRhVG9TZWNyZXRzbWFuYWdlclByb3BzLCBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyIH0gZnJvbSAnLi4vbGliJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYVwiO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9IFwiSW50ZWdyYXRpb24gVGVzdCBmb3IgYXdzLWxhbWJkYS1zZWNyZXRzbWFuYWdlclwiO1xuXG4vLyBDcmVhdGUgVlBDXG5jb25zdCB2cGMgPSBkZWZhdWx0cy5idWlsZFZwYyhzdGFjaywge1xuICBkZWZhdWx0VnBjUHJvcHM6IGRlZmF1bHRzLkRlZmF1bHRQdWJsaWNQcml2YXRlVnBjUHJvcHMoKSxcbiAgY29uc3RydWN0VnBjUHJvcHM6IHtcbiAgICBlbmFibGVEbnNIb3N0bmFtZXM6IHRydWUsXG4gICAgZW5hYmxlRG5zU3VwcG9ydDogdHJ1ZSxcbiAgfSxcbn0pO1xuXG4vLyBEZWZpbml0aW9uc1xuY29uc3QgcHJvcHM6IExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wcyA9IHtcbiAgbGFtYmRhRnVuY3Rpb25Qcm9wczoge1xuICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5PREVKU18xNF9YLFxuICAgIGhhbmRsZXI6IFwiaW5kZXguaGFuZGxlclwiLFxuICAgIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChgJHtfX2Rpcm5hbWV9L2xhbWJkYWApLFxuICB9LFxuICBzZWNyZXRQcm9wczoge1xuICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuREVTVFJPWVxuICB9LFxuICBleGlzdGluZ1ZwYzogdnBjXG59O1xuXG5uZXcgTGFtYmRhVG9TZWNyZXRzbWFuYWdlcihzdGFjaywgXCJ0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlci1zdGFja1wiLCBwcm9wcyk7XG5cbi8vIFN5bnRoXG5hcHAuc3ludGgoKTtcbiJdfQ==
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoRXhpc3RpbmdWcGMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5kZXBsb3lGdW5jdGlvbldpdGhFeGlzdGluZ1ZwYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsVUFBVTtBQUNWLDZDQUFzRDtBQUN0RCxnQ0FBNkU7QUFDN0UsaURBQWlEO0FBQ2pELDJEQUEyRDtBQUMzRCx5REFBd0U7QUFFeEUsUUFBUTtBQUNSLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsNkJBQXNCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUNqRSxLQUFLLENBQUMsZUFBZSxDQUFDLFdBQVcsR0FBRyxnREFBZ0QsQ0FBQztBQUVyRixhQUFhO0FBQ2IsTUFBTSxHQUFHLEdBQUcsUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUU7SUFDbkMsZUFBZSxFQUFFLFFBQVEsQ0FBQyw0QkFBNEIsRUFBRTtJQUN4RCxpQkFBaUIsRUFBRTtRQUNqQixrQkFBa0IsRUFBRSxJQUFJO1FBQ3hCLGdCQUFnQixFQUFFLElBQUk7S0FDdkI7Q0FDRixDQUFDLENBQUM7QUFFSCxjQUFjO0FBQ2QsTUFBTSxLQUFLLEdBQWdDO0lBQ3pDLG1CQUFtQixFQUFFO1FBQ25CLE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVc7UUFDbkMsT0FBTyxFQUFFLGVBQWU7UUFDeEIsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsU0FBUyxTQUFTLENBQUM7S0FDbkQ7SUFDRCxXQUFXLEVBQUU7UUFDWCxhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO0tBQ3JDO0lBQ0QsV0FBVyxFQUFFLEdBQUc7Q0FDakIsQ0FBQztBQUVGLElBQUksNEJBQXNCLENBQUMsS0FBSyxFQUFFLGtDQUFrQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0FBRTdFLFFBQVE7QUFDUixHQUFHLENBQUMsS0FBSyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqICBDb3B5cmlnaHQgQW1hem9uLmNvbSwgSW5jLiBvciBpdHMgYWZmaWxpYXRlcy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiAgTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZVwiKS4gWW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuICogIHdpdGggdGhlIExpY2Vuc2UuIEEgY29weSBvZiB0aGUgTGljZW5zZSBpcyBsb2NhdGVkIGF0XG4gKlxuICogICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiAgb3IgaW4gdGhlICdsaWNlbnNlJyBmaWxlIGFjY29tcGFueWluZyB0aGlzIGZpbGUuIFRoaXMgZmlsZSBpcyBkaXN0cmlidXRlZCBvbiBhbiAnQVMgSVMnIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVNcbiAqICBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBleHByZXNzIG9yIGltcGxpZWQuIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9uc1xuICogIGFuZCBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuXG4vLyBJbXBvcnRzXG5pbXBvcnQge0FwcCwgUmVtb3ZhbFBvbGljeSwgU3RhY2t9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHsgTGFtYmRhVG9TZWNyZXRzbWFuYWdlclByb3BzLCBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyIH0gZnJvbSAnLi4vbGliJztcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLWxhbWJkYVwiO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9IFwiSW50ZWdyYXRpb24gVGVzdCBmb3IgYXdzLWxhbWJkYS1zZWNyZXRzbWFuYWdlclwiO1xuXG4vLyBDcmVhdGUgVlBDXG5jb25zdCB2cGMgPSBkZWZhdWx0cy5idWlsZFZwYyhzdGFjaywge1xuICBkZWZhdWx0VnBjUHJvcHM6IGRlZmF1bHRzLkRlZmF1bHRQdWJsaWNQcml2YXRlVnBjUHJvcHMoKSxcbiAgY29uc3RydWN0VnBjUHJvcHM6IHtcbiAgICBlbmFibGVEbnNIb3N0bmFtZXM6IHRydWUsXG4gICAgZW5hYmxlRG5zU3VwcG9ydDogdHJ1ZSxcbiAgfSxcbn0pO1xuXG4vLyBEZWZpbml0aW9uc1xuY29uc3QgcHJvcHM6IExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wcyA9IHtcbiAgbGFtYmRhRnVuY3Rpb25Qcm9wczoge1xuICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5PREVKU18xNl9YLFxuICAgIGhhbmRsZXI6IFwiaW5kZXguaGFuZGxlclwiLFxuICAgIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChgJHtfX2Rpcm5hbWV9L2xhbWJkYWApLFxuICB9LFxuICBzZWNyZXRQcm9wczoge1xuICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuREVTVFJPWVxuICB9LFxuICBleGlzdGluZ1ZwYzogdnBjXG59O1xuXG5uZXcgTGFtYmRhVG9TZWNyZXRzbWFuYWdlcihzdGFjaywgXCJ0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlci1zdGFja1wiLCBwcm9wcyk7XG5cbi8vIFN5bnRoXG5hcHAuc3ludGgoKTtcbiJdfQ==
@@ -165,7 +165,7 @@
165
165
  }
166
166
  },
167
167
  "Handler": "index.handler",
168
- "Runtime": "nodejs14.x",
168
+ "Runtime": "nodejs16.x",
169
169
  "TracingConfig": {
170
170
  "Mode": "Active"
171
171
  },
@@ -24,7 +24,7 @@ stack.templateOptions.description = "Integration Test for aws-lambda-secretsmana
24
24
  // Definitions
25
25
  const props = {
26
26
  lambdaFunctionProps: {
27
- runtime: lambda.Runtime.NODEJS_14_X,
27
+ runtime: lambda.Runtime.NODEJS_16_X,
28
28
  handler: "index.handler",
29
29
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
30
30
  },
@@ -36,4 +36,4 @@ const props = {
36
36
  new lib_1.LambdaToSecretsmanager(stack, "test-lambda-secretsmanager", props);
37
37
  // Synth
38
38
  app.synth();
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoVnBjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoVnBjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7R0FXRzs7QUFFSCxVQUFVO0FBQ1YsNkNBQXNEO0FBQ3RELGdDQUE2RTtBQUM3RSxpREFBaUQ7QUFDakQseURBQXdFO0FBRXhFLFFBQVE7QUFDUixNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDakUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEdBQUcsZ0RBQWdELENBQUM7QUFFckYsY0FBYztBQUNkLE1BQU0sS0FBSyxHQUFnQztJQUN6QyxtQkFBbUIsRUFBRTtRQUNuQixPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXO1FBQ25DLE9BQU8sRUFBRSxlQUFlO1FBQ3hCLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLFNBQVMsU0FBUyxDQUFDO0tBQ25EO0lBQ0QsV0FBVyxFQUFFO1FBQ1gsYUFBYSxFQUFFLDJCQUFhLENBQUMsT0FBTztLQUNyQztJQUNELFNBQVMsRUFBRSxJQUFJO0NBQ2hCLENBQUM7QUFFRixJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSw0QkFBNEIsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUV2RSxRQUFRO0FBQ1IsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiAgQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIikuIFlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2VcbiAqICB3aXRoIHRoZSBMaWNlbnNlLiBBIGNvcHkgb2YgdGhlIExpY2Vuc2UgaXMgbG9jYXRlZCBhdFxuICpcbiAqICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogIG9yIGluIHRoZSAnbGljZW5zZScgZmlsZSBhY2NvbXBhbnlpbmcgdGhpcyBmaWxlLiBUaGlzIGZpbGUgaXMgZGlzdHJpYnV0ZWQgb24gYW4gJ0FTIElTJyBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTXG4gKiAgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZXhwcmVzcyBvciBpbXBsaWVkLiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnNcbiAqICBhbmQgbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuLy8gSW1wb3J0c1xuaW1wb3J0IHtBcHAsIFJlbW92YWxQb2xpY3ksIFN0YWNrfSBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCB7IExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wcywgTGFtYmRhVG9TZWNyZXRzbWFuYWdlciB9IGZyb20gJy4uL2xpYic7XG5pbXBvcnQgKiBhcyBsYW1iZGEgZnJvbSAnYXdzLWNkay1saWIvYXdzLWxhbWJkYSc7XG5pbXBvcnQgeyBnZW5lcmF0ZUludGVnU3RhY2tOYW1lIH0gZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcblxuLy8gU2V0dXBcbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgZ2VuZXJhdGVJbnRlZ1N0YWNrTmFtZShfX2ZpbGVuYW1lKSk7XG5zdGFjay50ZW1wbGF0ZU9wdGlvbnMuZGVzY3JpcHRpb24gPSBcIkludGVncmF0aW9uIFRlc3QgZm9yIGF3cy1sYW1iZGEtc2VjcmV0c21hbmFnZXJcIjtcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IHByb3BzOiBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMgPSB7XG4gIGxhbWJkYUZ1bmN0aW9uUHJvcHM6IHtcbiAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5OT0RFSlNfMTRfWCxcbiAgICBoYW5kbGVyOiBcImluZGV4LmhhbmRsZXJcIixcbiAgICBjb2RlOiBsYW1iZGEuQ29kZS5mcm9tQXNzZXQoYCR7X19kaXJuYW1lfS9sYW1iZGFgKSxcbiAgfSxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfSxcbiAgZGVwbG95VnBjOiB0cnVlLFxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssIFwidGVzdC1sYW1iZGEtc2VjcmV0c21hbmFnZXJcIiwgcHJvcHMpO1xuXG4vLyBTeW50aFxuYXBwLnN5bnRoKCk7XG4iXX0=
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoVnBjLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiaW50ZWcuZGVwbG95RnVuY3Rpb25XaXRoVnBjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7Ozs7R0FXRzs7QUFFSCxVQUFVO0FBQ1YsNkNBQXNEO0FBQ3RELGdDQUE2RTtBQUM3RSxpREFBaUQ7QUFDakQseURBQXdFO0FBRXhFLFFBQVE7QUFDUixNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDakUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEdBQUcsZ0RBQWdELENBQUM7QUFFckYsY0FBYztBQUNkLE1BQU0sS0FBSyxHQUFnQztJQUN6QyxtQkFBbUIsRUFBRTtRQUNuQixPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXO1FBQ25DLE9BQU8sRUFBRSxlQUFlO1FBQ3hCLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLFNBQVMsU0FBUyxDQUFDO0tBQ25EO0lBQ0QsV0FBVyxFQUFFO1FBQ1gsYUFBYSxFQUFFLDJCQUFhLENBQUMsT0FBTztLQUNyQztJQUNELFNBQVMsRUFBRSxJQUFJO0NBQ2hCLENBQUM7QUFFRixJQUFJLDRCQUFzQixDQUFDLEtBQUssRUFBRSw0QkFBNEIsRUFBRSxLQUFLLENBQUMsQ0FBQztBQUV2RSxRQUFRO0FBQ1IsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiAgQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIikuIFlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2VcbiAqICB3aXRoIHRoZSBMaWNlbnNlLiBBIGNvcHkgb2YgdGhlIExpY2Vuc2UgaXMgbG9jYXRlZCBhdFxuICpcbiAqICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogIG9yIGluIHRoZSAnbGljZW5zZScgZmlsZSBhY2NvbXBhbnlpbmcgdGhpcyBmaWxlLiBUaGlzIGZpbGUgaXMgZGlzdHJpYnV0ZWQgb24gYW4gJ0FTIElTJyBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTXG4gKiAgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZXhwcmVzcyBvciBpbXBsaWVkLiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnNcbiAqICBhbmQgbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuLy8gSW1wb3J0c1xuaW1wb3J0IHtBcHAsIFJlbW92YWxQb2xpY3ksIFN0YWNrfSBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCB7IExhbWJkYVRvU2VjcmV0c21hbmFnZXJQcm9wcywgTGFtYmRhVG9TZWNyZXRzbWFuYWdlciB9IGZyb20gJy4uL2xpYic7XG5pbXBvcnQgKiBhcyBsYW1iZGEgZnJvbSAnYXdzLWNkay1saWIvYXdzLWxhbWJkYSc7XG5pbXBvcnQgeyBnZW5lcmF0ZUludGVnU3RhY2tOYW1lIH0gZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcblxuLy8gU2V0dXBcbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgZ2VuZXJhdGVJbnRlZ1N0YWNrTmFtZShfX2ZpbGVuYW1lKSk7XG5zdGFjay50ZW1wbGF0ZU9wdGlvbnMuZGVzY3JpcHRpb24gPSBcIkludGVncmF0aW9uIFRlc3QgZm9yIGF3cy1sYW1iZGEtc2VjcmV0c21hbmFnZXJcIjtcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IHByb3BzOiBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMgPSB7XG4gIGxhbWJkYUZ1bmN0aW9uUHJvcHM6IHtcbiAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5OT0RFSlNfMTZfWCxcbiAgICBoYW5kbGVyOiBcImluZGV4LmhhbmRsZXJcIixcbiAgICBjb2RlOiBsYW1iZGEuQ29kZS5mcm9tQXNzZXQoYCR7X19kaXJuYW1lfS9sYW1iZGFgKSxcbiAgfSxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfSxcbiAgZGVwbG95VnBjOiB0cnVlLFxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssIFwidGVzdC1sYW1iZGEtc2VjcmV0c21hbmFnZXJcIiwgcHJvcHMpO1xuXG4vLyBTeW50aFxuYXBwLnN5bnRoKCk7XG4iXX0=
@@ -124,7 +124,7 @@
124
124
  }
125
125
  },
126
126
  "Handler": "index.handler",
127
- "Runtime": "nodejs14.x",
127
+ "Runtime": "nodejs16.x",
128
128
  "TracingConfig": {
129
129
  "Mode": "Active"
130
130
  }
@@ -24,7 +24,7 @@ const stack = new aws_cdk_lib_1.Stack(app, core_1.generateIntegStackName(__filen
24
24
  stack.templateOptions.description = 'Integration Test for aws-lambda-secretsmanager';
25
25
  // Definitions
26
26
  const lambdaFunctionProps = {
27
- runtime: lambda.Runtime.NODEJS_14_X,
27
+ runtime: lambda.Runtime.NODEJS_16_X,
28
28
  handler: 'index.handler',
29
29
  code: lambda.Code.fromAsset(`${__dirname}/lambda`)
30
30
  };
@@ -38,4 +38,4 @@ const props = {
38
38
  new lib_1.LambdaToSecretsmanager(stack, 'test-lambda-secretsmanager', props);
39
39
  // Synth
40
40
  app.synth();
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZXhpc3RpbmdGdW5jdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmV4aXN0aW5nRnVuY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7OztHQVdHOztBQUVILFVBQVU7QUFDViw2Q0FBc0Q7QUFDdEQsZ0NBQTZFO0FBQzdFLGlEQUFpRDtBQUNqRCwyREFBMkQ7QUFDM0QseURBQXdFO0FBRXhFLFFBQVE7QUFDUixNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDakUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEdBQUcsZ0RBQWdELENBQUM7QUFFckYsY0FBYztBQUNkLE1BQU0sbUJBQW1CLEdBQUc7SUFDMUIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVztJQUNuQyxPQUFPLEVBQUUsZUFBZTtJQUN4QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLFNBQVMsQ0FBQztDQUNuRCxDQUFDO0FBRUYsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLG9CQUFvQixDQUFDLEtBQUssRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0FBRXZFLE1BQU0sS0FBSyxHQUFnQztJQUN6QyxpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLFdBQVcsRUFBRTtRQUNYLGFBQWEsRUFBRSwyQkFBYSxDQUFDLE9BQU87S0FDckM7Q0FDRixDQUFDO0FBRUYsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsNEJBQTRCLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFdkUsUUFBUTtBQUNSLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCB7QXBwLCBSZW1vdmFsUG9saWN5LCBTdGFja30gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMsIExhbWJkYVRvU2VjcmV0c21hbmFnZXIgfSBmcm9tICcuLi9saWInO1xuaW1wb3J0ICogYXMgbGFtYmRhIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9ICdJbnRlZ3JhdGlvbiBUZXN0IGZvciBhd3MtbGFtYmRhLXNlY3JldHNtYW5hZ2VyJztcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IGxhbWJkYUZ1bmN0aW9uUHJvcHMgPSB7XG4gIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5PREVKU18xNF9YLFxuICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcicsXG4gIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChgJHtfX2Rpcm5hbWV9L2xhbWJkYWApXG59O1xuXG5jb25zdCBmdW5jID0gZGVmYXVsdHMuZGVwbG95TGFtYmRhRnVuY3Rpb24oc3RhY2ssIGxhbWJkYUZ1bmN0aW9uUHJvcHMpO1xuXG5jb25zdCBwcm9wczogTGFtYmRhVG9TZWNyZXRzbWFuYWdlclByb3BzID0ge1xuICBleGlzdGluZ0xhbWJkYU9iajogZnVuYyxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfVxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssICd0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlcicsIHByb3BzKTtcblxuLy8gU3ludGhcbmFwcC5zeW50aCgpO1xuIl19
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuZXhpc3RpbmdGdW5jdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmV4aXN0aW5nRnVuY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7OztHQVdHOztBQUVILFVBQVU7QUFDViw2Q0FBc0Q7QUFDdEQsZ0NBQTZFO0FBQzdFLGlEQUFpRDtBQUNqRCwyREFBMkQ7QUFDM0QseURBQXdFO0FBRXhFLFFBQVE7QUFDUixNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDakUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEdBQUcsZ0RBQWdELENBQUM7QUFFckYsY0FBYztBQUNkLE1BQU0sbUJBQW1CLEdBQUc7SUFDMUIsT0FBTyxFQUFFLE1BQU0sQ0FBQyxPQUFPLENBQUMsV0FBVztJQUNuQyxPQUFPLEVBQUUsZUFBZTtJQUN4QixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLFNBQVMsQ0FBQztDQUNuRCxDQUFDO0FBRUYsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLG9CQUFvQixDQUFDLEtBQUssRUFBRSxtQkFBbUIsQ0FBQyxDQUFDO0FBRXZFLE1BQU0sS0FBSyxHQUFnQztJQUN6QyxpQkFBaUIsRUFBRSxJQUFJO0lBQ3ZCLFdBQVcsRUFBRTtRQUNYLGFBQWEsRUFBRSwyQkFBYSxDQUFDLE9BQU87S0FDckM7Q0FDRixDQUFDO0FBRUYsSUFBSSw0QkFBc0IsQ0FBQyxLQUFLLEVBQUUsNEJBQTRCLEVBQUUsS0FBSyxDQUFDLENBQUM7QUFFdkUsUUFBUTtBQUNSLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vIEltcG9ydHNcbmltcG9ydCB7QXBwLCBSZW1vdmFsUG9saWN5LCBTdGFja30gZnJvbSBcImF3cy1jZGstbGliXCI7XG5pbXBvcnQgeyBMYW1iZGFUb1NlY3JldHNtYW5hZ2VyUHJvcHMsIExhbWJkYVRvU2VjcmV0c21hbmFnZXIgfSBmcm9tICcuLi9saWInO1xuaW1wb3J0ICogYXMgbGFtYmRhIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0ICogYXMgZGVmYXVsdHMgZnJvbSAnQGF3cy1zb2x1dGlvbnMtY29uc3RydWN0cy9jb3JlJztcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9ICdJbnRlZ3JhdGlvbiBUZXN0IGZvciBhd3MtbGFtYmRhLXNlY3JldHNtYW5hZ2VyJztcblxuLy8gRGVmaW5pdGlvbnNcbmNvbnN0IGxhbWJkYUZ1bmN0aW9uUHJvcHMgPSB7XG4gIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5PREVKU18xNl9YLFxuICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcicsXG4gIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChgJHtfX2Rpcm5hbWV9L2xhbWJkYWApXG59O1xuXG5jb25zdCBmdW5jID0gZGVmYXVsdHMuZGVwbG95TGFtYmRhRnVuY3Rpb24oc3RhY2ssIGxhbWJkYUZ1bmN0aW9uUHJvcHMpO1xuXG5jb25zdCBwcm9wczogTGFtYmRhVG9TZWNyZXRzbWFuYWdlclByb3BzID0ge1xuICBleGlzdGluZ0xhbWJkYU9iajogZnVuYyxcbiAgc2VjcmV0UHJvcHM6IHtcbiAgICByZW1vdmFsUG9saWN5OiBSZW1vdmFsUG9saWN5LkRFU1RST1lcbiAgfVxufTtcblxubmV3IExhbWJkYVRvU2VjcmV0c21hbmFnZXIoc3RhY2ssICd0ZXN0LWxhbWJkYS1zZWNyZXRzbWFuYWdlcicsIHByb3BzKTtcblxuLy8gU3ludGhcbmFwcC5zeW50aCgpO1xuIl19
@@ -10,4 +10,4 @@
10
10
  * OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
11
11
  * and limitations under the License.
12
12
  */
13
- import '@aws-cdk/assert/jest';
13
+ export {};
@@ -18,7 +18,7 @@ const lambda = require("aws-cdk-lib/aws-lambda");
18
18
  const aws_secretsmanager_1 = require("aws-cdk-lib/aws-secretsmanager");
19
19
  const ec2 = require("aws-cdk-lib/aws-ec2");
20
20
  const lib_1 = require("../lib");
21
- require("@aws-cdk/assert/jest");
21
+ const assertions_1 = require("aws-cdk-lib/assertions");
22
22
  const defaults = require("@aws-solutions-constructs/core");
23
23
  // --------------------------------------------------------------
24
24
  // Test the getter methods
@@ -29,7 +29,7 @@ test('Test the properties', () => {
29
29
  // Helper declaration
30
30
  const pattern = new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
31
31
  lambdaFunctionProps: {
32
- runtime: lambda.Runtime.NODEJS_14_X,
32
+ runtime: lambda.Runtime.NODEJS_16_X,
33
33
  handler: 'index.handler',
34
34
  code: lambda.Code.fromAsset(`${__dirname}/lambda`)
35
35
  },
@@ -52,14 +52,15 @@ test('Test deployment w/ existing secret', () => {
52
52
  const existingSecret = new aws_secretsmanager_1.Secret(stack, 'secret', {});
53
53
  const pattern = new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
54
54
  lambdaFunctionProps: {
55
- runtime: lambda.Runtime.NODEJS_14_X,
55
+ runtime: lambda.Runtime.NODEJS_16_X,
56
56
  handler: 'index.handler',
57
57
  code: lambda.Code.fromAsset(`${__dirname}/lambda`)
58
58
  },
59
59
  existingSecretObj: existingSecret
60
60
  });
61
61
  // Assertion 1
62
- expect(stack).toHaveResource("AWS::SecretsManager::Secret", {
62
+ const template = assertions_1.Template.fromStack(stack);
63
+ template.hasResourceProperties("AWS::SecretsManager::Secret", {
63
64
  GenerateSecretString: {},
64
65
  });
65
66
  // Assertion 2
@@ -73,7 +74,7 @@ test('Test deployment w/ existing function', () => {
73
74
  const stack = new aws_cdk_lib_1.Stack();
74
75
  // Helper declaration
75
76
  const lambdaFunctionProps = {
76
- runtime: lambda.Runtime.NODEJS_14_X,
77
+ runtime: lambda.Runtime.NODEJS_16_X,
77
78
  handler: 'index.handler',
78
79
  code: lambda.Code.fromAsset(`${__dirname}/lambda`)
79
80
  };
@@ -83,7 +84,8 @@ test('Test deployment w/ existing function', () => {
83
84
  secretProps: { removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY },
84
85
  });
85
86
  // Assertion 1
86
- expect(stack).toHaveResource("AWS::SecretsManager::Secret", {
87
+ const template = assertions_1.Template.fromStack(stack);
88
+ template.hasResourceProperties("AWS::SecretsManager::Secret", {
87
89
  GenerateSecretString: {},
88
90
  });
89
91
  // Assertion 2
@@ -98,7 +100,7 @@ test('Test minimal deployment write access to Secret', () => {
98
100
  // Helper declaration
99
101
  new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
100
102
  lambdaFunctionProps: {
101
- runtime: lambda.Runtime.NODEJS_14_X,
103
+ runtime: lambda.Runtime.NODEJS_16_X,
102
104
  handler: 'index.handler',
103
105
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
104
106
  },
@@ -106,7 +108,8 @@ test('Test minimal deployment write access to Secret', () => {
106
108
  grantWriteAccess: 'ReadWrite'
107
109
  });
108
110
  // Assertion 1
109
- expect(stack).toHaveResource("AWS::SecretsManager::Secret", {
111
+ const template = assertions_1.Template.fromStack(stack);
112
+ template.hasResourceProperties("AWS::SecretsManager::Secret", {
110
113
  GenerateSecretString: {},
111
114
  });
112
115
  });
@@ -119,14 +122,15 @@ test("Test minimal deployment that deploys a VPC without vpcProps", () => {
119
122
  // Helper declaration
120
123
  new lib_1.LambdaToSecretsmanager(stack, "lambda-to-secretsmanager-stack", {
121
124
  lambdaFunctionProps: {
122
- runtime: lambda.Runtime.NODEJS_14_X,
125
+ runtime: lambda.Runtime.NODEJS_16_X,
123
126
  handler: "index.handler",
124
127
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
125
128
  },
126
129
  secretProps: { removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY },
127
130
  deployVpc: true,
128
131
  });
129
- expect(stack).toHaveResource("AWS::Lambda::Function", {
132
+ const template = assertions_1.Template.fromStack(stack);
133
+ template.hasResourceProperties("AWS::Lambda::Function", {
130
134
  VpcConfig: {
131
135
  SecurityGroupIds: [
132
136
  {
@@ -146,15 +150,15 @@ test("Test minimal deployment that deploys a VPC without vpcProps", () => {
146
150
  ],
147
151
  },
148
152
  });
149
- expect(stack).toHaveResource("AWS::EC2::VPC", {
153
+ template.hasResourceProperties("AWS::EC2::VPC", {
150
154
  EnableDnsHostnames: true,
151
155
  EnableDnsSupport: true,
152
156
  });
153
- expect(stack).toHaveResource("AWS::EC2::VPCEndpoint", {
157
+ template.hasResourceProperties("AWS::EC2::VPCEndpoint", {
154
158
  VpcEndpointType: "Interface",
155
159
  });
156
- expect(stack).toCountResources("AWS::EC2::Subnet", 2);
157
- expect(stack).toCountResources("AWS::EC2::InternetGateway", 0);
160
+ template.resourceCountIs("AWS::EC2::Subnet", 2);
161
+ template.resourceCountIs("AWS::EC2::InternetGateway", 0);
158
162
  });
159
163
  // --------------------------------------------------------------
160
164
  // Test minimal deployment that deploys a VPC w/vpcProps
@@ -165,7 +169,7 @@ test("Test minimal deployment that deploys a VPC w/vpcProps", () => {
165
169
  // Helper declaration
166
170
  new lib_1.LambdaToSecretsmanager(stack, "lambda-to-secretsmanager-stack", {
167
171
  lambdaFunctionProps: {
168
- runtime: lambda.Runtime.NODEJS_14_X,
172
+ runtime: lambda.Runtime.NODEJS_16_X,
169
173
  handler: "index.handler",
170
174
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
171
175
  },
@@ -177,7 +181,8 @@ test("Test minimal deployment that deploys a VPC w/vpcProps", () => {
177
181
  },
178
182
  deployVpc: true,
179
183
  });
180
- expect(stack).toHaveResource("AWS::Lambda::Function", {
184
+ const template = assertions_1.Template.fromStack(stack);
185
+ template.hasResourceProperties("AWS::Lambda::Function", {
181
186
  VpcConfig: {
182
187
  SecurityGroupIds: [
183
188
  {
@@ -197,16 +202,16 @@ test("Test minimal deployment that deploys a VPC w/vpcProps", () => {
197
202
  ],
198
203
  },
199
204
  });
200
- expect(stack).toHaveResource("AWS::EC2::VPC", {
205
+ template.hasResourceProperties("AWS::EC2::VPC", {
201
206
  CidrBlock: "192.68.0.0/16",
202
207
  EnableDnsHostnames: true,
203
208
  EnableDnsSupport: true,
204
209
  });
205
- expect(stack).toHaveResource("AWS::EC2::VPCEndpoint", {
210
+ template.hasResourceProperties("AWS::EC2::VPCEndpoint", {
206
211
  VpcEndpointType: "Interface",
207
212
  });
208
- expect(stack).toCountResources("AWS::EC2::Subnet", 2);
209
- expect(stack).toCountResources("AWS::EC2::InternetGateway", 0);
213
+ template.resourceCountIs("AWS::EC2::Subnet", 2);
214
+ template.resourceCountIs("AWS::EC2::InternetGateway", 0);
210
215
  });
211
216
  // --------------------------------------------------------------
212
217
  // Test minimal deployment with an existing VPC
@@ -218,14 +223,15 @@ test("Test minimal deployment with an existing VPC", () => {
218
223
  // Helper declaration
219
224
  new lib_1.LambdaToSecretsmanager(stack, "lambda-to-secretsmanager-stack", {
220
225
  lambdaFunctionProps: {
221
- runtime: lambda.Runtime.NODEJS_14_X,
226
+ runtime: lambda.Runtime.NODEJS_16_X,
222
227
  handler: "index.handler",
223
228
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
224
229
  },
225
230
  secretProps: { removalPolicy: aws_cdk_lib_1.RemovalPolicy.DESTROY },
226
231
  existingVpc: testVpc,
227
232
  });
228
- expect(stack).toHaveResource("AWS::Lambda::Function", {
233
+ const template = assertions_1.Template.fromStack(stack);
234
+ template.hasResourceProperties("AWS::Lambda::Function", {
229
235
  VpcConfig: {
230
236
  SecurityGroupIds: [
231
237
  {
@@ -245,7 +251,7 @@ test("Test minimal deployment with an existing VPC", () => {
245
251
  ],
246
252
  },
247
253
  });
248
- expect(stack).toHaveResource("AWS::EC2::VPCEndpoint", {
254
+ template.hasResourceProperties("AWS::EC2::VPCEndpoint", {
249
255
  VpcEndpointType: "Interface",
250
256
  });
251
257
  });
@@ -259,7 +265,7 @@ test("Test minimal deployment with an existing VPC and existing Lambda function
259
265
  // Stack
260
266
  const stack = new aws_cdk_lib_1.Stack();
261
267
  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {
262
- runtime: lambda.Runtime.NODEJS_14_X,
268
+ runtime: lambda.Runtime.NODEJS_16_X,
263
269
  handler: "index.handler",
264
270
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
265
271
  });
@@ -287,7 +293,7 @@ test("Test bad call with existingVpc and deployVpc", () => {
287
293
  // Helper declaration
288
294
  new lib_1.LambdaToSecretsmanager(stack, "lambda-to-secretsmanager-stack", {
289
295
  lambdaFunctionProps: {
290
- runtime: lambda.Runtime.NODEJS_14_X,
296
+ runtime: lambda.Runtime.NODEJS_16_X,
291
297
  handler: "index.handler",
292
298
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
293
299
  },
@@ -308,7 +314,7 @@ test('Test lambda function custom environment variable', () => {
308
314
  // Helper declaration
309
315
  new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
310
316
  lambdaFunctionProps: {
311
- runtime: lambda.Runtime.NODEJS_14_X,
317
+ runtime: lambda.Runtime.NODEJS_16_X,
312
318
  handler: 'index.handler',
313
319
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
314
320
  environment: {
@@ -319,9 +325,10 @@ test('Test lambda function custom environment variable', () => {
319
325
  secretEnvironmentVariableName: 'CUSTOM_SECRET_NAME'
320
326
  });
321
327
  // Assertion
322
- expect(stack).toHaveResource('AWS::Lambda::Function', {
328
+ const template = assertions_1.Template.fromStack(stack);
329
+ template.hasResourceProperties('AWS::Lambda::Function', {
323
330
  Handler: 'index.handler',
324
- Runtime: 'nodejs14.x',
331
+ Runtime: 'nodejs16.x',
325
332
  Environment: {
326
333
  Variables: {
327
334
  AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',
@@ -344,7 +351,7 @@ test('Test overriding secretProps to pass a customer provided CMK', () => {
344
351
  // Helper declaration
345
352
  new lib_1.LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {
346
353
  lambdaFunctionProps: {
347
- runtime: lambda.Runtime.NODEJS_14_X,
354
+ runtime: lambda.Runtime.NODEJS_16_X,
348
355
  handler: 'index.handler',
349
356
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
350
357
  environment: {
@@ -356,9 +363,10 @@ test('Test overriding secretProps to pass a customer provided CMK', () => {
356
363
  }
357
364
  });
358
365
  // Assertion 1
359
- expect(stack).toHaveResource('AWS::Lambda::Function', {
366
+ const template = assertions_1.Template.fromStack(stack);
367
+ template.hasResourceProperties('AWS::Lambda::Function', {
360
368
  Handler: 'index.handler',
361
- Runtime: 'nodejs14.x',
369
+ Runtime: 'nodejs16.x',
362
370
  Environment: {
363
371
  Variables: {
364
372
  AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',
@@ -369,7 +377,7 @@ test('Test overriding secretProps to pass a customer provided CMK', () => {
369
377
  }
370
378
  });
371
379
  // Assertion 2
372
- expect(stack).toHaveResource("AWS::SecretsManager::Secret", {
380
+ template.hasResourceProperties("AWS::SecretsManager::Secret", {
373
381
  GenerateSecretString: {},
374
382
  KmsKeyId: {
375
383
  "Fn::GetAtt": [
@@ -379,9 +387,9 @@ test('Test overriding secretProps to pass a customer provided CMK', () => {
379
387
  }
380
388
  });
381
389
  // Assertion 3
382
- expect(stack).toHaveResource('AWS::KMS::Key', {
390
+ template.hasResourceProperties('AWS::KMS::Key', {
383
391
  Description: "secret-key",
384
392
  EnableKeyRotation: true
385
393
  });
386
394
  });
387
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-secretsmanager.test.js","sourceRoot":"","sources":["lambda-secretsmanager.test.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;GAWG;;AAEH,UAAU;AACV,6CAAmD;AACnD,iDAAiD;AACjD,uEAAwD;AACxD,2CAA2C;AAC3C,gCAAgD;AAChD,gCAA8B;AAC9B,2DAA2D;AAE3D,iEAAiE;AACjE,0BAA0B;AAC1B,iEAAiE;AACjE,IAAI,CAAC,qBAAqB,EAAE,GAAG,EAAE;IAC/B,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;KACtD,CAAC,CAAC;IACH,cAAc;IACd,MAAM,IAAI,GAAG,OAAO,CAAC,cAAc,CAAC;IACpC,MAAM,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,CAAC;IAC3B,cAAc;IACd,MAAM,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAC9B,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;AAC/B,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,qCAAqC;AACrC,iEAAiE;AACjE,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAC9C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,cAAc,GAAG,IAAI,2BAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,CAAC,CAAC;IACvD,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,iBAAiB,EAAE,cAAc;KAClC,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,6BAA6B,EAAE;QAC1D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;AAC9C,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,uCAAuC;AACvC,iEAAiE;AACjE,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;IAChD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,MAAM,mBAAmB,GAAG;QAC1B,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;QACnC,OAAO,EAAE,eAAe;QACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;KACnD,CAAC;IACF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,oBAAoB,CAAC,KAAK,EAAE,mBAAmB,CAAC,CAAC;IAEnF,MAAM,OAAO,GAAG,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClF,iBAAiB,EAAE,gBAAgB;QACnC,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;KACtD,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,6BAA6B,EAAE;QAC1D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;AACxD,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,sDAAsD;AACtD,iEAAiE;AACjE,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;IAC1D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,gBAAgB,EAAE,WAAW;KAC9B,CAAC,CAAC;IACH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,6BAA6B,EAAE;QAC1D,oBAAoB,EAAE,EAAE;KACzB,CAAC,CAAC;AAEL,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,8DAA8D;AAC9D,iEAAiE;AACjE,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;IACvE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,SAAS,EAAE,IAAI;KAChB,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,kCAAkC;iBACxC;gBACD;oBACE,GAAG,EAAE,kCAAkC;iBACxC;aACF;SACF;KACF,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,eAAe,EAAE;QAC5C,kBAAkB,EAAE,IAAI;QACxB,gBAAgB,EAAE,IAAI;KACvB,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC;IACtD,MAAM,CAAC,KAAK,CAAC,CAAC,gBAAgB,CAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC;AACjE,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,wDAAwD;AACxD,iEAAiE;AACjE,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;IACjE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAC1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,QAAQ,EAAE;YACR,kBAAkB,EAAE,KAAK;YACzB,gBAAgB,EAAE,KAAK;YACvB,WAAW,EAAE,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC;SACnD;QACD,SAAS,EAAE,IAAI;KAChB,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,kCAAkC;iBACxC;gBACD;oBACE,GAAG,EAAE,kCAAkC;iBACxC;aACF;SACF;KACF,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,eAAe,EAAE;QAC5C,SAAS,EAAE,eAAe;QAC1B,kBAAkB,EAAE,IAAI;QACxB,gBAAgB,EAAE,IAAI;KACvB,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC;IACtD,MAAM,CAAC,KAAK,CAAC,CAAC,gBAAgB,CAAC,2BAA2B,EAAE,CAAC,CAAC,CAAC;AACjE,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,+CAA+C;AAC/C,iEAAiE;AACjE,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;IACxD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;SACnD;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,WAAW,EAAE,OAAO;KACrB,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,SAAS,EAAE;YACT,gBAAgB,EAAE;gBAChB;oBACE,YAAY,EAAE;wBACZ,6EAA6E;wBAC7E,SAAS;qBACV;iBACF;aACF;YACD,SAAS,EAAE;gBACT;oBACE,GAAG,EAAE,qCAAqC;iBAC3C;gBACD;oBACE,GAAG,EAAE,qCAAqC;iBAC3C;aACF;SACF;KACF,CAAC,CAAC;IAEH,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,eAAe,EAAE,WAAW;KAC7B,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,yFAAyF;AACzF,EAAE;AACF,0EAA0E;AAC1E,oBAAoB;AACpB,iEAAiE;AACjE,IAAI,CAAC,wFAAwF,EAAE,GAAG,EAAE;IAClG,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,kBAAkB,GAAG,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,EAAE;QAClE,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;QACnC,OAAO,EAAE,eAAe;QACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;KACnD,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,qBAAqB;IACrB,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,qBAAqB;QACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;YAClE,iBAAiB,EAAE,kBAAkB;YACrC,WAAW,EAAE,OAAO;YACpB,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;SACtD,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC;AAE7B,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,+CAA+C;AAC/C,iEAAiE;AACjE,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;IACxD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAEnD,MAAM,GAAG,GAAG,GAAG,EAAE;QACf,qBAAqB;QACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;YAClE,mBAAmB,EAAE;gBACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;gBACnC,OAAO,EAAE,eAAe;gBACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;aACnD;YACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;YACrD,WAAW,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI;SAChB,CAAC,CAAC;IACL,CAAC,CAAC;IACF,YAAY;IACZ,MAAM,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC;AAC7B,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,mDAAmD;AACnD,iEAAiE;AACjE,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;IAC5D,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;YAClD,WAAW,EAAE;gBACX,mCAAmC,EAAE,GAAG;aACzC;SACF;QACD,WAAW,EAAE,EAAE,aAAa,EAAE,2BAAa,CAAC,OAAO,EAAE;QACrD,6BAA6B,EAAE,oBAAoB;KACpD,CAAC,CAAC;IAEH,YAAY;IACZ,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,OAAO,EAAE,eAAe;QACxB,OAAO,EAAE,YAAY;QACrB,WAAW,EAAE;YACX,SAAS,EAAE;gBACT,mCAAmC,EAAE,GAAG;gBACxC,kBAAkB,EAAE;oBAClB,GAAG,EAAE,2CAA2C;iBACjD;aACF;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,iEAAiE;AACjE,8DAA8D;AAC9D,iEAAiE;AACjE,IAAI,CAAC,6DAA6D,EAAE,GAAG,EAAE;IACvE,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,aAAa,GAAG,QAAQ,CAAC,kBAAkB,CAAC,KAAK,EAAE;QACvD,WAAW,EAAE,YAAY;KAC1B,CAAC,CAAC;IAEH,qBAAqB;IACrB,IAAI,4BAAsB,CAAC,KAAK,EAAE,gCAAgC,EAAE;QAClE,mBAAmB,EAAE;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,WAAW;YACnC,OAAO,EAAE,eAAe;YACxB,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,SAAS,SAAS,CAAC;YAClD,WAAW,EAAE;gBACX,mCAAmC,EAAE,GAAG;aACzC;SACF;QACD,WAAW,EAAE;YACX,aAAa;SACd;KACF,CAAC,CAAC;IAEH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,uBAAuB,EAAE;QACpD,OAAO,EAAE,eAAe;QACxB,OAAO,EAAE,YAAY;QACrB,WAAW,EAAE;YACX,SAAS,EAAE;gBACT,mCAAmC,EAAE,GAAG;gBACxC,UAAU,EAAE;oBACV,GAAG,EAAE,2CAA2C;iBACjD;aACF;SACF;KACF,CAAC,CAAC;IAEH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,6BAA6B,EAAE;QAC1D,oBAAoB,EAAE,EAAE;QACxB,QAAQ,EAAE;YACR,YAAY,EAAE;gBACZ,uBAAuB;gBACvB,KAAK;aACN;SACF;KACF,CAAC,CAAC;IAEH,cAAc;IACd,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,eAAe,EAAE;QAC5C,WAAW,EAAE,YAAY;QACzB,iBAAiB,EAAE,IAAI;KACxB,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport { RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport { Secret } from 'aws-cdk-lib/aws-secretsmanager';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { LambdaToSecretsmanager } from '../lib';\nimport '@aws-cdk/assert/jest';\nimport * as defaults from \"@aws-solutions-constructs/core\";\n\n// --------------------------------------------------------------\n// Test the getter methods\n// --------------------------------------------------------------\ntest('Test the properties', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const func = pattern.lambdaFunction;\n  expect(func).toBeDefined();\n  // Assertion 2\n  const secret = pattern.secret;\n  expect(secret).toBeDefined();\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing secret\n// --------------------------------------------------------------\ntest('Test deployment w/ existing secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const existingSecret = new Secret(stack, 'secret', {});\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    existingSecretObj: existingSecret\n  });\n  // Assertion 1\n  expect(stack).toHaveResource(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.secret).toBe(existingSecret);\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing function\n// --------------------------------------------------------------\ntest('Test deployment w/ existing function', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const lambdaFunctionProps = {\n    runtime: lambda.Runtime.NODEJS_14_X,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n  };\n  const existingFunction = defaults.deployLambdaFunction(stack, lambdaFunctionProps);\n\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    existingLambdaObj: existingFunction,\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  expect(stack).toHaveResource(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.lambdaFunction).toBe(existingFunction);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with write access to Secret\n// --------------------------------------------------------------\ntest('Test minimal deployment write access to Secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    grantWriteAccess: 'ReadWrite'\n  });\n  // Assertion 1\n  expect(stack).toHaveResource(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC without vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC without vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    deployVpc: true,\n  });\n\n  expect(stack).toHaveResource(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  expect(stack).toHaveResource(\"AWS::EC2::VPC\", {\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  expect(stack).toHaveResource(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  expect(stack).toCountResources(\"AWS::EC2::Subnet\", 2);\n  expect(stack).toCountResources(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC w/vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC w/vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    vpcProps: {\n      enableDnsHostnames: false,\n      enableDnsSupport: false,\n      ipAddresses: ec2.IpAddresses.cidr(\"192.68.0.0/16\"),\n    },\n    deployVpc: true,\n  });\n\n  expect(stack).toHaveResource(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  expect(stack).toHaveResource(\"AWS::EC2::VPC\", {\n    CidrBlock: \"192.68.0.0/16\",\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  expect(stack).toHaveResource(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  expect(stack).toCountResources(\"AWS::EC2::Subnet\", 2);\n  expect(stack).toCountResources(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    existingVpc: testVpc,\n  });\n\n  expect(stack).toHaveResource(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"testvpcPrivateSubnet1Subnet865FB50A\",\n        },\n        {\n          Ref: \"testvpcPrivateSubnet2Subnet23D3396F\",\n        },\n      ],\n    },\n  });\n\n  expect(stack).toHaveResource(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\n//\n// buildLambdaFunction should throw an error if the Lambda function is not\n// attached to a VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {\n    runtime: lambda.Runtime.NODEJS_14_X,\n    handler: \"index.handler\",\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      existingLambdaObj: testLambdaFunction,\n      existingVpc: testVpc,\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    });\n  };\n\n  // Assertion\n  expect(app).toThrowError();\n\n});\n\n// --------------------------------------------------------------\n// Test bad call with existingVpc and deployVpc\n// --------------------------------------------------------------\ntest(\"Test bad call with existingVpc and deployVpc\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      lambdaFunctionProps: {\n        runtime: lambda.Runtime.NODEJS_14_X,\n        handler: \"index.handler\",\n        code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      },\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n      existingVpc: testVpc,\n      deployVpc: true,\n    });\n  };\n  // Assertion\n  expect(app).toThrowError();\n});\n\n// --------------------------------------------------------------\n// Test lambda function custom environment variable\n// --------------------------------------------------------------\ntest('Test lambda function custom environment variable', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    secretEnvironmentVariableName: 'CUSTOM_SECRET_NAME'\n  });\n\n  // Assertion\n  expect(stack).toHaveResource('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs14.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        CUSTOM_SECRET_NAME: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n});\n\n// --------------------------------------------------------------\n// Test overriding secretProps to pass a customer provided CMK\n// --------------------------------------------------------------\ntest('Test overriding secretProps to pass a customer provided CMK', () => {\n  // Stack\n  const stack = new Stack();\n\n  const encryptionKey = defaults.buildEncryptionKey(stack, {\n    description: 'secret-key'\n  });\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_14_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: {\n      encryptionKey\n    }\n  });\n\n  // Assertion 1\n  expect(stack).toHaveResource('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs14.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        SECRET_ARN: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n\n  // Assertion 2\n  expect(stack).toHaveResource(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n    KmsKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  // Assertion 3\n  expect(stack).toHaveResource('AWS::KMS::Key', {\n    Description: \"secret-key\",\n    EnableKeyRotation: true\n  });\n});\n"]}
395
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lambda-secretsmanager.test.js","sourceRoot":"","sources":["lambda-secretsmanager.test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n// Imports\nimport { RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport * as lambda from \"aws-cdk-lib/aws-lambda\";\nimport { Secret } from 'aws-cdk-lib/aws-secretsmanager';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\nimport { LambdaToSecretsmanager } from '../lib';\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as defaults from \"@aws-solutions-constructs/core\";\n\n// --------------------------------------------------------------\n// Test the getter methods\n// --------------------------------------------------------------\ntest('Test the properties', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const func = pattern.lambdaFunction;\n  expect(func).toBeDefined();\n  // Assertion 2\n  const secret = pattern.secret;\n  expect(secret).toBeDefined();\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing secret\n// --------------------------------------------------------------\ntest('Test deployment w/ existing secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const existingSecret = new Secret(stack, 'secret', {});\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n    },\n    existingSecretObj: existingSecret\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.secret).toBe(existingSecret);\n});\n\n// --------------------------------------------------------------\n// Test deployment w/ existing function\n// --------------------------------------------------------------\ntest('Test deployment w/ existing function', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  const lambdaFunctionProps = {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n  };\n  const existingFunction = defaults.deployLambdaFunction(stack, lambdaFunctionProps);\n\n  const pattern = new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    existingLambdaObj: existingFunction,\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n  // Assertion 2\n  expect(pattern.lambdaFunction).toBe(existingFunction);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with write access to Secret\n// --------------------------------------------------------------\ntest('Test minimal deployment write access to Secret', () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    grantWriteAccess: 'ReadWrite'\n  });\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n  });\n\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC without vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC without vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment that deploys a VPC w/vpcProps\n// --------------------------------------------------------------\ntest(\"Test minimal deployment that deploys a VPC w/vpcProps\", () => {\n  // Stack\n  const stack = new Stack();\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    vpcProps: {\n      enableDnsHostnames: false,\n      enableDnsSupport: false,\n      ipAddresses: ec2.IpAddresses.cidr(\"192.68.0.0/16\"),\n    },\n    deployVpc: true,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"VpcisolatedSubnet1SubnetE62B1B9B\",\n        },\n        {\n          Ref: \"VpcisolatedSubnet2Subnet39217055\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPC\", {\n    CidrBlock: \"192.68.0.0/16\",\n    EnableDnsHostnames: true,\n    EnableDnsSupport: true,\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n\n  template.resourceCountIs(\"AWS::EC2::Subnet\", 2);\n  template.resourceCountIs(\"AWS::EC2::InternetGateway\", 0);\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: \"index.handler\",\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    existingVpc: testVpc,\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::Lambda::Function\", {\n    VpcConfig: {\n      SecurityGroupIds: [\n        {\n          \"Fn::GetAtt\": [\n            \"lambdatosecretsmanagerstackReplaceDefaultSecurityGroupsecuritygroupED420155\",\n            \"GroupId\",\n          ],\n        },\n      ],\n      SubnetIds: [\n        {\n          Ref: \"testvpcPrivateSubnet1Subnet865FB50A\",\n        },\n        {\n          Ref: \"testvpcPrivateSubnet2Subnet23D3396F\",\n        },\n      ],\n    },\n  });\n\n  template.hasResourceProperties(\"AWS::EC2::VPCEndpoint\", {\n    VpcEndpointType: \"Interface\",\n  });\n});\n\n// --------------------------------------------------------------\n// Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\n//\n// buildLambdaFunction should throw an error if the Lambda function is not\n// attached to a VPC\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with an existing VPC and existing Lambda function not in a VPC\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testLambdaFunction = new lambda.Function(stack, 'test-lamba', {\n    runtime: lambda.Runtime.NODEJS_16_X,\n    handler: \"index.handler\",\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      existingLambdaObj: testLambdaFunction,\n      existingVpc: testVpc,\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    });\n  };\n\n  // Assertion\n  expect(app).toThrowError();\n\n});\n\n// --------------------------------------------------------------\n// Test bad call with existingVpc and deployVpc\n// --------------------------------------------------------------\ntest(\"Test bad call with existingVpc and deployVpc\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const testVpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  const app = () => {\n    // Helper declaration\n    new LambdaToSecretsmanager(stack, \"lambda-to-secretsmanager-stack\", {\n      lambdaFunctionProps: {\n        runtime: lambda.Runtime.NODEJS_16_X,\n        handler: \"index.handler\",\n        code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      },\n      secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n      existingVpc: testVpc,\n      deployVpc: true,\n    });\n  };\n  // Assertion\n  expect(app).toThrowError();\n});\n\n// --------------------------------------------------------------\n// Test lambda function custom environment variable\n// --------------------------------------------------------------\ntest('Test lambda function custom environment variable', () => {\n  // Stack\n  const stack = new Stack();\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: { removalPolicy: RemovalPolicy.DESTROY },\n    secretEnvironmentVariableName: 'CUSTOM_SECRET_NAME'\n  });\n\n  // Assertion\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        CUSTOM_SECRET_NAME: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n});\n\n// --------------------------------------------------------------\n// Test overriding secretProps to pass a customer provided CMK\n// --------------------------------------------------------------\ntest('Test overriding secretProps to pass a customer provided CMK', () => {\n  // Stack\n  const stack = new Stack();\n\n  const encryptionKey = defaults.buildEncryptionKey(stack, {\n    description: 'secret-key'\n  });\n\n  // Helper declaration\n  new LambdaToSecretsmanager(stack, 'lambda-to-secretsmanager-stack', {\n    lambdaFunctionProps: {\n      runtime: lambda.Runtime.NODEJS_16_X,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      environment: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n      }\n    },\n    secretProps: {\n      encryptionKey\n    }\n  });\n\n  // Assertion 1\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: 'index.handler',\n    Runtime: 'nodejs16.x',\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: '1',\n        SECRET_ARN: {\n          Ref: 'lambdatosecretsmanagerstacksecretBA684E34'\n        }\n      }\n    }\n  });\n\n  // Assertion 2\n  template.hasResourceProperties(\"AWS::SecretsManager::Secret\", {\n    GenerateSecretString: {},\n    KmsKeyId: {\n      \"Fn::GetAtt\": [\n        \"EncryptionKey1B843E66\",\n        \"Arn\"\n      ]\n    }\n  });\n\n  // Assertion 3\n  template.hasResourceProperties('AWS::KMS::Key', {\n    Description: \"secret-key\",\n    EnableKeyRotation: true\n  });\n});\n"]}