@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
497 lines • 53.6 kB
JavaScript
"use strict";
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
* with the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
const aws_cdk_lib_1 = require("aws-cdk-lib");
const cloudfront = require("aws-cdk-lib/aws-cloudfront");
const apigw = require("aws-cdk-lib/aws-apigateway");
const lambda = require("aws-cdk-lib/aws-lambda");
const defaults = require("../index");
const s3 = require("aws-cdk-lib/aws-s3");
const cloudfront_distribution_helper_1 = require("../lib/cloudfront-distribution-helper");
const origins = require("aws-cdk-lib/aws-cloudfront-origins");
const aws_cloudfront_1 = require("aws-cdk-lib/aws-cloudfront");
const assertions_1 = require("aws-cdk-lib/assertions");
test('test cloudfront for Api Gateway with user provided logging bucket', () => {
const stack = new aws_cdk_lib_1.Stack();
const logBucket = new s3.Bucket(stack, 'MyCloudfrontLoggingBucket', defaults.DefaultS3Props());
const inProps = {
code: lambda.Code.fromAsset(`${__dirname}/lambda-test`),
runtime: lambda.Runtime.PYTHON_3_9,
handler: 'index.handler'
};
const cfdProps = {
enableLogging: true,
logBucket
};
const func = defaults.deployLambdaFunction(stack, inProps);
const api = new apigw.LambdaRestApi(stack, 'RestApi1', {
handler: func
});
(0, cloudfront_distribution_helper_1.CloudFrontDistributionForApiGateway)(stack, api, cfdProps);
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties("AWS::CloudFront::Distribution", {
DistributionConfig: {
DefaultCacheBehavior: {
CachePolicyId: "658327ea-f89d-4fab-a63d-7e88639e58f6",
Compress: true,
FunctionAssociations: [
{
EventType: "viewer-response",
FunctionARN: {
"Fn::GetAtt": [
"SetHttpSecurityHeadersEE936115",
"FunctionARN"
]
}
}
],
TargetOriginId: "CloudFrontDistributionOrigin176EC3A12",
ViewerProtocolPolicy: "redirect-to-https"
},
Enabled: true,
HttpVersion: "http2",
IPV6Enabled: true,
Logging: {
Bucket: {
"Fn::GetAtt": [
"MyCloudfrontLoggingBucket9AA652E8",
"RegionalDomainName"
]
}
},
Origins: [
{
CustomOriginConfig: {
OriginProtocolPolicy: "https-only"
},
DomainName: {
"Fn::Select": [
0,
{
"Fn::Split": [
"/",
{
"Fn::Select": [
1,
{
"Fn::Split": [
"://",
{
"Fn::Join": [
"",
[
"https://",
{
Ref: "RestApi1480AC499"
},
".execute-api.",
{
Ref: "AWS::Region"
},
".",
{
Ref: "AWS::URLSuffix"
},
"/",
{
Ref: "RestApi1DeploymentStageprod4FFC9BB4"
},
"/"
]
]
}
]
}
]
}
]
}
]
},
Id: "CloudFrontDistributionOrigin176EC3A12",
OriginPath: {
"Fn::Join": [
"",
[
"/",
{
Ref: "RestApi1DeploymentStageprod4FFC9BB4"
}
]
]
}
}
]
}
});
});
test('test cloudfront for Api Gateway override properties', () => {
const stack = new aws_cdk_lib_1.Stack();
const inProps = {
code: lambda.Code.fromAsset(`${__dirname}/lambda-test`),
runtime: lambda.Runtime.PYTHON_3_9,
handler: 'index.handler'
};
const func = defaults.deployLambdaFunction(stack, inProps);
const api = new apigw.LambdaRestApi(stack, 'RestApi1', {
handler: func
});
const props = {
defaultBehavior: {
origin: new origins.HttpOrigin(api.url, {
protocolPolicy: cloudfront.OriginProtocolPolicy.HTTP_ONLY
}),
allowedMethods: cloudfront.AllowedMethods.ALLOW_ALL,
cachedMethods: cloudfront.CachedMethods.CACHE_GET_HEAD_OPTIONS
},
};
(0, cloudfront_distribution_helper_1.CloudFrontDistributionForApiGateway)(stack, api, props);
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties("AWS::CloudFront::Distribution", {
DistributionConfig: {
DefaultCacheBehavior: {
AllowedMethods: [
"GET",
"HEAD",
"OPTIONS",
"PUT",
"PATCH",
"POST",
"DELETE"
],
CachePolicyId: "658327ea-f89d-4fab-a63d-7e88639e58f6",
CachedMethods: [
"GET",
"HEAD",
"OPTIONS"
],
Compress: true,
FunctionAssociations: [
{
EventType: "viewer-response",
FunctionARN: {
"Fn::GetAtt": [
"SetHttpSecurityHeadersEE936115",
"FunctionARN"
]
}
}
],
TargetOriginId: "CloudFrontDistributionOrigin176EC3A12",
ViewerProtocolPolicy: "redirect-to-https"
},
Enabled: true,
HttpVersion: "http2",
IPV6Enabled: true,
Logging: {
Bucket: {
"Fn::GetAtt": [
"CloudfrontLoggingBucket3C3EFAA7",
"RegionalDomainName"
]
}
},
Origins: [
{
CustomOriginConfig: {
OriginProtocolPolicy: "http-only"
},
DomainName: {
"Fn::Join": [
"",
[
"https://",
{
Ref: "RestApi1480AC499"
},
".execute-api.",
{
Ref: "AWS::Region"
},
".",
{
Ref: "AWS::URLSuffix"
},
"/",
{
Ref: "RestApi1DeploymentStageprod4FFC9BB4"
},
"/"
]
]
},
Id: "CloudFrontDistributionOrigin176EC3A12"
}
]
}
});
});
test('test override cloudfront add custom cloudfront function', () => {
const stack = new aws_cdk_lib_1.Stack();
// custom cloudfront function
const cloudfrontFunction = new cloudfront.Function(stack, "MyFunction", {
code: cloudfront.FunctionCode.fromInline("exports.handler = (event, context, callback) => {}")
});
// APIG Lambda function
const lambdaFunctionProps = {
runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
handler: 'index.handler',
code: lambda.Code.fromAsset(`${__dirname}/lambda`)
};
const func = new lambda.Function(stack, 'LambdaFunction', lambdaFunctionProps);
const api = new apigw.LambdaRestApi(stack, 'RestApi', {
handler: func
});
(0, cloudfront_distribution_helper_1.CloudFrontDistributionForApiGateway)(stack, api, {
defaultBehavior: {
functionAssociations: [
{
eventType: cloudfront.FunctionEventType.VIEWER_RESPONSE,
function: cloudfrontFunction
}
],
}
});
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties("AWS::CloudFront::Distribution", {
DistributionConfig: {
DefaultCacheBehavior: {
CachePolicyId: "658327ea-f89d-4fab-a63d-7e88639e58f6",
Compress: true,
FunctionAssociations: [
{
EventType: "viewer-response",
FunctionARN: {
"Fn::GetAtt": [
"MyFunction3BAA72D1",
"FunctionARN"
]
}
}
],
TargetOriginId: "CloudFrontDistributionOrigin176EC3A12",
ViewerProtocolPolicy: "redirect-to-https"
},
Enabled: true,
HttpVersion: "http2",
IPV6Enabled: true,
Logging: {
Bucket: {
"Fn::GetAtt": [
"CloudfrontLoggingBucket3C3EFAA7",
"RegionalDomainName"
]
}
},
Origins: [
{
CustomOriginConfig: {
OriginProtocolPolicy: "https-only",
OriginSSLProtocols: [
"TLSv1.2"
]
},
DomainName: {
"Fn::Select": [
0,
{
"Fn::Split": [
"/",
{
"Fn::Select": [
1,
{
"Fn::Split": [
"://",
{
"Fn::Join": [
"",
[
"https://",
{
Ref: "RestApi0C43BF4B"
},
".execute-api.",
{
Ref: "AWS::Region"
},
".",
{
Ref: "AWS::URLSuffix"
},
"/",
{
Ref: "RestApiDeploymentStageprod3855DE66"
},
"/"
]
]
}
]
}
]
}
]
}
]
},
Id: "CloudFrontDistributionOrigin176EC3A12",
OriginPath: {
"Fn::Join": [
"",
[
"/",
{
Ref: "RestApiDeploymentStageprod3855DE66"
}
]
]
}
}
]
}
});
});
test('test override cloudfront replace custom lambda@edge', () => {
const stack = new aws_cdk_lib_1.Stack();
// custom lambda@edg function
const handler = new lambda.Function(stack, 'SomeHandler', {
functionName: 'SomeHandler',
runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
handler: 'index.handler',
code: lambda.Code.fromAsset(`${__dirname}/lambda`),
});
const handlerVersion = new lambda.Version(stack, 'SomeHandlerVersion', {
lambda: handler,
});
// APIG Lambda function
const lambdaFunctionProps = {
runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,
handler: 'index.handler',
code: lambda.Code.fromAsset(`${__dirname}/lambda`)
};
const func = new lambda.Function(stack, 'LambdaFunction', lambdaFunctionProps);
const api = new apigw.LambdaRestApi(stack, 'RestApi', {
handler: func
});
(0, cloudfront_distribution_helper_1.CloudFrontDistributionForApiGateway)(stack, api, {
defaultBehavior: {
edgeLambdas: [
{
eventType: aws_cloudfront_1.LambdaEdgeEventType.VIEWER_REQUEST,
includeBody: false,
functionVersion: handlerVersion,
}
]
}
}, false);
const template = assertions_1.Template.fromStack(stack);
template.hasResourceProperties("AWS::CloudFront::Distribution", {
DistributionConfig: {
DefaultCacheBehavior: {
CachePolicyId: "658327ea-f89d-4fab-a63d-7e88639e58f6",
Compress: true,
LambdaFunctionAssociations: [
{
EventType: "viewer-request",
IncludeBody: false,
LambdaFunctionARN: {
Ref: "SomeHandlerVersionDA986E41"
}
}
],
TargetOriginId: "CloudFrontDistributionOrigin176EC3A12",
ViewerProtocolPolicy: "redirect-to-https"
},
Enabled: true,
HttpVersion: "http2",
IPV6Enabled: true,
Logging: {
Bucket: {
"Fn::GetAtt": [
"CloudfrontLoggingBucket3C3EFAA7",
"RegionalDomainName"
]
}
},
Origins: [
{
CustomOriginConfig: {
OriginProtocolPolicy: "https-only",
OriginSSLProtocols: [
"TLSv1.2"
]
},
DomainName: {
"Fn::Select": [
0,
{
"Fn::Split": [
"/",
{
"Fn::Select": [
1,
{
"Fn::Split": [
"://",
{
"Fn::Join": [
"",
[
"https://",
{
Ref: "RestApi0C43BF4B"
},
".execute-api.",
{
Ref: "AWS::Region"
},
".",
{
Ref: "AWS::URLSuffix"
},
"/",
{
Ref: "RestApiDeploymentStageprod3855DE66"
},
"/"
]
]
}
]
}
]
}
]
}
]
},
Id: "CloudFrontDistributionOrigin176EC3A12",
OriginPath: {
"Fn::Join": [
"",
[
"/",
{
Ref: "RestApiDeploymentStageprod3855DE66"
}
]
]
}
}
]
}
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudfront-distribution-api-gateway-helper.test.js","sourceRoot":"","sources":["cloudfront-distribution-api-gateway-helper.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 { Stack } from 'aws-cdk-lib';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as apigw from 'aws-cdk-lib/aws-apigateway';\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as defaults from '../index';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport { CloudFrontDistributionForApiGateway } from '../lib/cloudfront-distribution-helper';\nimport * as origins from 'aws-cdk-lib/aws-cloudfront-origins';\nimport { LambdaEdgeEventType } from 'aws-cdk-lib/aws-cloudfront';\nimport { Template } from 'aws-cdk-lib/assertions';\n\ntest('test cloudfront for Api Gateway with user provided logging bucket', () => {\n  const stack = new Stack();\n\n  const logBucket: s3.Bucket = new s3.Bucket(stack, 'MyCloudfrontLoggingBucket', defaults.DefaultS3Props());\n\n  const inProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda-test`),\n    runtime: lambda.Runtime.PYTHON_3_9,\n    handler: 'index.handler'\n  };\n\n  const cfdProps = {\n    enableLogging: true,\n    logBucket\n  };\n\n  const func = defaults.deployLambdaFunction(stack, inProps);\n\n  const api = new apigw.LambdaRestApi(stack, 'RestApi1', {\n    handler: func\n  });\n\n  CloudFrontDistributionForApiGateway(stack, api, cfdProps);\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::CloudFront::Distribution\", {\n    DistributionConfig: {\n      DefaultCacheBehavior: {\n        CachePolicyId: \"658327ea-f89d-4fab-a63d-7e88639e58f6\",\n        Compress: true,\n        FunctionAssociations: [\n          {\n            EventType: \"viewer-response\",\n            FunctionARN: {\n              \"Fn::GetAtt\": [\n                \"SetHttpSecurityHeadersEE936115\",\n                \"FunctionARN\"\n              ]\n            }\n          }\n        ],\n        TargetOriginId: \"CloudFrontDistributionOrigin176EC3A12\",\n        ViewerProtocolPolicy: \"redirect-to-https\"\n      },\n      Enabled: true,\n      HttpVersion: \"http2\",\n      IPV6Enabled: true,\n      Logging: {\n        Bucket: {\n          \"Fn::GetAtt\": [\n            \"MyCloudfrontLoggingBucket9AA652E8\",\n            \"RegionalDomainName\"\n          ]\n        }\n      },\n      Origins: [\n        {\n          CustomOriginConfig: {\n            OriginProtocolPolicy: \"https-only\"\n          },\n          DomainName: {\n            \"Fn::Select\": [\n              0,\n              {\n                \"Fn::Split\": [\n                  \"/\",\n                  {\n                    \"Fn::Select\": [\n                      1,\n                      {\n                        \"Fn::Split\": [\n                          \"://\",\n                          {\n                            \"Fn::Join\": [\n                              \"\",\n                              [\n                                \"https://\",\n                                {\n                                  Ref: \"RestApi1480AC499\"\n                                },\n                                \".execute-api.\",\n                                {\n                                  Ref: \"AWS::Region\"\n                                },\n                                \".\",\n                                {\n                                  Ref: \"AWS::URLSuffix\"\n                                },\n                                \"/\",\n                                {\n                                  Ref: \"RestApi1DeploymentStageprod4FFC9BB4\"\n                                },\n                                \"/\"\n                              ]\n                            ]\n                          }\n                        ]\n                      }\n                    ]\n                  }\n                ]\n              }\n            ]\n          },\n          Id: \"CloudFrontDistributionOrigin176EC3A12\",\n          OriginPath: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"/\",\n                {\n                  Ref: \"RestApi1DeploymentStageprod4FFC9BB4\"\n                }\n              ]\n            ]\n          }\n        }\n      ]\n    }\n  });\n});\n\ntest('test cloudfront for Api Gateway override properties', () => {\n  const stack = new Stack();\n\n  const inProps: lambda.FunctionProps = {\n    code: lambda.Code.fromAsset(`${__dirname}/lambda-test`),\n    runtime: lambda.Runtime.PYTHON_3_9,\n    handler: 'index.handler'\n  };\n\n  const func = defaults.deployLambdaFunction(stack, inProps);\n\n  const api = new apigw.LambdaRestApi(stack, 'RestApi1', {\n    handler: func\n  });\n\n  const props: cloudfront.DistributionProps = {\n    defaultBehavior: {\n      origin: new origins.HttpOrigin(api.url, {\n        protocolPolicy: cloudfront.OriginProtocolPolicy.HTTP_ONLY\n      }),\n      allowedMethods: cloudfront.AllowedMethods.ALLOW_ALL,\n      cachedMethods: cloudfront.CachedMethods.CACHE_GET_HEAD_OPTIONS\n    },\n  };\n\n  CloudFrontDistributionForApiGateway(stack, api, props);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::CloudFront::Distribution\", {\n    DistributionConfig: {\n      DefaultCacheBehavior: {\n        AllowedMethods: [\n          \"GET\",\n          \"HEAD\",\n          \"OPTIONS\",\n          \"PUT\",\n          \"PATCH\",\n          \"POST\",\n          \"DELETE\"\n        ],\n        CachePolicyId: \"658327ea-f89d-4fab-a63d-7e88639e58f6\",\n        CachedMethods: [\n          \"GET\",\n          \"HEAD\",\n          \"OPTIONS\"\n        ],\n        Compress: true,\n        FunctionAssociations: [\n          {\n            EventType: \"viewer-response\",\n            FunctionARN: {\n              \"Fn::GetAtt\": [\n                \"SetHttpSecurityHeadersEE936115\",\n                \"FunctionARN\"\n              ]\n            }\n          }\n        ],\n        TargetOriginId: \"CloudFrontDistributionOrigin176EC3A12\",\n        ViewerProtocolPolicy: \"redirect-to-https\"\n      },\n      Enabled: true,\n      HttpVersion: \"http2\",\n      IPV6Enabled: true,\n      Logging: {\n        Bucket: {\n          \"Fn::GetAtt\": [\n            \"CloudfrontLoggingBucket3C3EFAA7\",\n            \"RegionalDomainName\"\n          ]\n        }\n      },\n      Origins: [\n        {\n          CustomOriginConfig: {\n            OriginProtocolPolicy: \"http-only\"\n          },\n          DomainName: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"https://\",\n                {\n                  Ref: \"RestApi1480AC499\"\n                },\n                \".execute-api.\",\n                {\n                  Ref: \"AWS::Region\"\n                },\n                \".\",\n                {\n                  Ref: \"AWS::URLSuffix\"\n                },\n                \"/\",\n                {\n                  Ref: \"RestApi1DeploymentStageprod4FFC9BB4\"\n                },\n                \"/\"\n              ]\n            ]\n          },\n          Id: \"CloudFrontDistributionOrigin176EC3A12\"\n        }\n      ]\n    }\n  });\n\n});\n\ntest('test override cloudfront add custom cloudfront function', () => {\n  const stack = new Stack();\n\n  // custom cloudfront function\n  const cloudfrontFunction = new cloudfront.Function(stack, \"MyFunction\", {\n    code: cloudfront.FunctionCode.fromInline(\"exports.handler = (event, context, callback) => {}\")\n  });\n\n  // APIG Lambda function\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  const func = new lambda.Function(stack, 'LambdaFunction', lambdaFunctionProps);\n  const api = new apigw.LambdaRestApi(stack, 'RestApi', {\n    handler: func\n  });\n  CloudFrontDistributionForApiGateway(stack, api, {\n    defaultBehavior: {\n      functionAssociations: [\n        {\n          eventType: cloudfront.FunctionEventType.VIEWER_RESPONSE,\n          function: cloudfrontFunction\n        }\n      ],\n    }\n  });\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::CloudFront::Distribution\", {\n    DistributionConfig: {\n      DefaultCacheBehavior: {\n        CachePolicyId: \"658327ea-f89d-4fab-a63d-7e88639e58f6\",\n        Compress: true,\n        FunctionAssociations: [\n          {\n            EventType: \"viewer-response\",\n            FunctionARN: {\n              \"Fn::GetAtt\": [\n                \"MyFunction3BAA72D1\",\n                \"FunctionARN\"\n              ]\n            }\n          }\n        ],\n        TargetOriginId: \"CloudFrontDistributionOrigin176EC3A12\",\n        ViewerProtocolPolicy: \"redirect-to-https\"\n      },\n      Enabled: true,\n      HttpVersion: \"http2\",\n      IPV6Enabled: true,\n      Logging: {\n        Bucket: {\n          \"Fn::GetAtt\": [\n            \"CloudfrontLoggingBucket3C3EFAA7\",\n            \"RegionalDomainName\"\n          ]\n        }\n      },\n      Origins: [\n        {\n          CustomOriginConfig: {\n            OriginProtocolPolicy: \"https-only\",\n            OriginSSLProtocols: [\n              \"TLSv1.2\"\n            ]\n          },\n          DomainName: {\n            \"Fn::Select\": [\n              0,\n              {\n                \"Fn::Split\": [\n                  \"/\",\n                  {\n                    \"Fn::Select\": [\n                      1,\n                      {\n                        \"Fn::Split\": [\n                          \"://\",\n                          {\n                            \"Fn::Join\": [\n                              \"\",\n                              [\n                                \"https://\",\n                                {\n                                  Ref: \"RestApi0C43BF4B\"\n                                },\n                                \".execute-api.\",\n                                {\n                                  Ref: \"AWS::Region\"\n                                },\n                                \".\",\n                                {\n                                  Ref: \"AWS::URLSuffix\"\n                                },\n                                \"/\",\n                                {\n                                  Ref: \"RestApiDeploymentStageprod3855DE66\"\n                                },\n                                \"/\"\n                              ]\n                            ]\n                          }\n                        ]\n                      }\n                    ]\n                  }\n                ]\n              }\n            ]\n          },\n          Id: \"CloudFrontDistributionOrigin176EC3A12\",\n          OriginPath: {\n            \"Fn::Join\": [\n              \"\",\n              [\n                \"/\",\n                {\n                  Ref: \"RestApiDeploymentStageprod3855DE66\"\n                }\n              ]\n            ]\n          }\n        }\n      ]\n    }\n  });\n});\n\ntest('test override cloudfront replace custom lambda@edge', () => {\n  const stack = new Stack();\n\n  // custom lambda@edg function\n  const handler = new lambda.Function(stack, 'SomeHandler', {\n    functionName: 'SomeHandler',\n    runtime: defaults.COMMERCIAL_REGION_LAMBDA_NODE_RUNTIME,\n    handler: 'index.handler',\n    code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  });\n\n  const handlerVersion = new lambda.Version(stack, 'SomeHandlerVersion', {\n    lambda: handler,\n  });\n\n  // APIG Lambda function\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  const func = new lambda.Function(stack, 'LambdaFunction', lambdaFunctionProps);\n  const api = new apigw.LambdaRestApi(stack, 'RestApi', {\n    handler: func\n  });\n  CloudFrontDistributionForApiGateway(stack, api, {\n    defaultBehavior: {\n      edgeLambdas: [\n        {\n          eventType: LambdaEdgeEventType.VIEWER_REQUEST,\n          includeBody: false,\n          functionVersion: handlerVersion,\n        }\n      ]\n    }\n  },\n  false);\n\n  const template = Template.fromStack(stack);\n  template.hasResourceProperties(\"AWS::CloudFront::Distribution\", {\n    DistributionConfig: {\n      DefaultCacheBehavior: {\n        CachePolicyId: \"658327ea-f89d-4fab-a63d-7e88639e58f6\",\n       