@aws-solutions-constructs/aws-cloudfront-apigateway-lambda 2.99.0 → 2.100.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.
Files changed (38) hide show
  1. package/.jsii +9 -12
  2. package/lib/index.js +4 -2
  3. package/package.json +8 -9
  4. package/test/cloudfront-apigateway-lambda.test.js +399 -0
  5. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js +2 -2
  6. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/cdk.out +1 -1
  7. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/cftaplam-customCloudfrontLoggingBucket.assets.json +4 -4
  8. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/cftaplam-customCloudfrontLoggingBucket.template.json +1 -4
  9. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/cftaplamcustomCloudfrontLoggingBucketIntegDefaultTestDeployAssert35A683E0.assets.json +1 -1
  10. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/integ.json +2 -2
  11. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/manifest.json +23 -31
  12. package/test/integ.cftaplam-customCloudfrontLoggingBucket.js.snapshot/tree.json +1 -1
  13. package/test/integ.cftaplam-no-arguments.js +2 -2
  14. package/test/integ.cftaplam-no-arguments.js.snapshot/cdk.out +1 -1
  15. package/test/integ.cftaplam-no-arguments.js.snapshot/cftaplam-no-arguments.assets.json +4 -4
  16. package/test/integ.cftaplam-no-arguments.js.snapshot/cftaplam-no-arguments.template.json +1 -4
  17. package/test/integ.cftaplam-no-arguments.js.snapshot/cftaplamnoargumentsIntegDefaultTestDeployAssertACC32F59.assets.json +1 -1
  18. package/test/integ.cftaplam-no-arguments.js.snapshot/integ.json +2 -2
  19. package/test/integ.cftaplam-no-arguments.js.snapshot/manifest.json +23 -31
  20. package/test/integ.cftaplam-no-arguments.js.snapshot/tree.json +1 -1
  21. package/test/integ.cftaplam-no-usage-plan.js +2 -2
  22. package/test/integ.cftaplam-no-usage-plan.js.snapshot/cdk.out +1 -1
  23. package/test/integ.cftaplam-no-usage-plan.js.snapshot/cftaplam-no-usage-plan.assets.json +4 -4
  24. package/test/integ.cftaplam-no-usage-plan.js.snapshot/cftaplam-no-usage-plan.template.json +1 -4
  25. package/test/integ.cftaplam-no-usage-plan.js.snapshot/cftaplamnousageplanIntegDefaultTestDeployAssertABA4F4C5.assets.json +1 -1
  26. package/test/integ.cftaplam-no-usage-plan.js.snapshot/integ.json +2 -2
  27. package/test/integ.cftaplam-no-usage-plan.js.snapshot/manifest.json +23 -31
  28. package/test/integ.cftaplam-no-usage-plan.js.snapshot/tree.json +1 -1
  29. package/test/integ.cftaplam-override-behavior.js +2 -2
  30. package/test/integ.cftaplam-override-behavior.js.snapshot/cdk.out +1 -1
  31. package/test/integ.cftaplam-override-behavior.js.snapshot/cftaplam-override-behavior.assets.json +4 -4
  32. package/test/integ.cftaplam-override-behavior.js.snapshot/cftaplam-override-behavior.template.json +1 -4
  33. package/test/integ.cftaplam-override-behavior.js.snapshot/cftaplamoverridebehaviorIntegDefaultTestDeployAssert3DC30427.assets.json +1 -1
  34. package/test/integ.cftaplam-override-behavior.js.snapshot/integ.json +2 -2
  35. package/test/integ.cftaplam-override-behavior.js.snapshot/manifest.json +23 -31
  36. package/test/integ.cftaplam-override-behavior.js.snapshot/tree.json +1 -1
  37. package/test/test.cloudfront-apigateway-lambda.test.js +0 -364
  38. /package/test/{test.cloudfront-apigateway-lambda.test.d.ts → cloudfront-apigateway-lambda.test.d.ts} +0 -0
package/.jsii CHANGED
@@ -8,9 +8,9 @@
8
8
  "url": "https://aws.amazon.com"
9
9
  },
10
10
  "dependencies": {
11
- "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.99.0",
12
- "@aws-solutions-constructs/core": "2.99.0",
13
- "aws-cdk-lib": "^2.238.0",
11
+ "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.100.0",
12
+ "@aws-solutions-constructs/core": "2.100.0",
13
+ "aws-cdk-lib": "^2.239.0",
14
14
  "constructs": "^10.0.0"
15
15
  },
16
16
  "dependencyClosure": {
@@ -101,8 +101,7 @@
101
101
  "dotnet": {
102
102
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png",
103
103
  "namespace": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGateway",
104
- "packageId": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGateway",
105
- "signAssembly": true
104
+ "packageId": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGateway"
106
105
  },
107
106
  "java": {
108
107
  "maven": {
@@ -125,8 +124,7 @@
125
124
  "dotnet": {
126
125
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png",
127
126
  "namespace": "Amazon.SolutionsConstructs.AWS.Core",
128
- "packageId": "Amazon.SolutionsConstructs.AWS.Core",
129
- "signAssembly": true
127
+ "packageId": "Amazon.SolutionsConstructs.AWS.Core"
130
128
  },
131
129
  "java": {
132
130
  "maven": {
@@ -8546,7 +8544,7 @@
8546
8544
  },
8547
8545
  "description": "CDK Constructs for AWS Cloudfront to AWS API Gateway to AWS Lambda integration.",
8548
8546
  "homepage": "https://github.com/awslabs/aws-solutions-constructs.git",
8549
- "jsiiVersion": "5.9.8 (build 3d2e131)",
8547
+ "jsiiVersion": "5.9.28 (build cbad63d)",
8550
8548
  "keywords": [
8551
8549
  "aws",
8552
8550
  "cdk",
@@ -8578,8 +8576,7 @@
8578
8576
  "dotnet": {
8579
8577
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png",
8580
8578
  "namespace": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGatewayLambda",
8581
- "packageId": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGatewayLambda",
8582
- "signAssembly": true
8579
+ "packageId": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGatewayLambda"
8583
8580
  },
8584
8581
  "java": {
8585
8582
  "maven": {
@@ -8910,6 +8907,6 @@
8910
8907
  "symbolId": "lib/index:CloudFrontToApiGatewayToLambdaProps"
8911
8908
  }
8912
8909
  },
8913
- "version": "2.99.0",
8914
- "fingerprint": "PmYYbK+N3BN6wxmJXKZQmOZOJpbMhNgk4JQjK0iGKq4="
8910
+ "version": "2.100.0",
8911
+ "fingerprint": "Pzq/kAtuUsPNTRgHliXp+ertEGuoe9zZulZAPuE619o="
8915
8912
  }
package/lib/index.js CHANGED
@@ -20,6 +20,8 @@ class CloudFrontToApiGatewayToLambda extends constructs_1.Construct {
20
20
  super(scope, id);
21
21
  defaults.CheckLambdaProps(props);
22
22
  defaults.CheckApiProps(props);
23
+ defaults.ValidateLambdaRestApiProps(this, props.apiGatewayProps);
24
+ defaults.ValidateDistributionProps(this, props.cloudFrontDistributionProps);
23
25
  // CheckCloudFrontProps() is called by internal aws-cloudfront-apigateway construct
24
26
  if (!props.apiGatewayProps?.defaultMethodOptions?.authorizationType) {
25
27
  defaults.printWarning('As of v2.48.0, apiGatewayProps.defaultMethodOptions.authorizationType is\
@@ -57,5 +59,5 @@ class CloudFrontToApiGatewayToLambda extends constructs_1.Construct {
57
59
  }
58
60
  exports.CloudFrontToApiGatewayToLambda = CloudFrontToApiGatewayToLambda;
59
61
  _a = JSII_RTTI_SYMBOL_1;
60
- CloudFrontToApiGatewayToLambda[_a] = { fqn: "@aws-solutions-constructs/aws-cloudfront-apigateway-lambda.CloudFrontToApiGatewayToLambda", version: "2.99.0" };
61
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAmBA,2DAA2D;AAC3D,wFAAwF;AACxF,2CAAuC;AACvC,mGAA6F;AA4E7F,MAAa,8BAA+B,SAAQ,sBAAS;IAS3D;;;;;;;OAOG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0C;QAClF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACjC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAE9B,mFAAmF;QACnF,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,CAAC;YACpE,QAAQ,CAAC,YAAY,CAAC;;4IAEgH,CAAC,CAAC;YACxI,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;QACnH,CAAC;aAAM,IAAI,KAAK,CAAC,eAAe,CAAC,oBAAoB,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;YACtF,MAAM,IAAI,KAAK,CAAC,qGAAqG,CAAC,CAAC;QACzH,CAAC;QAED,wEAAwE;QACxE,2DAA2D;QAC3D,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,iDAAiD,EAAE,IAAI,CAAC,CAAC;QAE9E,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE;YACvD,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;YAC1C,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;SAC/C,CAAC,CAAC;QAEH,4EAA4E;QAC5E,6EAA6E;QAC7E,MAAM,6BAA6B,GAAG,QAAQ,CAAC,qBAAqB,CAAC,IAAI,EACvE,IAAI,CAAC,cAAc,EACnB,KAAK,CAAC,eAAe,EACrB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,eAAe,EACrB,KAAK,CAAC,CAAC;QACT,IAAI,CAAC,UAAU,GAAG,6BAA6B,CAAC,GAAG,CAAC;QACpD,IAAI,CAAC,wBAAwB,GAAG,6BAA6B,CAAC,IAAI,CAAC;QACnE,IAAI,CAAC,kBAAkB,GAAG,6BAA6B,CAAC,KAAK,CAAC;QAE9D,MAAM,aAAa,GAA2B,IAAI,kDAAsB,CAAC,IAAI,EAAE,wBAAwB,EAAE;YACvG,qBAAqB,EAAE,IAAI,CAAC,UAAU;YACtC,2BAA2B,EAAE,KAAK,CAAC,2BAA2B;YAC9D,yBAAyB,EAAE,KAAK,CAAC,yBAAyB;YAC1D,4BAA4B,EAAE,KAAK,CAAC,4BAA4B;YAChE,0BAA0B,EAAE,KAAK,CAAC,0BAA0B;SAC7D,CAAC,CAAC;QAEH,IAAI,CAAC,yBAAyB,GAAG,aAAa,CAAC,yBAAyB,CAAC;QACzE,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC,kBAAkB,CAAC;QAC3D,IAAI,CAAC,uBAAuB,GAAG,aAAa,CAAC,uBAAuB,CAAC;IACvE,CAAC;;AAhEH,wEAiEC","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\nimport * as api from 'aws-cdk-lib/aws-apigateway';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as defaults from '@aws-solutions-constructs/core';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\nimport { CloudFrontToApiGateway } from '@aws-solutions-constructs/aws-cloudfront-apigateway';\n\n/**\n * @summary The properties for the CloudFrontToApiGatewayToLambda Construct\n */\nexport interface CloudFrontToApiGatewayToLambdaProps {\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   * Optional - user provided props to override the default props for the Lambda function. Providing both this and `existingLambdaObj`\n   * causes an error.\n   *\n   * @default - Default props are used\n   */\n  readonly lambdaFunctionProps?: lambda.FunctionProps\n  /**\n   * User provided props to override the default props for the API Gateway. As of release\n   * 2.48.0, clients must include this property with defaultMethodOptions: { authorizationType: string } specified.\n   * See Issue1043 in the github repo https://github.com/awslabs/aws-solutions-constructs/issues/1043\n   *\n   * @default - defaultMethodOptions/authorizationType is required, for other, unspecified values the\n   * default props are used\n   */\n  readonly apiGatewayProps: api.LambdaRestApiProps | any\n  /**\n   * Whether to create a Usage Plan attached to the API. Must be true if\n   * apiGatewayProps.defaultMethodOptions.apiKeyRequired is true\n   *\n   * @default - true (to match legacy behavior)\n   */\n  readonly createUsagePlan?: boolean\n  /**\n   * Optional user provided props to override the default props\n   *\n   * @default - Default props are used\n   */\n  readonly cloudFrontDistributionProps?: cloudfront.DistributionProps | any,\n  /**\n   * Optional user provided props to turn on/off the automatic injection of best practice HTTP\n   * security headers in all responses from cloudfront.\n   * Turning this on will inject default headers and is mutually exclusive with passing custom security headers\n   * via the responseHeadersPolicyProps parameter.\n   *\n   * @default - true\n   */\n  readonly insertHttpSecurityHeaders?: boolean,\n  /**\n   * Optional user provided configuration that cloudfront applies to all http responses.\n   * Can be used to pass a custom ResponseSecurityHeadersBehavior, ResponseCustomHeadersBehavior or\n   * ResponseHeadersCorsBehavior to the cloudfront distribution.\n   *\n   * Passing a custom ResponseSecurityHeadersBehavior is mutually exclusive with turning on the default security headers\n   * via `insertHttpSecurityHeaders` prop. Will throw an error if both `insertHttpSecurityHeaders` is set to `true`\n   * and ResponseSecurityHeadersBehavior is passed.\n   *\n   * @default - undefined\n   */\n  readonly responseHeadersPolicyProps?: cloudfront.ResponseHeadersPolicyProps\n  /**\n   * Optional user provided props to override the default props for the CloudWatchLogs LogGroup.\n   *\n   * @default - Default props are used\n   */\n  readonly logGroupProps?: logs.LogGroupProps\n  /**\n   * Optional user provided props to override the default props for the CloudFront Logging Bucket.\n   *\n   * @default - Default props are used\n   */\n   readonly cloudFrontLoggingBucketProps?: s3.BucketProps\n}\n\nexport class CloudFrontToApiGatewayToLambda extends Construct {\n  public readonly cloudFrontWebDistribution: cloudfront.Distribution;\n  public readonly cloudFrontFunction?: cloudfront.Function;\n  public readonly cloudFrontLoggingBucket?: s3.Bucket;\n  public readonly apiGateway: api.RestApi;\n  public readonly apiGatewayCloudWatchRole?: iam.Role;\n  public readonly apiGatewayLogGroup: logs.LogGroup;\n  public readonly lambdaFunction: lambda.Function;\n\n  /**\n   * @summary Constructs a new instance of the CloudFrontToApiGatewayToLambda class.\n   * @param {Construct} scope - represents the scope for all the resources.\n   * @param {string} id - this is a a scope-unique id.\n   * @param {CloudFrontToApiGatewayToLambdaProps} props - user provided props for the construct\n   * @since 0.8.0\n   * @access public\n   */\n  constructor(scope: Construct, id: string, props: CloudFrontToApiGatewayToLambdaProps) {\n    super(scope, id);\n    defaults.CheckLambdaProps(props);\n    defaults.CheckApiProps(props);\n\n    // CheckCloudFrontProps() is called by internal aws-cloudfront-apigateway construct\n    if (!props.apiGatewayProps?.defaultMethodOptions?.authorizationType) {\n      defaults.printWarning('As of v2.48.0, apiGatewayProps.defaultMethodOptions.authorizationType is\\\n      required. To update your instantiation call, add the following to your CloudFrontToApiGatewayToLambdaProps argument\\\n      \\n\\napiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\\n\\nSee Issue1043 for an explanation.');\n      throw new Error('As of v2.48.0, an explicit authorization type is required for CloudFront/API Gateway patterns');\n    } else if (props.apiGatewayProps.defaultMethodOptions.authorizationType === \"AWS_IAM\") {\n      throw new Error('Amazon API Gateway Rest APIs integrated with Amazon CloudFront do not support AWS_IAM authorization');\n    }\n\n    // All our tests are based upon this behavior being on, so we're setting\n    // context here rather than assuming the client will set it\n    this.node.setContext(\"@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy\", true);\n\n    this.lambdaFunction = defaults.buildLambdaFunction(this, {\n      existingLambdaObj: props.existingLambdaObj,\n      lambdaFunctionProps: props.lambdaFunctionProps\n    });\n\n    // We can't default to IAM authentication with a CloudFront distribution, so\n    // we'll instruct core to not use any default auth to avoid override warnings\n    const regionalLambdaRestApiResponse = defaults.RegionalLambdaRestApi(this,\n      this.lambdaFunction,\n      props.apiGatewayProps,\n      props.logGroupProps,\n      props.createUsagePlan,\n      false);\n    this.apiGateway = regionalLambdaRestApiResponse.api;\n    this.apiGatewayCloudWatchRole = regionalLambdaRestApiResponse.role;\n    this.apiGatewayLogGroup = regionalLambdaRestApiResponse.group;\n\n    const apiCloudfront: CloudFrontToApiGateway = new CloudFrontToApiGateway(this, 'CloudFrontToApiGateway', {\n      existingApiGatewayObj: this.apiGateway,\n      cloudFrontDistributionProps: props.cloudFrontDistributionProps,\n      insertHttpSecurityHeaders: props.insertHttpSecurityHeaders,\n      cloudFrontLoggingBucketProps: props.cloudFrontLoggingBucketProps,\n      responseHeadersPolicyProps: props.responseHeadersPolicyProps\n    });\n\n    this.cloudFrontWebDistribution = apiCloudfront.cloudFrontWebDistribution;\n    this.cloudFrontFunction = apiCloudfront.cloudFrontFunction;\n    this.cloudFrontLoggingBucket = apiCloudfront.cloudFrontLoggingBucket;\n  }\n}\n"]}
62
+ CloudFrontToApiGatewayToLambda[_a] = { fqn: "@aws-solutions-constructs/aws-cloudfront-apigateway-lambda.CloudFrontToApiGatewayToLambda", version: "2.100.0" };
63
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAmBA,2DAA2D;AAC3D,wFAAwF;AACxF,2CAAuC;AACvC,mGAA6F;AA4E7F,MAAa,8BAA+B,SAAQ,sBAAS;IAS3D;;;;;;;OAOG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0C;QAClF,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACjC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC9B,QAAQ,CAAC,0BAA0B,CAAC,IAAI,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC;QACjE,QAAQ,CAAC,yBAAyB,CAAC,IAAI,EAAE,KAAK,CAAC,2BAA2B,CAAC,CAAC;QAE5E,mFAAmF;QACnF,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,CAAC;YACpE,QAAQ,CAAC,YAAY,CAAC;;4IAEgH,CAAC,CAAC;YACxI,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;QACnH,CAAC;aAAM,IAAI,KAAK,CAAC,eAAe,CAAC,oBAAoB,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;YACtF,MAAM,IAAI,KAAK,CAAC,qGAAqG,CAAC,CAAC;QACzH,CAAC;QAED,wEAAwE;QACxE,2DAA2D;QAC3D,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,iDAAiD,EAAE,IAAI,CAAC,CAAC;QAE9E,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,mBAAmB,CAAC,IAAI,EAAE;YACvD,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;YAC1C,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;SAC/C,CAAC,CAAC;QAEH,4EAA4E;QAC5E,6EAA6E;QAC7E,MAAM,6BAA6B,GAAG,QAAQ,CAAC,qBAAqB,CAAC,IAAI,EACvE,IAAI,CAAC,cAAc,EACnB,KAAK,CAAC,eAAe,EACrB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,eAAe,EACrB,KAAK,CAAC,CAAC;QACT,IAAI,CAAC,UAAU,GAAG,6BAA6B,CAAC,GAAG,CAAC;QACpD,IAAI,CAAC,wBAAwB,GAAG,6BAA6B,CAAC,IAAI,CAAC;QACnE,IAAI,CAAC,kBAAkB,GAAG,6BAA6B,CAAC,KAAK,CAAC;QAE9D,MAAM,aAAa,GAA2B,IAAI,kDAAsB,CAAC,IAAI,EAAE,wBAAwB,EAAE;YACvG,qBAAqB,EAAE,IAAI,CAAC,UAAU;YACtC,2BAA2B,EAAE,KAAK,CAAC,2BAA2B;YAC9D,yBAAyB,EAAE,KAAK,CAAC,yBAAyB;YAC1D,4BAA4B,EAAE,KAAK,CAAC,4BAA4B;YAChE,0BAA0B,EAAE,KAAK,CAAC,0BAA0B;SAC7D,CAAC,CAAC;QAEH,IAAI,CAAC,yBAAyB,GAAG,aAAa,CAAC,yBAAyB,CAAC;QACzE,IAAI,CAAC,kBAAkB,GAAG,aAAa,CAAC,kBAAkB,CAAC;QAC3D,IAAI,CAAC,uBAAuB,GAAG,aAAa,CAAC,uBAAuB,CAAC;IACvE,CAAC;;AAlEH,wEAmEC","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\nimport * as api from 'aws-cdk-lib/aws-apigateway';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as logs from 'aws-cdk-lib/aws-logs';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport * as defaults from '@aws-solutions-constructs/core';\n// Note: To ensure CDKv2 compatibility, keep the import statement for Construct separate\nimport { Construct } from 'constructs';\nimport { CloudFrontToApiGateway } from '@aws-solutions-constructs/aws-cloudfront-apigateway';\n\n/**\n * @summary The properties for the CloudFrontToApiGatewayToLambda Construct\n */\nexport interface CloudFrontToApiGatewayToLambdaProps {\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   * Optional - user provided props to override the default props for the Lambda function. Providing both this and `existingLambdaObj`\n   * causes an error.\n   *\n   * @default - Default props are used\n   */\n  readonly lambdaFunctionProps?: lambda.FunctionProps\n  /**\n   * User provided props to override the default props for the API Gateway. As of release\n   * 2.48.0, clients must include this property with defaultMethodOptions: { authorizationType: string } specified.\n   * See Issue1043 in the github repo https://github.com/awslabs/aws-solutions-constructs/issues/1043\n   *\n   * @default - defaultMethodOptions/authorizationType is required, for other, unspecified values the\n   * default props are used\n   */\n  readonly apiGatewayProps: api.LambdaRestApiProps | any\n  /**\n   * Whether to create a Usage Plan attached to the API. Must be true if\n   * apiGatewayProps.defaultMethodOptions.apiKeyRequired is true\n   *\n   * @default - true (to match legacy behavior)\n   */\n  readonly createUsagePlan?: boolean\n  /**\n   * Optional user provided props to override the default props\n   *\n   * @default - Default props are used\n   */\n  readonly cloudFrontDistributionProps?: cloudfront.DistributionProps | any,\n  /**\n   * Optional user provided props to turn on/off the automatic injection of best practice HTTP\n   * security headers in all responses from cloudfront.\n   * Turning this on will inject default headers and is mutually exclusive with passing custom security headers\n   * via the responseHeadersPolicyProps parameter.\n   *\n   * @default - true\n   */\n  readonly insertHttpSecurityHeaders?: boolean,\n  /**\n   * Optional user provided configuration that cloudfront applies to all http responses.\n   * Can be used to pass a custom ResponseSecurityHeadersBehavior, ResponseCustomHeadersBehavior or\n   * ResponseHeadersCorsBehavior to the cloudfront distribution.\n   *\n   * Passing a custom ResponseSecurityHeadersBehavior is mutually exclusive with turning on the default security headers\n   * via `insertHttpSecurityHeaders` prop. Will throw an error if both `insertHttpSecurityHeaders` is set to `true`\n   * and ResponseSecurityHeadersBehavior is passed.\n   *\n   * @default - undefined\n   */\n  readonly responseHeadersPolicyProps?: cloudfront.ResponseHeadersPolicyProps\n  /**\n   * Optional user provided props to override the default props for the CloudWatchLogs LogGroup.\n   *\n   * @default - Default props are used\n   */\n  readonly logGroupProps?: logs.LogGroupProps\n  /**\n   * Optional user provided props to override the default props for the CloudFront Logging Bucket.\n   *\n   * @default - Default props are used\n   */\n   readonly cloudFrontLoggingBucketProps?: s3.BucketProps\n}\n\nexport class CloudFrontToApiGatewayToLambda extends Construct {\n  public readonly cloudFrontWebDistribution: cloudfront.Distribution;\n  public readonly cloudFrontFunction?: cloudfront.Function;\n  public readonly cloudFrontLoggingBucket?: s3.Bucket;\n  public readonly apiGateway: api.RestApi;\n  public readonly apiGatewayCloudWatchRole?: iam.Role;\n  public readonly apiGatewayLogGroup: logs.LogGroup;\n  public readonly lambdaFunction: lambda.Function;\n\n  /**\n   * @summary Constructs a new instance of the CloudFrontToApiGatewayToLambda class.\n   * @param {Construct} scope - represents the scope for all the resources.\n   * @param {string} id - this is a a scope-unique id.\n   * @param {CloudFrontToApiGatewayToLambdaProps} props - user provided props for the construct\n   * @since 0.8.0\n   * @access public\n   */\n  constructor(scope: Construct, id: string, props: CloudFrontToApiGatewayToLambdaProps) {\n    super(scope, id);\n    defaults.CheckLambdaProps(props);\n    defaults.CheckApiProps(props);\n    defaults.ValidateLambdaRestApiProps(this, props.apiGatewayProps);\n    defaults.ValidateDistributionProps(this, props.cloudFrontDistributionProps);\n\n    // CheckCloudFrontProps() is called by internal aws-cloudfront-apigateway construct\n    if (!props.apiGatewayProps?.defaultMethodOptions?.authorizationType) {\n      defaults.printWarning('As of v2.48.0, apiGatewayProps.defaultMethodOptions.authorizationType is\\\n      required. To update your instantiation call, add the following to your CloudFrontToApiGatewayToLambdaProps argument\\\n      \\n\\napiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\\n\\nSee Issue1043 for an explanation.');\n      throw new Error('As of v2.48.0, an explicit authorization type is required for CloudFront/API Gateway patterns');\n    } else if (props.apiGatewayProps.defaultMethodOptions.authorizationType === \"AWS_IAM\") {\n      throw new Error('Amazon API Gateway Rest APIs integrated with Amazon CloudFront do not support AWS_IAM authorization');\n    }\n\n    // All our tests are based upon this behavior being on, so we're setting\n    // context here rather than assuming the client will set it\n    this.node.setContext(\"@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy\", true);\n\n    this.lambdaFunction = defaults.buildLambdaFunction(this, {\n      existingLambdaObj: props.existingLambdaObj,\n      lambdaFunctionProps: props.lambdaFunctionProps\n    });\n\n    // We can't default to IAM authentication with a CloudFront distribution, so\n    // we'll instruct core to not use any default auth to avoid override warnings\n    const regionalLambdaRestApiResponse = defaults.RegionalLambdaRestApi(this,\n      this.lambdaFunction,\n      props.apiGatewayProps,\n      props.logGroupProps,\n      props.createUsagePlan,\n      false);\n    this.apiGateway = regionalLambdaRestApiResponse.api;\n    this.apiGatewayCloudWatchRole = regionalLambdaRestApiResponse.role;\n    this.apiGatewayLogGroup = regionalLambdaRestApiResponse.group;\n\n    const apiCloudfront: CloudFrontToApiGateway = new CloudFrontToApiGateway(this, 'CloudFrontToApiGateway', {\n      existingApiGatewayObj: this.apiGateway,\n      cloudFrontDistributionProps: props.cloudFrontDistributionProps,\n      insertHttpSecurityHeaders: props.insertHttpSecurityHeaders,\n      cloudFrontLoggingBucketProps: props.cloudFrontLoggingBucketProps,\n      responseHeadersPolicyProps: props.responseHeadersPolicyProps\n    });\n\n    this.cloudFrontWebDistribution = apiCloudfront.cloudFrontWebDistribution;\n    this.cloudFrontFunction = apiCloudfront.cloudFrontFunction;\n    this.cloudFrontLoggingBucket = apiCloudfront.cloudFrontLoggingBucket;\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aws-solutions-constructs/aws-cloudfront-apigateway-lambda",
3
- "version": "2.99.0",
3
+ "version": "2.100.0",
4
4
  "description": "CDK Constructs for AWS Cloudfront to AWS API Gateway to AWS Lambda integration.",
5
5
  "main": "lib/index.js",
6
6
  "types": "lib/index.d.ts",
@@ -45,7 +45,6 @@
45
45
  "dotnet": {
46
46
  "namespace": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGatewayLambda",
47
47
  "packageId": "Amazon.SolutionsConstructs.AWS.CloudfrontApiGatewayLambda",
48
- "signAssembly": true,
49
48
  "iconUrl": "https://raw.githubusercontent.com/aws/aws-cdk/master/logo/default-256-dark.png"
50
49
  },
51
50
  "python": {
@@ -55,16 +54,16 @@
55
54
  }
56
55
  },
57
56
  "dependencies": {
58
- "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.99.0",
59
- "@aws-solutions-constructs/core": "2.99.0",
57
+ "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.100.0",
58
+ "@aws-solutions-constructs/core": "2.100.0",
60
59
  "constructs": "^10.0.0"
61
60
  },
62
61
  "devDependencies": {
63
- "@aws-cdk/integ-tests-alpha": "2.238.0-alpha.0",
62
+ "@aws-cdk/integ-tests-alpha": "2.239.0-alpha.0",
64
63
  "@types/jest": "^27.4.0",
65
64
  "@types/node": "^10.3.0",
66
65
  "constructs": "^10.0.0",
67
- "aws-cdk-lib": "2.238.0"
66
+ "aws-cdk-lib": "2.239.0"
68
67
  },
69
68
  "jest": {
70
69
  "moduleFileExtensions": [
@@ -81,10 +80,10 @@
81
80
  ]
82
81
  },
83
82
  "peerDependencies": {
84
- "@aws-solutions-constructs/core": "2.99.0",
85
- "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.99.0",
83
+ "@aws-solutions-constructs/core": "2.100.0",
84
+ "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.100.0",
86
85
  "constructs": "^10.0.0",
87
- "aws-cdk-lib": "^2.238.0"
86
+ "aws-cdk-lib": "^2.239.0"
88
87
  },
89
88
  "keywords": [
90
89
  "aws",
@@ -0,0 +1,399 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
4
+ *
5
+ * Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
6
+ * with the License. A copy of the License is located at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
11
+ * OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
12
+ * and limitations under the License.
13
+ */
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ const lib_1 = require("../lib");
16
+ const cdk = require("aws-cdk-lib");
17
+ const lambda = require("aws-cdk-lib/aws-lambda");
18
+ const api = require("aws-cdk-lib/aws-apigateway");
19
+ const s3 = require("aws-cdk-lib/aws-s3");
20
+ const assertions_1 = require("aws-cdk-lib/assertions");
21
+ const defaults = require("@aws-solutions-constructs/core");
22
+ function deployNewFunc(stack) {
23
+ const lambdaFunctionProps = {
24
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
25
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
26
+ handler: 'index.handler'
27
+ };
28
+ return new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {
29
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
30
+ lambdaFunctionProps
31
+ });
32
+ }
33
+ function useExistingFunc(stack) {
34
+ const lambdaFunctionProps = {
35
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
36
+ handler: 'index.handler',
37
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`)
38
+ };
39
+ return new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {
40
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
41
+ existingLambdaObj: new lambda.Function(stack, 'MyExistingFunction', lambdaFunctionProps)
42
+ });
43
+ }
44
+ test('check properties', () => {
45
+ const stack = new cdk.Stack();
46
+ const construct = deployNewFunc(stack);
47
+ expect(construct.cloudFrontWebDistribution).toBeDefined();
48
+ expect(construct.apiGateway).toBeDefined();
49
+ expect(construct.lambdaFunction).toBeDefined();
50
+ expect(construct.cloudFrontFunction).toBeDefined();
51
+ expect(construct.cloudFrontLoggingBucket).toBeDefined();
52
+ expect(construct.apiGatewayCloudWatchRole).toBeDefined();
53
+ expect(construct.apiGatewayLogGroup).toBeDefined();
54
+ });
55
+ test('check lambda function properties for deploy: true', () => {
56
+ const stack = new cdk.Stack();
57
+ deployNewFunc(stack);
58
+ const template = assertions_1.Template.fromStack(stack);
59
+ template.hasResourceProperties('AWS::Lambda::Function', {
60
+ Handler: "index.handler",
61
+ Role: {
62
+ "Fn::GetAtt": [
63
+ "testcloudfrontapigatewaylambdaLambdaFunctionServiceRoleCB74590F",
64
+ "Arn"
65
+ ]
66
+ },
67
+ Runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_STRING,
68
+ Environment: {
69
+ Variables: {
70
+ AWS_NODEJS_CONNECTION_REUSE_ENABLED: "1"
71
+ }
72
+ }
73
+ });
74
+ template.resourceCountIs('AWS::ApiGateway::UsagePlan', 1);
75
+ });
76
+ test('check lambda function role for deploy: false', () => {
77
+ const stack = new cdk.Stack();
78
+ useExistingFunc(stack);
79
+ const template = assertions_1.Template.fromStack(stack);
80
+ template.hasResourceProperties('AWS::IAM::Role', {
81
+ AssumeRolePolicyDocument: {
82
+ Statement: [
83
+ {
84
+ Action: "sts:AssumeRole",
85
+ Effect: "Allow",
86
+ Principal: {
87
+ Service: "lambda.amazonaws.com"
88
+ }
89
+ }
90
+ ],
91
+ Version: "2012-10-17"
92
+ },
93
+ ManagedPolicyArns: [
94
+ {
95
+ "Fn::Join": [
96
+ "",
97
+ [
98
+ "arn:",
99
+ {
100
+ Ref: "AWS::Partition"
101
+ },
102
+ ":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
103
+ ]
104
+ ]
105
+ }
106
+ ]
107
+ });
108
+ });
109
+ test('check exception for Missing existingObj from props', () => {
110
+ const stack = new cdk.Stack();
111
+ const props = {
112
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
113
+ };
114
+ try {
115
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);
116
+ }
117
+ catch (e) {
118
+ expect(e).toBeInstanceOf(Error);
119
+ }
120
+ });
121
+ test('check no prop', () => {
122
+ const stack = new cdk.Stack();
123
+ const props = {
124
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
125
+ };
126
+ try {
127
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);
128
+ }
129
+ catch (e) {
130
+ expect(e).toBeInstanceOf(Error);
131
+ }
132
+ });
133
+ test('override api gateway properties with existingLambdaObj', () => {
134
+ const stack = new cdk.Stack();
135
+ const lambdaFunctionProps = {
136
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
137
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
138
+ handler: 'index.handler'
139
+ };
140
+ const fn = new lambda.Function(stack, 'MyExistingFunction', lambdaFunctionProps);
141
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {
142
+ existingLambdaObj: fn,
143
+ apiGatewayProps: {
144
+ defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },
145
+ description: "Override description"
146
+ }
147
+ });
148
+ const template = assertions_1.Template.fromStack(stack);
149
+ template.hasResourceProperties('AWS::ApiGateway::RestApi', {
150
+ Description: "Override description",
151
+ EndpointConfiguration: {
152
+ Types: [
153
+ "REGIONAL"
154
+ ]
155
+ },
156
+ Name: "LambdaRestApi"
157
+ });
158
+ });
159
+ test('override api gateway properties without existingLambdaObj', () => {
160
+ const stack = new cdk.Stack();
161
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {
162
+ lambdaFunctionProps: {
163
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
164
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
165
+ handler: 'index.handler'
166
+ },
167
+ apiGatewayProps: {
168
+ defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },
169
+ endpointConfiguration: {
170
+ types: [api.EndpointType.PRIVATE],
171
+ },
172
+ description: "Override description"
173
+ }
174
+ });
175
+ const template = assertions_1.Template.fromStack(stack);
176
+ template.hasResourceProperties('AWS::ApiGateway::RestApi', {
177
+ Description: "Override description",
178
+ EndpointConfiguration: {
179
+ Types: [
180
+ "PRIVATE"
181
+ ]
182
+ },
183
+ Name: "LambdaRestApi"
184
+ });
185
+ });
186
+ test('Cloudfront logging bucket with destroy removal policy and auto delete objects', () => {
187
+ const stack = new cdk.Stack();
188
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {
189
+ lambdaFunctionProps: {
190
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
191
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
192
+ handler: 'index.handler'
193
+ },
194
+ apiGatewayProps: {
195
+ defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },
196
+ endpointConfiguration: {
197
+ types: [api.EndpointType.PRIVATE],
198
+ }
199
+ },
200
+ cloudFrontLoggingBucketProps: {
201
+ removalPolicy: cdk.RemovalPolicy.DESTROY,
202
+ autoDeleteObjects: true
203
+ }
204
+ });
205
+ const template = assertions_1.Template.fromStack(stack);
206
+ template.hasResourceProperties("AWS::S3::Bucket", {
207
+ OwnershipControls: { Rules: [{ ObjectOwnership: "ObjectWriter" }] },
208
+ });
209
+ template.hasResourceProperties("Custom::S3AutoDeleteObjects", {
210
+ ServiceToken: {
211
+ "Fn::GetAtt": [
212
+ "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F",
213
+ "Arn"
214
+ ]
215
+ },
216
+ BucketName: {
217
+ Ref: "testcloudfrontapigatewaylambdaCloudFrontToApiGatewayCloudfrontLoggingBucket7F467421"
218
+ }
219
+ });
220
+ });
221
+ test('Cloudfront logging bucket error when providing existing log bucket and logBucketProps', () => {
222
+ const stack = new cdk.Stack();
223
+ const logBucket = new s3.Bucket(stack, 'cloudfront-log-bucket', {});
224
+ const app = () => {
225
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'cloudfront-s3', {
226
+ lambdaFunctionProps: {
227
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
228
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
229
+ handler: 'index.handler'
230
+ },
231
+ apiGatewayProps: {
232
+ endpointConfiguration: {
233
+ types: [api.EndpointType.PRIVATE],
234
+ }
235
+ },
236
+ cloudFrontLoggingBucketProps: {
237
+ removalPolicy: cdk.RemovalPolicy.DESTROY,
238
+ autoDeleteObjects: true
239
+ },
240
+ cloudFrontDistributionProps: {
241
+ logBucket
242
+ },
243
+ });
244
+ };
245
+ expect(app).toThrow();
246
+ });
247
+ test('Confirm CheckLambdaProps is being called', () => {
248
+ const stack = new cdk.Stack();
249
+ const existingLambdaObj = new lambda.Function(stack, 'ExistingLambda', {
250
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
251
+ handler: 'index.handler',
252
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
253
+ });
254
+ const props = {
255
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
256
+ existingLambdaObj,
257
+ lambdaFunctionProps: {
258
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
259
+ handler: 'index.handler',
260
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
261
+ }
262
+ };
263
+ const app = () => {
264
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'cf-test-apigateway-lambda', props);
265
+ };
266
+ expect(app).toThrow('Error - Either provide lambdaFunctionProps or existingLambdaObj, but not both.\n');
267
+ });
268
+ test("Confirm CheckCloudFrontProps is being called", () => {
269
+ const stack = new cdk.Stack();
270
+ expect(() => {
271
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, "test-cloudfront-apigateway-lambda", {
272
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE } },
273
+ lambdaFunctionProps: {
274
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
275
+ handler: 'index.handler',
276
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
277
+ },
278
+ insertHttpSecurityHeaders: true,
279
+ responseHeadersPolicyProps: {
280
+ securityHeadersBehavior: {
281
+ strictTransportSecurity: {
282
+ accessControlMaxAge: cdk.Duration.seconds(63072),
283
+ includeSubdomains: true,
284
+ override: false,
285
+ preload: true
286
+ }
287
+ }
288
+ }
289
+ });
290
+ }).toThrow('responseHeadersPolicyProps.securityHeadersBehavior can only be passed if httpSecurityHeaders is set to `false`.');
291
+ });
292
+ test('confirm error thrown for AWS_IAM authorization', () => {
293
+ const stack = new cdk.Stack();
294
+ const lambdaFunctionProps = {
295
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
296
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
297
+ handler: 'index.handler'
298
+ };
299
+ const props = {
300
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_IAM' } },
301
+ lambdaFunctionProps
302
+ };
303
+ const app = () => {
304
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-one', props);
305
+ };
306
+ expect(app).toThrow(/Amazon API Gateway Rest APIs integrated with Amazon CloudFront do not support AWS_IAM authorization/);
307
+ });
308
+ test('confirm error thrown for unspecified authorization', () => {
309
+ const stack = new cdk.Stack();
310
+ const lambdaFunctionProps = {
311
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
312
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
313
+ handler: 'index.handler'
314
+ };
315
+ const props = {
316
+ apiGatewayProps: {},
317
+ lambdaFunctionProps
318
+ };
319
+ const app = () => {
320
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-one', props);
321
+ };
322
+ expect(app).toThrow(/As of v2.48.0, an explicit authorization type is required for CloudFront\/API Gateway patterns/);
323
+ });
324
+ test('Confirm call to CheckApiProps', () => {
325
+ // Initial Setup
326
+ const stack = new cdk.Stack();
327
+ const lambdaFunction = new lambda.Function(stack, 'a-function', {
328
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
329
+ handler: 'index.handler',
330
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
331
+ });
332
+ const props = {
333
+ existingLambdaObj: lambdaFunction,
334
+ apiGatewayProps: {
335
+ defaultMethodOptions: {
336
+ authorizationType: 'AWS_NONE',
337
+ apiKeyRequired: true
338
+ },
339
+ },
340
+ createUsagePlan: false,
341
+ };
342
+ const app = () => {
343
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);
344
+ };
345
+ // Assertion
346
+ expect(app).toThrow('Error - if API key is required, then the Usage plan must be created\n');
347
+ });
348
+ test('Confirm suppression of Usage Plan', () => {
349
+ // Initial Setup
350
+ const stack = new cdk.Stack();
351
+ const props = {
352
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_NONE' } },
353
+ lambdaFunctionProps: {
354
+ code: new lambda.InlineCode('exports.handler = async (event) => { console.log(event); return {\'statusCode\': 200, \'body\': \'\'}; }'),
355
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
356
+ handler: 'index.handler',
357
+ },
358
+ createUsagePlan: false
359
+ };
360
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);
361
+ const template = assertions_1.Template.fromStack(stack);
362
+ template.resourceCountIs('AWS::ApiGateway::UsagePlan', 0);
363
+ });
364
+ test('Test that ValidateLambdaRestApiProps() is being called', () => {
365
+ const stack = new cdk.Stack();
366
+ const props = {
367
+ lambdaFunctionProps: {
368
+ code: lambda.Code.fromAsset(`${__dirname}/lambda`),
369
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
370
+ handler: 'index.handler'
371
+ },
372
+ apiGatewayProps: {
373
+ invalidProperty: true
374
+ }
375
+ };
376
+ const app = () => {
377
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-construct', props);
378
+ };
379
+ expect(app).toThrow(/ERROR - invalidProperty is not a valid property of LambdaRestApiProps/);
380
+ });
381
+ test('Test that ValidateDistributionProps() is being called', () => {
382
+ const stack = new cdk.Stack();
383
+ const props = {
384
+ apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_NONE' } },
385
+ lambdaFunctionProps: {
386
+ code: new lambda.InlineCode('exports.handler = async (event) => { console.log(event); return {\'statusCode\': 200, \'body\': \'\'}; }'),
387
+ runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
388
+ handler: 'index.handler',
389
+ },
390
+ cloudFrontDistributionProps: {
391
+ invalidProperty: true
392
+ }
393
+ };
394
+ const app = () => {
395
+ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'test-construct', props);
396
+ };
397
+ expect(app).toThrow(/ERROR - invalidProperty is not a valid property of DistributionProps/);
398
+ });
399
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudfront-apigateway-lambda.test.js","sourceRoot":"","sources":["cloudfront-apigateway-lambda.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\nimport { CloudFrontToApiGatewayToLambda, CloudFrontToApiGatewayToLambdaProps } from \"../lib\";\nimport * as cdk from \"aws-cdk-lib\";\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as api from 'aws-cdk-lib/aws-apigateway';\nimport * as s3 from \"aws-cdk-lib/aws-s3\";\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as defaults from '@aws-solutions-constructs/core';\n\nfunction deployNewFunc(stack: cdk.Stack) {\n  const lambdaFunctionProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler'\n  };\n\n  return new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n    lambdaFunctionProps\n  });\n}\n\nfunction useExistingFunc(stack: cdk.Stack) {\n  const lambdaFunctionProps: lambda.FunctionProps = {\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`)\n  };\n\n  return new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n    existingLambdaObj: new lambda.Function(stack, 'MyExistingFunction', lambdaFunctionProps)\n  });\n}\n\ntest('check properties', () => {\n  const stack = new cdk.Stack();\n\n  const construct: CloudFrontToApiGatewayToLambda = deployNewFunc(stack);\n\n  expect(construct.cloudFrontWebDistribution).toBeDefined();\n  expect(construct.apiGateway).toBeDefined();\n  expect(construct.lambdaFunction).toBeDefined();\n  expect(construct.cloudFrontFunction).toBeDefined();\n  expect(construct.cloudFrontLoggingBucket).toBeDefined();\n  expect(construct.apiGatewayCloudWatchRole).toBeDefined();\n  expect(construct.apiGatewayLogGroup).toBeDefined();\n});\n\ntest('check lambda function properties for deploy: true', () => {\n  const stack = new cdk.Stack();\n\n  deployNewFunc(stack);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::Lambda::Function', {\n    Handler: \"index.handler\",\n    Role: {\n      \"Fn::GetAtt\": [\n        \"testcloudfrontapigatewaylambdaLambdaFunctionServiceRoleCB74590F\",\n        \"Arn\"\n      ]\n    },\n    Runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_STRING,\n    Environment: {\n      Variables: {\n        AWS_NODEJS_CONNECTION_REUSE_ENABLED: \"1\"\n      }\n    }\n  });\n  template.resourceCountIs('AWS::ApiGateway::UsagePlan', 1);\n});\n\ntest('check lambda function role for deploy: false', () => {\n  const stack = new cdk.Stack();\n\n  useExistingFunc(stack);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::IAM::Role', {\n    AssumeRolePolicyDocument: {\n      Statement: [\n        {\n          Action: \"sts:AssumeRole\",\n          Effect: \"Allow\",\n          Principal: {\n            Service: \"lambda.amazonaws.com\"\n          }\n        }\n      ],\n      Version: \"2012-10-17\"\n    },\n    ManagedPolicyArns: [\n      {\n        \"Fn::Join\": [\n          \"\",\n          [\n            \"arn:\",\n            {\n              Ref: \"AWS::Partition\"\n            },\n            \":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole\"\n          ]\n        ]\n      }\n    ]\n  });\n});\n\ntest('check exception for Missing existingObj from props', () => {\n  const stack = new cdk.Stack();\n\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n  };\n\n  try {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);\n  } catch (e) {\n    expect(e).toBeInstanceOf(Error);\n  }\n});\n\ntest('check no prop', () => {\n  const stack = new cdk.Stack();\n\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n  };\n\n  try {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);\n  } catch (e) {\n    expect(e).toBeInstanceOf(Error);\n  }\n});\n\ntest('override api gateway properties with existingLambdaObj', () => {\n  const stack = new cdk.Stack();\n\n  const lambdaFunctionProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler'\n  };\n\n  const fn: lambda.Function = new lambda.Function(stack, 'MyExistingFunction', lambdaFunctionProps);\n\n  new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {\n    existingLambdaObj: fn,\n    apiGatewayProps: {\n      defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },\n      description: \"Override description\"\n    }\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::ApiGateway::RestApi',\n    {\n      Description: \"Override description\",\n      EndpointConfiguration: {\n        Types: [\n          \"REGIONAL\"\n        ]\n      },\n      Name: \"LambdaRestApi\"\n    });\n});\n\ntest('override api gateway properties without existingLambdaObj', () => {\n  const stack = new cdk.Stack();\n\n  new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {\n    lambdaFunctionProps: {\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n      handler: 'index.handler'\n    },\n    apiGatewayProps: {\n      defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },\n      endpointConfiguration: {\n        types: [api.EndpointType.PRIVATE],\n      },\n      description: \"Override description\"\n    }\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties('AWS::ApiGateway::RestApi',\n    {\n      Description: \"Override description\",\n      EndpointConfiguration: {\n        Types: [\n          \"PRIVATE\"\n        ]\n      },\n      Name: \"LambdaRestApi\"\n    });\n});\n\ntest('Cloudfront logging bucket with destroy removal policy and auto delete objects', () => {\n  const stack = new cdk.Stack();\n\n  new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', {\n    lambdaFunctionProps: {\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n      handler: 'index.handler'\n    },\n    apiGatewayProps: {\n      defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE },\n      endpointConfiguration: {\n        types: [api.EndpointType.PRIVATE],\n      }\n    },\n    cloudFrontLoggingBucketProps: {\n      removalPolicy: cdk.RemovalPolicy.DESTROY,\n      autoDeleteObjects: true\n    }\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::S3::Bucket\", {\n    OwnershipControls: { Rules: [ { ObjectOwnership: \"ObjectWriter\" } ] },\n  });\n\n  template.hasResourceProperties(\"Custom::S3AutoDeleteObjects\", {\n    ServiceToken: {\n      \"Fn::GetAtt\": [\n        \"CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F\",\n        \"Arn\"\n      ]\n    },\n    BucketName: {\n      Ref: \"testcloudfrontapigatewaylambdaCloudFrontToApiGatewayCloudfrontLoggingBucket7F467421\"\n    }\n  });\n});\n\ntest('Cloudfront logging bucket error when providing existing log bucket and logBucketProps', () => {\n  const stack = new cdk.Stack();\n  const logBucket = new s3.Bucket(stack, 'cloudfront-log-bucket', {});\n\n  const app = () => { new CloudFrontToApiGatewayToLambda(stack, 'cloudfront-s3', {\n    lambdaFunctionProps: {\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n      handler: 'index.handler'\n    },\n    apiGatewayProps: {\n      endpointConfiguration: {\n        types: [api.EndpointType.PRIVATE],\n      }\n    },\n    cloudFrontLoggingBucketProps: {\n      removalPolicy: cdk.RemovalPolicy.DESTROY,\n      autoDeleteObjects: true\n    },\n    cloudFrontDistributionProps: {\n      logBucket\n    },\n  });\n  };\n\n  expect(app).toThrow();\n});\n\ntest('Confirm CheckLambdaProps is being called', () => {\n  const stack = new cdk.Stack();\n  const existingLambdaObj = new lambda.Function(stack, 'ExistingLambda', {\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n    existingLambdaObj,\n    lambdaFunctionProps: {\n      runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n      handler: 'index.handler',\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    }\n  };\n\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'cf-test-apigateway-lambda', props);\n  };\n  expect(app).toThrow('Error - Either provide lambdaFunctionProps or existingLambdaObj, but not both.\\n');\n});\n\ntest(\"Confirm CheckCloudFrontProps is being called\", () => {\n  const stack = new cdk.Stack();\n\n  expect(() => {\n    new CloudFrontToApiGatewayToLambda(stack, \"test-cloudfront-apigateway-lambda\", {\n      apiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n      lambdaFunctionProps: {\n        runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n        handler: 'index.handler',\n        code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      },\n      insertHttpSecurityHeaders: true,\n      responseHeadersPolicyProps: {\n        securityHeadersBehavior: {\n          strictTransportSecurity: {\n            accessControlMaxAge: cdk.Duration.seconds(63072),\n            includeSubdomains: true,\n            override: false,\n            preload: true\n          }\n        }\n      }\n    });\n  }).toThrow('responseHeadersPolicyProps.securityHeadersBehavior can only be passed if httpSecurityHeaders is set to `false`.');\n});\n\ntest('confirm error thrown for AWS_IAM authorization', () => {\n  const stack = new cdk.Stack();\n  const lambdaFunctionProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler'\n  };\n\n  const props = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_IAM' }},\n    lambdaFunctionProps\n  };\n\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-one', props);\n  };\n  expect(app).toThrow(/Amazon API Gateway Rest APIs integrated with Amazon CloudFront do not support AWS_IAM authorization/);\n});\n\ntest('confirm error thrown for unspecified authorization', () => {\n  const stack = new cdk.Stack();\n  const lambdaFunctionProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler'\n  };\n\n  const props = {\n    apiGatewayProps: { },\n    lambdaFunctionProps\n  };\n\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-one', props);\n  };\n  expect(app).toThrow(/As of v2.48.0, an explicit authorization type is required for CloudFront\\/API Gateway patterns/);\n});\n\ntest('Confirm call to CheckApiProps', () => {\n  // Initial Setup\n  const stack = new cdk.Stack();\n  const lambdaFunction = new lambda.Function(stack, 'a-function', {\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    existingLambdaObj: lambdaFunction,\n    apiGatewayProps: {\n      defaultMethodOptions: {\n        authorizationType: 'AWS_NONE',\n        apiKeyRequired: true\n      },\n    },\n    createUsagePlan: false,\n  };\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);\n  };\n  // Assertion\n  expect(app).toThrow('Error - if API key is required, then the Usage plan must be created\\n');\n});\n\ntest('Confirm suppression of Usage Plan', () => {\n  // Initial Setup\n  const stack = new cdk.Stack();\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_NONE' }},\n    lambdaFunctionProps: {\n       code: new lambda.InlineCode('exports.handler = async (event) => { console.log(event); return {\\'statusCode\\': 200, \\'body\\': \\'\\'}; }'),\n       runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n       handler: 'index.handler',\n    },\n    createUsagePlan: false\n  };\n  new CloudFrontToApiGatewayToLambda(stack, 'test-cloudfront-apigateway-lambda', props);\n\n  const template = Template.fromStack(stack);\n  template.resourceCountIs('AWS::ApiGateway::UsagePlan', 0);\n});\n\ntest('Test that ValidateLambdaRestApiProps() is being called', () => {\n  const stack = new cdk.Stack();\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    lambdaFunctionProps: {\n      code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n      runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n      handler: 'index.handler'\n    },\n    apiGatewayProps: {\n      invalidProperty: true\n    }\n  };\n\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-construct', props);\n  };\n\n  expect(app).toThrow(/ERROR - invalidProperty is not a valid property of LambdaRestApiProps/);\n});\n\ntest('Test that ValidateDistributionProps() is being called', () => {\n  const stack = new cdk.Stack();\n  const props: CloudFrontToApiGatewayToLambdaProps = {\n    apiGatewayProps: { defaultMethodOptions: { authorizationType: 'AWS_NONE' }},\n    lambdaFunctionProps: {\n       code: new lambda.InlineCode('exports.handler = async (event) => { console.log(event); return {\\'statusCode\\': 200, \\'body\\': \\'\\'}; }'),\n       runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n       handler: 'index.handler',\n    },\n    cloudFrontDistributionProps: {\n      invalidProperty: true\n    }\n  };\n\n  const app = () => {\n    new CloudFrontToApiGatewayToLambda(stack, 'test-construct', props);\n  };\n\n  expect(app).toThrow(/ERROR - invalidProperty is not a valid property of DistributionProps/);\n});\n"]}