@aws-solutions-constructs/aws-cloudfront-apigateway-lambda 2.46.0 → 2.48.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,177 @@
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
+ "AuthorizerUri": {
167
+ "Fn::Join": [
168
+ "",
169
+ [
170
+ "arn:",
171
+ {
172
+ "Fn::Select": [
173
+ 1,
174
+ {
175
+ "Fn::Split": [
176
+ ":",
177
+ {
178
+ "Fn::GetAtt": [
179
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
180
+ "Arn"
181
+ ]
182
+ }
183
+ ]
184
+ }
185
+ ]
186
+ },
187
+ ":apigateway:",
188
+ {
189
+ "Fn::Select": [
190
+ 3,
191
+ {
192
+ "Fn::Split": [
193
+ ":",
194
+ {
195
+ "Fn::GetAtt": [
196
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
197
+ "Arn"
198
+ ]
199
+ }
200
+ ]
201
+ }
202
+ ]
203
+ },
204
+ ":lambda:path/2015-03-31/functions/",
205
+ {
206
+ "Fn::GetAtt": [
207
+ "cftaplamoverridebehaviorauthorizerAuthFunction9DD827D6",
208
+ "Arn"
209
+ ]
210
+ },
211
+ "/invocations"
212
+ ]
213
+ ]
214
+ },
215
+ "IdentitySource": "method.request.header.Authorization",
216
+ "Name": "cftaplamoverridebehaviorcftaplamoverridebehaviorauthorizer3042C32C",
217
+ "RestApiId": {
218
+ "Ref": "cfapilambdaoverrideLambdaRestApi6E7952FC"
219
+ },
220
+ "Type": "REQUEST"
221
+ }
222
+ },
52
223
  "cfapilambdaoverrideLambdaFunctionServiceRole4B1A4043": {
53
224
  "Type": "AWS::IAM::Role",
54
225
  "Properties": {
@@ -217,7 +388,7 @@
217
388
  "Name": "LambdaRestApi"
218
389
  }
219
390
  },
220
- "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00e7f3a114a506221ddcaf53765c4dd518": {
391
+ "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00a88f54114ca67f75c1f46116226ebd9d": {
221
392
  "Type": "AWS::ApiGateway::Deployment",
222
393
  "Properties": {
223
394
  "Description": "Automatically created by the RestApi construct",
@@ -255,7 +426,7 @@
255
426
  "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
427
  },
257
428
  "DeploymentId": {
258
- "Ref": "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00e7f3a114a506221ddcaf53765c4dd518"
429
+ "Ref": "cfapilambdaoverrideLambdaRestApiDeployment82ACBB00a88f54114ca67f75c1f46116226ebd9d"
259
430
  },
260
431
  "MethodSettings": [
261
432
  {
@@ -290,7 +461,10 @@
290
461
  "cfapilambdaoverrideLambdaRestApistaticGET81EF9C24": {
291
462
  "Type": "AWS::ApiGateway::Method",
292
463
  "Properties": {
293
- "AuthorizationType": "NONE",
464
+ "AuthorizationType": "CUSTOM",
465
+ "AuthorizerId": {
466
+ "Ref": "cftaplamoverridebehaviorauthorizer74D77225"
467
+ },
294
468
  "HttpMethod": "GET",
295
469
  "Integration": {
296
470
  "IntegrationHttpMethod": "GET",
@@ -411,7 +585,10 @@
411
585
  "cfapilambdaoverrideLambdaRestApidynamicGET15050D54": {
412
586
  "Type": "AWS::ApiGateway::Method",
413
587
  "Properties": {
414
- "AuthorizationType": "NONE",
588
+ "AuthorizationType": "CUSTOM",
589
+ "AuthorizerId": {
590
+ "Ref": "cftaplamoverridebehaviorauthorizer74D77225"
591
+ },
415
592
  "HttpMethod": "GET",
416
593
  "Integration": {
417
594
  "IntegrationHttpMethod": "POST",
@@ -559,10 +736,9 @@
559
736
  "Name": "SetHttpSecurityHeadersc826c2a6a3ffe209aed33765f37752084820de0d3b"
560
737
  }
561
738
  },
562
- "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0": {
739
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9": {
563
740
  "Type": "AWS::S3::Bucket",
564
741
  "Properties": {
565
- "AccessControl": "LogDeliveryWrite",
566
742
  "BucketEncryption": {
567
743
  "ServerSideEncryptionConfiguration": [
568
744
  {
@@ -602,12 +778,197 @@
602
778
  "rules_to_suppress": [
603
779
  {
604
780
  "id": "W35",
605
- "reason": "This S3 bucket is used as the access logging bucket for CloudFront Distribution"
781
+ "reason": "This S3 bucket is used as the access logging bucket for another bucket"
606
782
  }
607
783
  ]
608
784
  }
609
785
  }
610
786
  },
787
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicy53DB42E0": {
788
+ "Type": "AWS::S3::BucketPolicy",
789
+ "Properties": {
790
+ "Bucket": {
791
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
792
+ },
793
+ "PolicyDocument": {
794
+ "Statement": [
795
+ {
796
+ "Action": "s3:*",
797
+ "Condition": {
798
+ "Bool": {
799
+ "aws:SecureTransport": "false"
800
+ }
801
+ },
802
+ "Effect": "Deny",
803
+ "Principal": {
804
+ "AWS": "*"
805
+ },
806
+ "Resource": [
807
+ {
808
+ "Fn::GetAtt": [
809
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
810
+ "Arn"
811
+ ]
812
+ },
813
+ {
814
+ "Fn::Join": [
815
+ "",
816
+ [
817
+ {
818
+ "Fn::GetAtt": [
819
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
820
+ "Arn"
821
+ ]
822
+ },
823
+ "/*"
824
+ ]
825
+ ]
826
+ }
827
+ ]
828
+ },
829
+ {
830
+ "Action": [
831
+ "s3:PutBucketPolicy",
832
+ "s3:GetBucket*",
833
+ "s3:List*",
834
+ "s3:DeleteObject*"
835
+ ],
836
+ "Effect": "Allow",
837
+ "Principal": {
838
+ "AWS": {
839
+ "Fn::GetAtt": [
840
+ "CustomS3AutoDeleteObjectsCustomResourceProviderRole3B1BD092",
841
+ "Arn"
842
+ ]
843
+ }
844
+ },
845
+ "Resource": [
846
+ {
847
+ "Fn::GetAtt": [
848
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
849
+ "Arn"
850
+ ]
851
+ },
852
+ {
853
+ "Fn::Join": [
854
+ "",
855
+ [
856
+ {
857
+ "Fn::GetAtt": [
858
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
859
+ "Arn"
860
+ ]
861
+ },
862
+ "/*"
863
+ ]
864
+ ]
865
+ }
866
+ ]
867
+ },
868
+ {
869
+ "Action": "s3:PutObject",
870
+ "Condition": {
871
+ "ArnLike": {
872
+ "aws:SourceArn": {
873
+ "Fn::GetAtt": [
874
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0",
875
+ "Arn"
876
+ ]
877
+ }
878
+ },
879
+ "StringEquals": {
880
+ "aws:SourceAccount": {
881
+ "Ref": "AWS::AccountId"
882
+ }
883
+ }
884
+ },
885
+ "Effect": "Allow",
886
+ "Principal": {
887
+ "Service": "logging.s3.amazonaws.com"
888
+ },
889
+ "Resource": {
890
+ "Fn::Join": [
891
+ "",
892
+ [
893
+ {
894
+ "Fn::GetAtt": [
895
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9",
896
+ "Arn"
897
+ ]
898
+ },
899
+ "/*"
900
+ ]
901
+ ]
902
+ }
903
+ }
904
+ ],
905
+ "Version": "2012-10-17"
906
+ }
907
+ }
908
+ },
909
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogAutoDeleteObjectsCustomResource33279C95": {
910
+ "Type": "Custom::S3AutoDeleteObjects",
911
+ "Properties": {
912
+ "ServiceToken": {
913
+ "Fn::GetAtt": [
914
+ "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F",
915
+ "Arn"
916
+ ]
917
+ },
918
+ "BucketName": {
919
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
920
+ }
921
+ },
922
+ "DependsOn": [
923
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicy53DB42E0"
924
+ ],
925
+ "UpdateReplacePolicy": "Delete",
926
+ "DeletionPolicy": "Delete"
927
+ },
928
+ "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0": {
929
+ "Type": "AWS::S3::Bucket",
930
+ "Properties": {
931
+ "AccessControl": "LogDeliveryWrite",
932
+ "BucketEncryption": {
933
+ "ServerSideEncryptionConfiguration": [
934
+ {
935
+ "ServerSideEncryptionByDefault": {
936
+ "SSEAlgorithm": "AES256"
937
+ }
938
+ }
939
+ ]
940
+ },
941
+ "LoggingConfiguration": {
942
+ "DestinationBucketName": {
943
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
944
+ }
945
+ },
946
+ "OwnershipControls": {
947
+ "Rules": [
948
+ {
949
+ "ObjectOwnership": "ObjectWriter"
950
+ }
951
+ ]
952
+ },
953
+ "PublicAccessBlockConfiguration": {
954
+ "BlockPublicAcls": true,
955
+ "BlockPublicPolicy": true,
956
+ "IgnorePublicAcls": true,
957
+ "RestrictPublicBuckets": true
958
+ },
959
+ "Tags": [
960
+ {
961
+ "Key": "aws-cdk:auto-delete-objects",
962
+ "Value": "true"
963
+ }
964
+ ],
965
+ "VersioningConfiguration": {
966
+ "Status": "Enabled"
967
+ }
968
+ },
969
+ "UpdateReplacePolicy": "Delete",
970
+ "DeletionPolicy": "Delete"
971
+ },
611
972
  "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketPolicyC3092436": {
612
973
  "Type": "AWS::S3::BucketPolicy",
613
974
  "Properties": {
@@ -949,7 +1310,7 @@
949
1310
  [
950
1311
  "Lambda function for auto-deleting objects in ",
951
1312
  {
952
- "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucket3A71B9E0"
1313
+ "Ref": "cfapilambdaoverrideCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog9CEB5CD9"
953
1314
  },
954
1315
  " S3 bucket."
955
1316
  ]
@@ -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"]}