UNPKG

@aws-solutions-constructs/core

Version:
497 lines 53.6 kB
"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       