@aws-solutions-constructs/aws-cloudfront-apigateway-lambda 2.47.0 → 2.49.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.
@@ -49,6 +49,178 @@
49
49
  }
50
50
  }
51
51
  },
52
+ "cftaplamoverridebehaviorauthorizerAuthFunctionServiceRoleA606974F": {
53
+ "Type": "AWS::IAM::Role",
54
+ "Properties": {
55
+ "AssumeRolePolicyDocument": {
56
+ "Statement": [
57
+ {
58
+ "Action": "sts:AssumeRole",
59
+ "Effect": "Allow",
60
+ "Principal": {
61
+ "Service": "lambda.amazonaws.com"
62
+ }
63
+ }
64
+ ],
65
+ "Version": "2012-10-17"
66
+ },
67
+ "ManagedPolicyArns": [
68
+ {
69
+ "Fn::Join": [
70
+ "",
71
+ [
72
+ "arn:",
73
+ {
74
+ "Ref": "AWS::Partition"
75
+ },
76
+ ":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
77
+ ]
78
+ ]
79
+ }
80
+ ]
81
+ }
82
+ },
83
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6": {
84
+ "Type": "AWS::Lambda::Function",
85
+ "Properties": {
86
+ "Code": {
87
+ "S3Bucket": {
88
+ "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
89
+ },
90
+ "S3Key": "42a35bbf0dec9ef0ac5b0dde87e71a1b8929e8d2d178dd09ccfb2c928ec0198c.zip"
91
+ },
92
+ "Handler": ".handler",
93
+ "Role": {
94
+ "Fn::GetAtt": [
95
+ "cftaplamoverridebehaviorauthorizerAuthFunctionServiceRoleA606974F",
96
+ "Arn"
97
+ ]
98
+ },
99
+ "Runtime": "nodejs16.x"
100
+ },
101
+ "DependsOn": [
102
+ "cftaplamoverridebehaviorauthorizerAuthFunctionServiceRoleA606974F"
103
+ ],
104
+ "Metadata": {
105
+ "cfn_nag": {
106
+ "rules_to_suppress": [
107
+ {
108
+ "id": "W58",
109
+ "reason": "Test Resource"
110
+ },
111
+ {
112
+ "id": "W89",
113
+ "reason": "Test Resource"
114
+ },
115
+ {
116
+ "id": "W92",
117
+ "reason": "Test Resource"
118
+ }
119
+ ]
120
+ }
121
+ }
122
+ },
123
+ "cftaplamoverridebehaviorauthorizerAuthFunctioncftaplamoverridebehaviorcftaplamoverridebehaviorauthorizer3042C32CPermissions33B8870B": {
124
+ "Type": "AWS::Lambda::Permission",
125
+ "Properties": {
126
+ "Action": "lambda:InvokeFunction",
127
+ "FunctionName": {
128
+ "Fn::GetAtt": [
129
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
130
+ "Arn"
131
+ ]
132
+ },
133
+ "Principal": "apigateway.amazonaws.com",
134
+ "SourceArn": {
135
+ "Fn::Join": [
136
+ "",
137
+ [
138
+ "arn:",
139
+ {
140
+ "Ref": "AWS::Partition"
141
+ },
142
+ ":execute-api:",
143
+ {
144
+ "Ref": "AWS::Region"
145
+ },
146
+ ":",
147
+ {
148
+ "Ref": "AWS::AccountId"
149
+ },
150
+ ":",
151
+ {
152
+ "Ref": "cfapilambdaoverrideLambdaRestApi6E7952FC"
153
+ },
154
+ "/authorizers/",
155
+ {
156
+ "Ref": "cftaplamoverridebehaviorauthorizer74D77225"
157
+ }
158
+ ]
159
+ ]
160
+ }
161
+ }
162
+ },
163
+ "cftaplamoverridebehaviorauthorizer74D77225": {
164
+ "Type": "AWS::ApiGateway::Authorizer",
165
+ "Properties": {
166
+ "AuthorizerResultTtlInSeconds": 300,
167
+ "AuthorizerUri": {
168
+ "Fn::Join": [
169
+ "",
170
+ [
171
+ "arn:",
172
+ {
173
+ "Fn::Select": [
174
+ 1,
175
+ {
176
+ "Fn::Split": [
177
+ ":",
178
+ {
179
+ "Fn::GetAtt": [
180
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
181
+ "Arn"
182
+ ]
183
+ }
184
+ ]
185
+ }
186
+ ]
187
+ },
188
+ ":apigateway:",
189
+ {
190
+ "Fn::Select": [
191
+ 3,
192
+ {
193
+ "Fn::Split": [
194
+ ":",
195
+ {
196
+ "Fn::GetAtt": [
197
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
198
+ "Arn"
199
+ ]
200
+ }
201
+ ]
202
+ }
203
+ ]
204
+ },
205
+ ":lambda:path/2015-03-31/functions/",
206
+ {
207
+ "Fn::GetAtt": [
208
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
209
+ "Arn"
210
+ ]
211
+ },
212
+ "/invocations"
213
+ ]
214
+ ]
215
+ },
216
+ "IdentitySource": "method.request.header.Authorization",
217
+ "Name": "cftaplamoverridebehaviorcftaplamoverridebehaviorauthorizer3042C32C",
218
+ "RestApiId": {
219
+ "Ref": "cfapilambdaoverrideLambdaRestApi6E7952FC"
220
+ },
221
+ "Type": "REQUEST"
222
+ }
223
+ },
52
224
  "cfapilambdaoverrideLambdaFunctionServiceRole4B1A4043": {
53
225
  "Type": "AWS::IAM::Role",
54
226
  "Properties": {
@@ -217,7 +389,7 @@
217
389
  "Name": "LambdaRestApi"
218
390
  }
219
391
  },
220
- "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00e7f3a114a506221ddcaf53765c4dd518": {
392
+ "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00a88f54114ca67f75c1f46116226ebd9d": {
221
393
  "Type": "AWS::ApiGateway::Deployment",
222
394
  "Properties": {
223
395
  "Description": "Automatically created by the RestApi construct",
@@ -255,7 +427,7 @@
255
427
  "Format": "{\"requestId\":\"$context.requestId\",\"ip\":\"$context.identity.sourceIp\",\"user\":\"$context.identity.user\",\"caller\":\"$context.identity.caller\",\"requestTime\":\"$context.requestTime\",\"httpMethod\":\"$context.httpMethod\",\"resourcePath\":\"$context.resourcePath\",\"status\":\"$context.status\",\"protocol\":\"$context.protocol\",\"responseLength\":\"$context.responseLength\"}"
256
428
  },
257
429
  "DeploymentId": {
258
- "Ref": "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00e7f3a114a506221ddcaf53765c4dd518"
430
+ "Ref": "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00a88f54114ca67f75c1f46116226ebd9d"
259
431
  },
260
432
  "MethodSettings": [
261
433
  {
@@ -290,7 +462,10 @@
290
462
  "cfapilambdaoverrideLambdaRestApistaticGET81EF9C24": {
291
463
  "Type": "AWS::ApiGateway::Method",
292
464
  "Properties": {
293
- "AuthorizationType": "NONE",
465
+ "AuthorizationType": "CUSTOM",
466
+ "AuthorizerId": {
467
+ "Ref": "cftaplamoverridebehaviorauthorizer74D77225"
468
+ },
294
469
  "HttpMethod": "GET",
295
470
  "Integration": {
296
471
  "IntegrationHttpMethod": "GET",
@@ -411,7 +586,10 @@
411
586
  "cfapilambdaoverrideLambdaRestApidynamicGET15050D54": {
412
587
  "Type": "AWS::ApiGateway::Method",
413
588
  "Properties": {
414
- "AuthorizationType": "NONE",
589
+ "AuthorizationType": "CUSTOM",
590
+ "AuthorizerId": {
591
+ "Ref": "cftaplamoverridebehaviorauthorizer74D77225"
592
+ },
415
593
  "HttpMethod": "GET",
416
594
  "Integration": {
417
595
  "IntegrationHttpMethod": "POST",
@@ -559,10 +737,9 @@
559
737
  "Name": "SetHttpSecurityHeadersc826c2a6a3ffe209aed33765f37752084820de0d3b"
560
738
  }
561
739
  },
562
- "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0": {
740
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9": {
563
741
  "Type": "AWS::S3::Bucket",
564
742
  "Properties": {
565
- "AccessControl": "LogDeliveryWrite",
566
743
  "BucketEncryption": {
567
744
  "ServerSideEncryptionConfiguration": [
568
745
  {
@@ -602,12 +779,197 @@
602
779
  "rules_to_suppress": [
603
780
  {
604
781
  "id": "W35",
605
- "reason": "This S3 bucket is used as the access logging bucket for CloudFront Distribution"
782
+ "reason": "This S3 bucket is used as the access logging bucket for another bucket"
606
783
  }
607
784
  ]
608
785
  }
609
786
  }
610
787
  },
788
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicy53DB42E0": {
789
+ "Type": "AWS::S3::BucketPolicy",
790
+ "Properties": {
791
+ "Bucket": {
792
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
793
+ },
794
+ "PolicyDocument": {
795
+ "Statement": [
796
+ {
797
+ "Action": "s3:*",
798
+ "Condition": {
799
+ "Bool": {
800
+ "aws:SecureTransport": "false"
801
+ }
802
+ },
803
+ "Effect": "Deny",
804
+ "Principal": {
805
+ "AWS": "*"
806
+ },
807
+ "Resource": [
808
+ {
809
+ "Fn::GetAtt": [
810
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
811
+ "Arn"
812
+ ]
813
+ },
814
+ {
815
+ "Fn::Join": [
816
+ "",
817
+ [
818
+ {
819
+ "Fn::GetAtt": [
820
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
821
+ "Arn"
822
+ ]
823
+ },
824
+ "/*"
825
+ ]
826
+ ]
827
+ }
828
+ ]
829
+ },
830
+ {
831
+ "Action": [
832
+ "s3:PutBucketPolicy",
833
+ "s3:GetBucket*",
834
+ "s3:List*",
835
+ "s3:DeleteObject*"
836
+ ],
837
+ "Effect": "Allow",
838
+ "Principal": {
839
+ "AWS": {
840
+ "Fn::GetAtt": [
841
+ "CustomS3AutoDeleteObjectsCustomResourceProviderRole3B1BD092",
842
+ "Arn"
843
+ ]
844
+ }
845
+ },
846
+ "Resource": [
847
+ {
848
+ "Fn::GetAtt": [
849
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
850
+ "Arn"
851
+ ]
852
+ },
853
+ {
854
+ "Fn::Join": [
855
+ "",
856
+ [
857
+ {
858
+ "Fn::GetAtt": [
859
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
860
+ "Arn"
861
+ ]
862
+ },
863
+ "/*"
864
+ ]
865
+ ]
866
+ }
867
+ ]
868
+ },
869
+ {
870
+ "Action": "s3:PutObject",
871
+ "Condition": {
872
+ "ArnLike": {
873
+ "aws:SourceArn": {
874
+ "Fn::GetAtt": [
875
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0",
876
+ "Arn"
877
+ ]
878
+ }
879
+ },
880
+ "StringEquals": {
881
+ "aws:SourceAccount": {
882
+ "Ref": "AWS::AccountId"
883
+ }
884
+ }
885
+ },
886
+ "Effect": "Allow",
887
+ "Principal": {
888
+ "Service": "logging.s3.amazonaws.com"
889
+ },
890
+ "Resource": {
891
+ "Fn::Join": [
892
+ "",
893
+ [
894
+ {
895
+ "Fn::GetAtt": [
896
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
897
+ "Arn"
898
+ ]
899
+ },
900
+ "/*"
901
+ ]
902
+ ]
903
+ }
904
+ }
905
+ ],
906
+ "Version": "2012-10-17"
907
+ }
908
+ }
909
+ },
910
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogAutoDeleteObjectsCustomResource33279C95": {
911
+ "Type": "Custom::S3AutoDeleteObjects",
912
+ "Properties": {
913
+ "ServiceToken": {
914
+ "Fn::GetAtt": [
915
+ "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F",
916
+ "Arn"
917
+ ]
918
+ },
919
+ "BucketName": {
920
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
921
+ }
922
+ },
923
+ "DependsOn": [
924
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicy53DB42E0"
925
+ ],
926
+ "UpdateReplacePolicy": "Delete",
927
+ "DeletionPolicy": "Delete"
928
+ },
929
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0": {
930
+ "Type": "AWS::S3::Bucket",
931
+ "Properties": {
932
+ "AccessControl": "LogDeliveryWrite",
933
+ "BucketEncryption": {
934
+ "ServerSideEncryptionConfiguration": [
935
+ {
936
+ "ServerSideEncryptionByDefault": {
937
+ "SSEAlgorithm": "AES256"
938
+ }
939
+ }
940
+ ]
941
+ },
942
+ "LoggingConfiguration": {
943
+ "DestinationBucketName": {
944
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
945
+ }
946
+ },
947
+ "OwnershipControls": {
948
+ "Rules": [
949
+ {
950
+ "ObjectOwnership": "ObjectWriter"
951
+ }
952
+ ]
953
+ },
954
+ "PublicAccessBlockConfiguration": {
955
+ "BlockPublicAcls": true,
956
+ "BlockPublicPolicy": true,
957
+ "IgnorePublicAcls": true,
958
+ "RestrictPublicBuckets": true
959
+ },
960
+ "Tags": [
961
+ {
962
+ "Key": "aws-cdk:auto-delete-objects",
963
+ "Value": "true"
964
+ }
965
+ ],
966
+ "VersioningConfiguration": {
967
+ "Status": "Enabled"
968
+ }
969
+ },
970
+ "UpdateReplacePolicy": "Delete",
971
+ "DeletionPolicy": "Delete"
972
+ },
611
973
  "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketPolicyC3092436": {
612
974
  "Type": "AWS::S3::BucketPolicy",
613
975
  "Properties": {
@@ -949,7 +1311,7 @@
949
1311
  [
950
1312
  "Lambda function for auto-deleting objects in ",
951
1313
  {
952
- "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0"
1314
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
953
1315
  },
954
1316
  " S3 bucket."
955
1317
  ]
@@ -50,7 +50,8 @@ const construct = new lib_1.CloudFrontToApiGatewayToLambda(stack, 'cf-api-lambda
50
50
  apiGatewayProps: {
51
51
  proxy: false,
52
52
  defaultMethodOptions: {
53
- authorizationType: apigateway.AuthorizationType.NONE,
53
+ authorizationType: apigateway.AuthorizationType.CUSTOM,
54
+ authorizer: core_1.CreateApiAuthorizer(stack, `${core_1.generateIntegStackName(__filename)}-authorizer`)
54
55
  },
55
56
  },
56
57
  cloudFrontDistributionProps: {
@@ -93,4 +94,4 @@ function suppressWarnings(method) {
93
94
  core_1.suppressAutoDeleteHandlerWarnings(stack);
94
95
  // Synth
95
96
  app.synth();
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ.cftaplam-override-behavior.js","sourceRoot":"","sources":["integ.cftaplam-override-behavior.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n/// !cdk-integ *\nimport { App, RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport { CloudFrontToApiGatewayToLambda } from \"../lib\";\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as apigateway from 'aws-cdk-lib/aws-apigateway';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration } from \"aws-cdk-lib\";\nimport * as origins from 'aws-cdk-lib/aws-cloudfront-origins';\nimport { generateIntegStackName, suppressAutoDeleteHandlerWarnings } from '@aws-solutions-constructs/core';\n\n// Setup\nconst app = new App();\nconst stack = new Stack(app, generateIntegStackName(__filename));\nstack.templateOptions.description = 'Integration Test for aws-cloudfront-apigateway-lambda';\n\nconst lambdaProps: lambda.FunctionProps = {\n  code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  runtime: lambda.Runtime.NODEJS_16_X,\n  handler: 'index.handler'\n};\n\n// Some Caching for static content\nconst someCachePolicy = new cloudfront.CachePolicy(stack, 'SomeCachePolicy', {\n  cachePolicyName: 'SomeCachePolicy',\n  defaultTtl: Duration.hours(8),\n  minTtl: Duration.hours(5),\n  maxTtl: Duration.hours(10),\n});\n\n// Disable Caching for dynamic content\nconst noCachePolicy = new cloudfront.CachePolicy(stack, 'NoCachePolicy', {\n  cachePolicyName: 'NoCachePolicy',\n  defaultTtl: Duration.minutes(0),\n  minTtl: Duration.minutes(0),\n  maxTtl: Duration.minutes(0),\n});\n\nconst construct = new CloudFrontToApiGatewayToLambda(stack, 'cf-api-lambda-override', {\n  lambdaFunctionProps: lambdaProps,\n  apiGatewayProps: {\n    proxy: false,\n    defaultMethodOptions: {\n      authorizationType: apigateway.AuthorizationType.NONE,\n    },\n  },\n  cloudFrontDistributionProps: {\n    defaultBehavior: {\n      cachePolicy: someCachePolicy\n    }\n  },\n  cloudFrontLoggingBucketProps: {\n    removalPolicy: RemovalPolicy.DESTROY,\n    autoDeleteObjects: true\n  },\n});\n\nconst apiEndPoint = construct.apiGateway;\nconst apiEndPointUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split(\"://\", apiEndPoint.url));\nconst apiEndPointDomainName = cdk.Fn.select(0, cdk.Fn.split(\"/\", apiEndPointUrlWithoutProtocol));\n\nconst staticResource = construct.apiGateway.root.addResource('static');\nconst staticMethod = staticResource.addMethod('GET', new apigateway.HttpIntegration('http://amazon.com'));\n\nconst dynamicResource = construct.apiGateway.root.addResource('dynamic');\nconst dynamicMethod = dynamicResource.addMethod('GET');\n\n// Add behavior\nconstruct.cloudFrontWebDistribution.addBehavior('/dynamic', new origins.HttpOrigin(apiEndPointDomainName, {\n  originPath: `/${apiEndPoint.deploymentStage.stageName}/dynamic`\n}), {\n  cachePolicy: noCachePolicy\n});\n// Suppress CFN_NAG warnings\nsuppressWarnings(staticMethod);\nsuppressWarnings(dynamicMethod);\n\nfunction suppressWarnings(method: apigateway.Method) {\n  const child = method.node.findChild('Resource') as apigateway.CfnMethod;\n  child.cfnOptions.metadata = {\n    cfn_nag: {\n      rules_to_suppress: [{\n        id: 'W59',\n        reason: `AWS::ApiGateway::Method AuthorizationType is set to 'NONE' because API Gateway behind CloudFront does not support AWS_IAM authentication`\n      }]\n    }\n  };\n}\n\nsuppressAutoDeleteHandlerWarnings(stack);\n// Synth\napp.synth();\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"integ.cftaplam-override-behavior.js","sourceRoot":"","sources":["integ.cftaplam-override-behavior.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\n/// !cdk-integ *\nimport { App, RemovalPolicy, Stack } from \"aws-cdk-lib\";\nimport { CloudFrontToApiGatewayToLambda } from \"../lib\";\nimport * as lambda from 'aws-cdk-lib/aws-lambda';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport * as apigateway from 'aws-cdk-lib/aws-apigateway';\nimport * as cdk from 'aws-cdk-lib';\nimport { Duration } from \"aws-cdk-lib\";\nimport * as origins from 'aws-cdk-lib/aws-cloudfront-origins';\nimport { generateIntegStackName, suppressAutoDeleteHandlerWarnings, CreateApiAuthorizer } from '@aws-solutions-constructs/core';\n\n// Setup\nconst app = new App();\nconst stack = new Stack(app, generateIntegStackName(__filename));\nstack.templateOptions.description = 'Integration Test for aws-cloudfront-apigateway-lambda';\n\nconst lambdaProps: lambda.FunctionProps = {\n  code: lambda.Code.fromAsset(`${__dirname}/lambda`),\n  runtime: lambda.Runtime.NODEJS_16_X,\n  handler: 'index.handler'\n};\n\n// Some Caching for static content\nconst someCachePolicy = new cloudfront.CachePolicy(stack, 'SomeCachePolicy', {\n  cachePolicyName: 'SomeCachePolicy',\n  defaultTtl: Duration.hours(8),\n  minTtl: Duration.hours(5),\n  maxTtl: Duration.hours(10),\n});\n\n// Disable Caching for dynamic content\nconst noCachePolicy = new cloudfront.CachePolicy(stack, 'NoCachePolicy', {\n  cachePolicyName: 'NoCachePolicy',\n  defaultTtl: Duration.minutes(0),\n  minTtl: Duration.minutes(0),\n  maxTtl: Duration.minutes(0),\n});\n\nconst construct = new CloudFrontToApiGatewayToLambda(stack, 'cf-api-lambda-override', {\n  lambdaFunctionProps: lambdaProps,\n  apiGatewayProps: {\n    proxy: false,\n    defaultMethodOptions: {\n      authorizationType: apigateway.AuthorizationType.CUSTOM,\n      authorizer: CreateApiAuthorizer(stack, `${generateIntegStackName(__filename)}-authorizer`)\n    },\n  },\n  cloudFrontDistributionProps: {\n    defaultBehavior: {\n      cachePolicy: someCachePolicy\n    }\n  },\n  cloudFrontLoggingBucketProps: {\n    removalPolicy: RemovalPolicy.DESTROY,\n    autoDeleteObjects: true\n  },\n});\n\nconst apiEndPoint = construct.apiGateway;\nconst apiEndPointUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split(\"://\", apiEndPoint.url));\nconst apiEndPointDomainName = cdk.Fn.select(0, cdk.Fn.split(\"/\", apiEndPointUrlWithoutProtocol));\n\nconst staticResource = construct.apiGateway.root.addResource('static');\nconst staticMethod = staticResource.addMethod('GET', new apigateway.HttpIntegration('http://amazon.com'));\n\nconst dynamicResource = construct.apiGateway.root.addResource('dynamic');\nconst dynamicMethod = dynamicResource.addMethod('GET');\n\n// Add behavior\nconstruct.cloudFrontWebDistribution.addBehavior('/dynamic', new origins.HttpOrigin(apiEndPointDomainName, {\n  originPath: `/${apiEndPoint.deploymentStage.stageName}/dynamic`\n}), {\n  cachePolicy: noCachePolicy\n});\n// Suppress CFN_NAG warnings\nsuppressWarnings(staticMethod);\nsuppressWarnings(dynamicMethod);\n\nfunction suppressWarnings(method: apigateway.Method) {\n  const child = method.node.findChild('Resource') as apigateway.CfnMethod;\n  child.cfnOptions.metadata = {\n    cfn_nag: {\n      rules_to_suppress: [{\n        id: 'W59',\n        reason: `AWS::ApiGateway::Method AuthorizationType is set to 'NONE' because API Gateway behind CloudFront does not support AWS_IAM authentication`\n      }]\n    }\n  };\n}\n\nsuppressAutoDeleteHandlerWarnings(stack);\n// Synth\napp.synth();\n"]}