@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.
package/lib/index.js CHANGED
@@ -20,27 +20,28 @@ class CloudFrontToApiGatewayToLambda extends constructs_1.Construct {
20
20
  super(scope, id);
21
21
  defaults.CheckLambdaProps(props);
22
22
  // CheckCloudFrontProps() is called by internal aws-cloudfront-apigateway construct
23
+ if (!props.apiGatewayProps?.defaultMethodOptions?.authorizationType) {
24
+ defaults.printWarning('As of v2.48.0, apiGatewayProps.defaultMethodOptions.authorizationType is\
25
+ required. To update your instantiation call, add the following to your CloudFrontToApiGatewayToLambdaProps argument\
26
+ \n\napiGatewayProps: { defaultMethodOptions: { authorizationType: api.AuthorizationType.NONE }},\n\nSee Issue1043 for an explanation.');
27
+ throw new Error('As of v2.48.0, an explicit authorization type is required for CloudFront/API Gateway patterns');
28
+ }
29
+ else if (props.apiGatewayProps.defaultMethodOptions.authorizationType === "AWS_IAM") {
30
+ throw new Error('Amazon API Gateway Rest APIs integrated with Amazon CloudFront do not support AWS_IAM authorization');
31
+ }
32
+ // All our tests are based upon this behavior being on, so we're setting
33
+ // context here rather than assuming the client will set it
34
+ this.node.setContext("@aws-cdk/aws-s3:serverAccessLogsUseBucketPolicy", true);
23
35
  this.lambdaFunction = defaults.buildLambdaFunction(this, {
24
36
  existingLambdaObj: props.existingLambdaObj,
25
37
  lambdaFunctionProps: props.lambdaFunctionProps
26
38
  });
27
- const regionalLambdaRestApiResponse = defaults.RegionalLambdaRestApi(this, this.lambdaFunction, props.apiGatewayProps, props.logGroupProps);
39
+ // We can't default to IAM authentication with a CloudFront distribution, so
40
+ // we'll instruct core to not use any default auth to avoid override warnings
41
+ const regionalLambdaRestApiResponse = defaults.RegionalLambdaRestApi(this, this.lambdaFunction, props.apiGatewayProps, props.logGroupProps, false);
28
42
  this.apiGateway = regionalLambdaRestApiResponse.api;
29
43
  this.apiGatewayCloudWatchRole = regionalLambdaRestApiResponse.role;
30
44
  this.apiGatewayLogGroup = regionalLambdaRestApiResponse.group;
31
- this.apiGateway.methods.forEach((apiMethod) => {
32
- // Override the API Gateway Authorization Type from AWS_IAM to NONE
33
- const child = apiMethod.node.findChild('Resource');
34
- if (child.authorizationType === 'AWS_IAM') {
35
- child.addPropertyOverride('AuthorizationType', 'NONE');
36
- defaults.addCfnSuppressRules(apiMethod, [
37
- {
38
- id: 'W59',
39
- reason: `AWS::ApiGateway::Method AuthorizationType is set to 'NONE' because API Gateway behind CloudFront does not support AWS_IAM authentication`
40
- },
41
- ]);
42
- }
43
- });
44
45
  const apiCloudfront = new aws_cloudfront_apigateway_1.CloudFrontToApiGateway(this, 'CloudFrontToApiGateway', {
45
46
  existingApiGatewayObj: this.apiGateway,
46
47
  cloudFrontDistributionProps: props.cloudFrontDistributionProps,
@@ -55,5 +56,5 @@ class CloudFrontToApiGatewayToLambda extends constructs_1.Construct {
55
56
  }
56
57
  exports.CloudFrontToApiGatewayToLambda = CloudFrontToApiGatewayToLambda;
57
58
  _a = JSII_RTTI_SYMBOL_1;
58
- CloudFrontToApiGatewayToLambda[_a] = { fqn: "@aws-solutions-constructs/aws-cloudfront-apigateway-lambda.CloudFrontToApiGatewayToLambda", version: "2.47.0" };
59
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAmBA,2DAA2D;AAC3D,wFAAwF;AACxF,2CAAuC;AACvC,mGAA6F;AAiE7F,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,mFAAmF;QAEnF,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,MAAM,6BAA6B,GAAG,QAAQ,CAAC,qBAAqB,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,eAAe,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QAC5I,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,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,EAAE;YAC5C,mEAAmE;YACnE,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAkB,CAAC;YACpE,IAAI,KAAK,CAAC,iBAAiB,KAAK,SAAS,EAAE;gBACzC,KAAK,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;gBAEvD,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE;oBACtC;wBACE,EAAE,EAAE,KAAK;wBACT,MAAM,EAAE,0IAA0I;qBACnJ;iBACF,CAAC,CAAC;aAEJ;QACH,CAAC,CAAC,CAAC;QAEH,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;;AA3DH,wEA4DC","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.\n   *\n   * @default - Default props are used\n   */\n  readonly lambdaFunctionProps?: lambda.FunctionProps\n  /**\n   * Optional user provided props to override the default props for the API Gateway.\n   *\n   * @default - Default props are used\n   */\n  readonly apiGatewayProps?: api.LambdaRestApiProps | any\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    // CheckCloudFrontProps() is called by internal aws-cloudfront-apigateway construct\n\n    this.lambdaFunction = defaults.buildLambdaFunction(this, {\n      existingLambdaObj: props.existingLambdaObj,\n      lambdaFunctionProps: props.lambdaFunctionProps\n    });\n\n    const regionalLambdaRestApiResponse = defaults.RegionalLambdaRestApi(this, this.lambdaFunction, props.apiGatewayProps, props.logGroupProps);\n    this.apiGateway = regionalLambdaRestApiResponse.api;\n    this.apiGatewayCloudWatchRole = regionalLambdaRestApiResponse.role;\n    this.apiGatewayLogGroup = regionalLambdaRestApiResponse.group;\n\n    this.apiGateway.methods.forEach((apiMethod) => {\n      // Override the API Gateway Authorization Type from AWS_IAM to NONE\n      const child = apiMethod.node.findChild('Resource') as api.CfnMethod;\n      if (child.authorizationType === 'AWS_IAM') {\n        child.addPropertyOverride('AuthorizationType', 'NONE');\n\n        defaults.addCfnSuppressRules(apiMethod, [\n          {\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    });\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"]}
59
+ CloudFrontToApiGatewayToLambda[_a] = { fqn: "@aws-solutions-constructs/aws-cloudfront-apigateway-lambda.CloudFrontToApiGatewayToLambda", version: "2.49.0" };
60
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.ts"],"names":[],"mappings":";;;;;AAmBA,2DAA2D;AAC3D,wFAAwF;AACxF,2CAAuC;AACvC,mGAA6F;AAoE7F,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,mFAAmF;QACnF,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,oBAAoB,EAAE,iBAAiB,EAAE;YACnE,QAAQ,CAAC,YAAY,CAAC;;4IAEgH,CAAC,CAAC;YACxI,MAAM,IAAI,KAAK,CAAC,+FAA+F,CAAC,CAAC;SAClH;aAAM,IAAI,KAAK,CAAC,eAAe,CAAC,oBAAoB,CAAC,iBAAiB,KAAK,SAAS,EAAE;YACrF,MAAM,IAAI,KAAK,CAAC,qGAAqG,CAAC,CAAC;SACxH;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,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;;AA7DH,wEA8DC","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.\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   * 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    // 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      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.47.0",
3
+ "version": "2.49.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",
@@ -53,13 +53,13 @@
53
53
  }
54
54
  },
55
55
  "dependencies": {
56
- "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.47.0",
57
- "@aws-solutions-constructs/core": "2.47.0"
56
+ "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.49.0",
57
+ "@aws-solutions-constructs/core": "2.49.0"
58
58
  },
59
59
  "devDependencies": {
60
60
  "@types/jest": "^27.4.0",
61
61
  "@types/node": "^10.3.0",
62
- "aws-cdk-lib": "2.111.0",
62
+ "aws-cdk-lib": "2.118.0",
63
63
  "constructs": "^10.0.0"
64
64
  },
65
65
  "jest": {
@@ -77,9 +77,9 @@
77
77
  ]
78
78
  },
79
79
  "peerDependencies": {
80
- "@aws-solutions-constructs/core": "2.47.0",
81
- "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.47.0",
82
- "aws-cdk-lib": "^2.111.0",
80
+ "@aws-solutions-constructs/core": "2.49.0",
81
+ "@aws-solutions-constructs/aws-cloudfront-apigateway": "2.49.0",
82
+ "aws-cdk-lib": "^2.118.0",
83
83
  "constructs": "^10.0.0"
84
84
  },
85
85
  "keywords": [
@@ -1,6 +1,178 @@
1
1
  {
2
2
  "Description": "Integration Test for aws-cloudfront-apigateway-lambda custom Cloudfront Logging Bucket",
3
3
  "Resources": {
4
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunctionServiceRole00AAA44C": {
5
+ "Type": "AWS::IAM::Role",
6
+ "Properties": {
7
+ "AssumeRolePolicyDocument": {
8
+ "Statement": [
9
+ {
10
+ "Action": "sts:AssumeRole",
11
+ "Effect": "Allow",
12
+ "Principal": {
13
+ "Service": "lambda.amazonaws.com"
14
+ }
15
+ }
16
+ ],
17
+ "Version": "2012-10-17"
18
+ },
19
+ "ManagedPolicyArns": [
20
+ {
21
+ "Fn::Join": [
22
+ "",
23
+ [
24
+ "arn:",
25
+ {
26
+ "Ref": "AWS::Partition"
27
+ },
28
+ ":iam::aws:policy/service-role/AWSLambdaBasicExecutionRole"
29
+ ]
30
+ ]
31
+ }
32
+ ]
33
+ }
34
+ },
35
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunction86ECA8C3": {
36
+ "Type": "AWS::Lambda::Function",
37
+ "Properties": {
38
+ "Code": {
39
+ "S3Bucket": {
40
+ "Fn::Sub": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}"
41
+ },
42
+ "S3Key": "42a35bbf0dec9ef0ac5b0dde87e71a1b8929e8d2d178dd09ccfb2c928ec0198c.zip"
43
+ },
44
+ "Handler": ".handler",
45
+ "Role": {
46
+ "Fn::GetAtt": [
47
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunctionServiceRole00AAA44C",
48
+ "Arn"
49
+ ]
50
+ },
51
+ "Runtime": "nodejs16.x"
52
+ },
53
+ "DependsOn": [
54
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunctionServiceRole00AAA44C"
55
+ ],
56
+ "Metadata": {
57
+ "cfn_nag": {
58
+ "rules_to_suppress": [
59
+ {
60
+ "id": "W58",
61
+ "reason": "Test Resource"
62
+ },
63
+ {
64
+ "id": "W89",
65
+ "reason": "Test Resource"
66
+ },
67
+ {
68
+ "id": "W92",
69
+ "reason": "Test Resource"
70
+ }
71
+ ]
72
+ }
73
+ }
74
+ },
75
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunctioncftaplamcustomCloudfrontLoggingBucketcftaplamcustomCloudfrontLoggingBucketauthorizer02C97B0FPermissionsBF8A1A3B": {
76
+ "Type": "AWS::Lambda::Permission",
77
+ "Properties": {
78
+ "Action": "lambda:InvokeFunction",
79
+ "FunctionName": {
80
+ "Fn::GetAtt": [
81
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunction86ECA8C3",
82
+ "Arn"
83
+ ]
84
+ },
85
+ "Principal": "apigateway.amazonaws.com",
86
+ "SourceArn": {
87
+ "Fn::Join": [
88
+ "",
89
+ [
90
+ "arn:",
91
+ {
92
+ "Ref": "AWS::Partition"
93
+ },
94
+ ":execute-api:",
95
+ {
96
+ "Ref": "AWS::Region"
97
+ },
98
+ ":",
99
+ {
100
+ "Ref": "AWS::AccountId"
101
+ },
102
+ ":",
103
+ {
104
+ "Ref": "cfapigwlambdaLambdaRestApi775C255B"
105
+ },
106
+ "/authorizers/",
107
+ {
108
+ "Ref": "cftaplamcustomCloudfrontLoggingBucketauthorizer4D180075"
109
+ }
110
+ ]
111
+ ]
112
+ }
113
+ }
114
+ },
115
+ "cftaplamcustomCloudfrontLoggingBucketauthorizer4D180075": {
116
+ "Type": "AWS::ApiGateway::Authorizer",
117
+ "Properties": {
118
+ "AuthorizerResultTtlInSeconds": 300,
119
+ "AuthorizerUri": {
120
+ "Fn::Join": [
121
+ "",
122
+ [
123
+ "arn:",
124
+ {
125
+ "Fn::Select": [
126
+ 1,
127
+ {
128
+ "Fn::Split": [
129
+ ":",
130
+ {
131
+ "Fn::GetAtt": [
132
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunction86ECA8C3",
133
+ "Arn"
134
+ ]
135
+ }
136
+ ]
137
+ }
138
+ ]
139
+ },
140
+ ":apigateway:",
141
+ {
142
+ "Fn::Select": [
143
+ 3,
144
+ {
145
+ "Fn::Split": [
146
+ ":",
147
+ {
148
+ "Fn::GetAtt": [
149
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunction86ECA8C3",
150
+ "Arn"
151
+ ]
152
+ }
153
+ ]
154
+ }
155
+ ]
156
+ },
157
+ ":lambda:path/2015-03-31/functions/",
158
+ {
159
+ "Fn::GetAtt": [
160
+ "cftaplamcustomCloudfrontLoggingBucketauthorizerAuthFunction86ECA8C3",
161
+ "Arn"
162
+ ]
163
+ },
164
+ "/invocations"
165
+ ]
166
+ ]
167
+ },
168
+ "IdentitySource": "method.request.header.Authorization",
169
+ "Name": "cftaplamcustomCloudfrontLoggingBucketcftaplamcustomCloudfrontLoggingBucketauthorizer02C97B0F",
170
+ "RestApiId": {
171
+ "Ref": "cfapigwlambdaLambdaRestApi775C255B"
172
+ },
173
+ "Type": "REQUEST"
174
+ }
175
+ },
4
176
  "cfapigwlambdaLambdaFunctionServiceRole9B40D826": {
5
177
  "Type": "AWS::IAM::Role",
6
178
  "Properties": {
@@ -169,7 +341,7 @@
169
341
  "Name": "LambdaRestApi"
170
342
  }
171
343
  },
172
- "cfapigwlambdaLambdaRestApiDeployment33C24C7D5b6eb6dc887b9e8b9bde9a765f4aacbb": {
344
+ "cfapigwlambdaLambdaRestApiDeployment33C24C7D41e6d6ff15b0c6d292b31cce930b3216": {
173
345
  "Type": "AWS::ApiGateway::Deployment",
174
346
  "Properties": {
175
347
  "Description": "Automatically created by the RestApi construct",
@@ -206,7 +378,7 @@
206
378
  "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\"}"
207
379
  },
208
380
  "DeploymentId": {
209
- "Ref": "cfapigwlambdaLambdaRestApiDeployment33C24C7D5b6eb6dc887b9e8b9bde9a765f4aacbb"
381
+ "Ref": "cfapigwlambdaLambdaRestApiDeployment33C24C7D41e6d6ff15b0c6d292b31cce930b3216"
210
382
  },
211
383
  "MethodSettings": [
212
384
  {
@@ -319,7 +491,10 @@
319
491
  "cfapigwlambdaLambdaRestApiproxyANY68181290": {
320
492
  "Type": "AWS::ApiGateway::Method",
321
493
  "Properties": {
322
- "AuthorizationType": "NONE",
494
+ "AuthorizationType": "CUSTOM",
495
+ "AuthorizerId": {
496
+ "Ref": "cftaplamcustomCloudfrontLoggingBucketauthorizer4D180075"
497
+ },
323
498
  "HttpMethod": "ANY",
324
499
  "Integration": {
325
500
  "IntegrationHttpMethod": "POST",
@@ -354,16 +529,6 @@
354
529
  "RestApiId": {
355
530
  "Ref": "cfapigwlambdaLambdaRestApi775C255B"
356
531
  }
357
- },
358
- "Metadata": {
359
- "cfn_nag": {
360
- "rules_to_suppress": [
361
- {
362
- "id": "W59",
363
- "reason": "AWS::ApiGateway::Method AuthorizationType is set to 'NONE' because API Gateway behind CloudFront does not support AWS_IAM authentication"
364
- }
365
- ]
366
- }
367
532
  }
368
533
  },
369
534
  "cfapigwlambdaLambdaRestApiANYApiPermissioncftaplamcustomCloudfrontLoggingBucketcfapigwlambdaLambdaRestApi92F6CCCCANY63987F12": {
@@ -447,7 +612,10 @@
447
612
  "cfapigwlambdaLambdaRestApiANY81C176E9": {
448
613
  "Type": "AWS::ApiGateway::Method",
449
614
  "Properties": {
450
- "AuthorizationType": "NONE",
615
+ "AuthorizationType": "CUSTOM",
616
+ "AuthorizerId": {
617
+ "Ref": "cftaplamcustomCloudfrontLoggingBucketauthorizer4D180075"
618
+ },
451
619
  "HttpMethod": "ANY",
452
620
  "Integration": {
453
621
  "IntegrationHttpMethod": "POST",
@@ -485,16 +653,6 @@
485
653
  "RestApiId": {
486
654
  "Ref": "cfapigwlambdaLambdaRestApi775C255B"
487
655
  }
488
- },
489
- "Metadata": {
490
- "cfn_nag": {
491
- "rules_to_suppress": [
492
- {
493
- "id": "W59",
494
- "reason": "AWS::ApiGateway::Method AuthorizationType is set to 'NONE' because API Gateway behind CloudFront does not support AWS_IAM authentication"
495
- }
496
- ]
497
- }
498
656
  }
499
657
  },
500
658
  "cfapigwlambdaLambdaRestApiUsagePlan11CE9748": {
@@ -598,10 +756,9 @@
598
756
  "Name": "SetHttpSecurityHeadersc860b559e82562b55d86431c32566a0eb839407df7"
599
757
  }
600
758
  },
601
- "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucket2E8E3DC2": {
759
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A": {
602
760
  "Type": "AWS::S3::Bucket",
603
761
  "Properties": {
604
- "AccessControl": "LogDeliveryWrite",
605
762
  "BucketEncryption": {
606
763
  "ServerSideEncryptionConfiguration": [
607
764
  {
@@ -641,12 +798,197 @@
641
798
  "rules_to_suppress": [
642
799
  {
643
800
  "id": "W35",
644
- "reason": "This S3 bucket is used as the access logging bucket for CloudFront Distribution"
801
+ "reason": "This S3 bucket is used as the access logging bucket for another bucket"
645
802
  }
646
803
  ]
647
804
  }
648
805
  }
649
806
  },
807
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicyC05E1C71": {
808
+ "Type": "AWS::S3::BucketPolicy",
809
+ "Properties": {
810
+ "Bucket": {
811
+ "Ref": "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A"
812
+ },
813
+ "PolicyDocument": {
814
+ "Statement": [
815
+ {
816
+ "Action": "s3:*",
817
+ "Condition": {
818
+ "Bool": {
819
+ "aws:SecureTransport": "false"
820
+ }
821
+ },
822
+ "Effect": "Deny",
823
+ "Principal": {
824
+ "AWS": "*"
825
+ },
826
+ "Resource": [
827
+ {
828
+ "Fn::GetAtt": [
829
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A",
830
+ "Arn"
831
+ ]
832
+ },
833
+ {
834
+ "Fn::Join": [
835
+ "",
836
+ [
837
+ {
838
+ "Fn::GetAtt": [
839
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A",
840
+ "Arn"
841
+ ]
842
+ },
843
+ "/*"
844
+ ]
845
+ ]
846
+ }
847
+ ]
848
+ },
849
+ {
850
+ "Action": [
851
+ "s3:PutBucketPolicy",
852
+ "s3:GetBucket*",
853
+ "s3:List*",
854
+ "s3:DeleteObject*"
855
+ ],
856
+ "Effect": "Allow",
857
+ "Principal": {
858
+ "AWS": {
859
+ "Fn::GetAtt": [
860
+ "CustomS3AutoDeleteObjectsCustomResourceProviderRole3B1BD092",
861
+ "Arn"
862
+ ]
863
+ }
864
+ },
865
+ "Resource": [
866
+ {
867
+ "Fn::GetAtt": [
868
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A",
869
+ "Arn"
870
+ ]
871
+ },
872
+ {
873
+ "Fn::Join": [
874
+ "",
875
+ [
876
+ {
877
+ "Fn::GetAtt": [
878
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A",
879
+ "Arn"
880
+ ]
881
+ },
882
+ "/*"
883
+ ]
884
+ ]
885
+ }
886
+ ]
887
+ },
888
+ {
889
+ "Action": "s3:PutObject",
890
+ "Condition": {
891
+ "ArnLike": {
892
+ "aws:SourceArn": {
893
+ "Fn::GetAtt": [
894
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucket2E8E3DC2",
895
+ "Arn"
896
+ ]
897
+ }
898
+ },
899
+ "StringEquals": {
900
+ "aws:SourceAccount": {
901
+ "Ref": "AWS::AccountId"
902
+ }
903
+ }
904
+ },
905
+ "Effect": "Allow",
906
+ "Principal": {
907
+ "Service": "logging.s3.amazonaws.com"
908
+ },
909
+ "Resource": {
910
+ "Fn::Join": [
911
+ "",
912
+ [
913
+ {
914
+ "Fn::GetAtt": [
915
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A",
916
+ "Arn"
917
+ ]
918
+ },
919
+ "/*"
920
+ ]
921
+ ]
922
+ }
923
+ }
924
+ ],
925
+ "Version": "2012-10-17"
926
+ }
927
+ }
928
+ },
929
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogAutoDeleteObjectsCustomResource296BC002": {
930
+ "Type": "Custom::S3AutoDeleteObjects",
931
+ "Properties": {
932
+ "ServiceToken": {
933
+ "Fn::GetAtt": [
934
+ "CustomS3AutoDeleteObjectsCustomResourceProviderHandler9D90184F",
935
+ "Arn"
936
+ ]
937
+ },
938
+ "BucketName": {
939
+ "Ref": "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A"
940
+ }
941
+ },
942
+ "DependsOn": [
943
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLogPolicyC05E1C71"
944
+ ],
945
+ "UpdateReplacePolicy": "Delete",
946
+ "DeletionPolicy": "Delete"
947
+ },
948
+ "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucket2E8E3DC2": {
949
+ "Type": "AWS::S3::Bucket",
950
+ "Properties": {
951
+ "AccessControl": "LogDeliveryWrite",
952
+ "BucketEncryption": {
953
+ "ServerSideEncryptionConfiguration": [
954
+ {
955
+ "ServerSideEncryptionByDefault": {
956
+ "SSEAlgorithm": "AES256"
957
+ }
958
+ }
959
+ ]
960
+ },
961
+ "LoggingConfiguration": {
962
+ "DestinationBucketName": {
963
+ "Ref": "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A"
964
+ }
965
+ },
966
+ "OwnershipControls": {
967
+ "Rules": [
968
+ {
969
+ "ObjectOwnership": "ObjectWriter"
970
+ }
971
+ ]
972
+ },
973
+ "PublicAccessBlockConfiguration": {
974
+ "BlockPublicAcls": true,
975
+ "BlockPublicPolicy": true,
976
+ "IgnorePublicAcls": true,
977
+ "RestrictPublicBuckets": true
978
+ },
979
+ "Tags": [
980
+ {
981
+ "Key": "aws-cdk:auto-delete-objects",
982
+ "Value": "true"
983
+ }
984
+ ],
985
+ "VersioningConfiguration": {
986
+ "Status": "Enabled"
987
+ }
988
+ },
989
+ "UpdateReplacePolicy": "Delete",
990
+ "DeletionPolicy": "Delete"
991
+ },
650
992
  "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketPolicy416A95E3": {
651
993
  "Type": "AWS::S3::BucketPolicy",
652
994
  "Properties": {
@@ -910,7 +1252,7 @@
910
1252
  [
911
1253
  "Lambda function for auto-deleting objects in ",
912
1254
  {
913
- "Ref": "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucket2E8E3DC2"
1255
+ "Ref": "cfapigwlambdaCloudFrontToApiGatewayCloudfrontLoggingBucketAccessLog48BE423A"
914
1256
  },
915
1257
  " S3 bucket."
916
1258
  ]
@@ -18,11 +18,18 @@ const lib_1 = require("../lib");
18
18
  const lambda = require("aws-cdk-lib/aws-lambda");
19
19
  const aws_s3_1 = require("aws-cdk-lib/aws-s3");
20
20
  const core_1 = require("@aws-solutions-constructs/core");
21
+ const apigateway = require("aws-cdk-lib/aws-apigateway");
21
22
  // Setup
22
23
  const app = new aws_cdk_lib_1.App();
23
24
  const stack = new aws_cdk_lib_1.Stack(app, core_1.generateIntegStackName(__filename));
24
25
  stack.templateOptions.description = 'Integration Test for aws-cloudfront-apigateway-lambda custom Cloudfront Logging Bucket';
25
26
  new lib_1.CloudFrontToApiGatewayToLambda(stack, 'cf-apigw-lambda', {
27
+ apiGatewayProps: {
28
+ defaultMethodOptions: {
29
+ authorizationType: apigateway.AuthorizationType.CUSTOM,
30
+ authorizer: core_1.CreateApiAuthorizer(stack, `${core_1.generateIntegStackName(__filename)}-authorizer`)
31
+ },
32
+ },
26
33
  lambdaFunctionProps: {
27
34
  code: lambda.Code.fromAsset(`${__dirname}/lambda`),
28
35
  runtime: lambda.Runtime.NODEJS_16_X,
@@ -38,4 +45,4 @@ new lib_1.CloudFrontToApiGatewayToLambda(stack, 'cf-apigw-lambda', {
38
45
  core_1.suppressAutoDeleteHandlerWarnings(stack);
39
46
  // Synth
40
47
  app.synth();
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2Z0YXBsYW0tY3VzdG9tQ2xvdWRmcm9udExvZ2dpbmdCdWNrZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5jZnRhcGxhbS1jdXN0b21DbG91ZGZyb250TG9nZ2luZ0J1Y2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsZ0JBQWdCO0FBQ2hCLDZDQUF3RDtBQUN4RCxnQ0FBd0Q7QUFDeEQsaURBQWlEO0FBQ2pELCtDQUFzRDtBQUN0RCx5REFBMkc7QUFFM0csUUFBUTtBQUNSLE1BQU0sR0FBRyxHQUFHLElBQUksaUJBQUcsRUFBRSxDQUFDO0FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksbUJBQUssQ0FBQyxHQUFHLEVBQUUsNkJBQXNCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQztBQUNqRSxLQUFLLENBQUMsZUFBZSxDQUFDLFdBQVcsR0FBRyx3RkFBd0YsQ0FBQztBQUU3SCxJQUFJLG9DQUE4QixDQUFDLEtBQUssRUFBRSxpQkFBaUIsRUFBRTtJQUMzRCxtQkFBbUIsRUFBRTtRQUNuQixJQUFJLEVBQUUsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxTQUFTLFNBQVMsQ0FBQztRQUNsRCxPQUFPLEVBQUUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxXQUFXO1FBQ25DLE9BQU8sRUFBRSxlQUFlO0tBQ3pCO0lBQ0QsNEJBQTRCLEVBQUU7UUFDNUIsYUFBYSxFQUFFLDJCQUFhLENBQUMsT0FBTztRQUNwQyxpQkFBaUIsRUFBRSxJQUFJO1FBQ3ZCLFVBQVUsRUFBRSx5QkFBZ0IsQ0FBQyxVQUFVO1FBQ3ZDLFNBQVMsRUFBRSxJQUFJO0tBQ2hCO0NBQ0YsQ0FBQyxDQUFDO0FBQ0gsd0NBQWlDLENBQUMsS0FBSyxDQUFDLENBQUM7QUFFekMsUUFBUTtBQUNSLEdBQUcsQ0FBQyxLQUFLLEVBQUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuICpcbiAqICBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlXCIpLiBZb3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4gKiAgd2l0aCB0aGUgTGljZW5zZS4gQSBjb3B5IG9mIHRoZSBMaWNlbnNlIGlzIGxvY2F0ZWQgYXRcbiAqXG4gKiAgICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqICBvciBpbiB0aGUgJ2xpY2Vuc2UnIGZpbGUgYWNjb21wYW55aW5nIHRoaXMgZmlsZS4gVGhpcyBmaWxlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuICdBUyBJUycgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFU1xuICogIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGV4cHJlc3Mgb3IgaW1wbGllZC4gU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zXG4gKiAgYW5kIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG5cbi8vLyAhY2RrLWludGVnICpcbmltcG9ydCB7IEFwcCwgU3RhY2ssIFJlbW92YWxQb2xpY3kgfSBmcm9tIFwiYXdzLWNkay1saWJcIjtcbmltcG9ydCB7IENsb3VkRnJvbnRUb0FwaUdhdGV3YXlUb0xhbWJkYSB9IGZyb20gXCIuLi9saWJcIjtcbmltcG9ydCAqIGFzIGxhbWJkYSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcbmltcG9ydCB7IEJ1Y2tldEVuY3J5cHRpb24gfSBmcm9tIFwiYXdzLWNkay1saWIvYXdzLXMzXCI7XG5pbXBvcnQgeyBnZW5lcmF0ZUludGVnU3RhY2tOYW1lLCBzdXBwcmVzc0F1dG9EZWxldGVIYW5kbGVyV2FybmluZ3MgfSBmcm9tICdAYXdzLXNvbHV0aW9ucy1jb25zdHJ1Y3RzL2NvcmUnO1xuXG4vLyBTZXR1cFxuY29uc3QgYXBwID0gbmV3IEFwcCgpO1xuY29uc3Qgc3RhY2sgPSBuZXcgU3RhY2soYXBwLCBnZW5lcmF0ZUludGVnU3RhY2tOYW1lKF9fZmlsZW5hbWUpKTtcbnN0YWNrLnRlbXBsYXRlT3B0aW9ucy5kZXNjcmlwdGlvbiA9ICdJbnRlZ3JhdGlvbiBUZXN0IGZvciBhd3MtY2xvdWRmcm9udC1hcGlnYXRld2F5LWxhbWJkYSBjdXN0b20gQ2xvdWRmcm9udCBMb2dnaW5nIEJ1Y2tldCc7XG5cbm5ldyBDbG91ZEZyb250VG9BcGlHYXRld2F5VG9MYW1iZGEoc3RhY2ssICdjZi1hcGlndy1sYW1iZGEnLCB7XG4gIGxhbWJkYUZ1bmN0aW9uUHJvcHM6IHtcbiAgICBjb2RlOiBsYW1iZGEuQ29kZS5mcm9tQXNzZXQoYCR7X19kaXJuYW1lfS9sYW1iZGFgKSxcbiAgICBydW50aW1lOiBsYW1iZGEuUnVudGltZS5OT0RFSlNfMTZfWCxcbiAgICBoYW5kbGVyOiAnaW5kZXguaGFuZGxlcidcbiAgfSxcbiAgY2xvdWRGcm9udExvZ2dpbmdCdWNrZXRQcm9wczoge1xuICAgIHJlbW92YWxQb2xpY3k6IFJlbW92YWxQb2xpY3kuREVTVFJPWSxcbiAgICBhdXRvRGVsZXRlT2JqZWN0czogdHJ1ZSxcbiAgICBlbmNyeXB0aW9uOiBCdWNrZXRFbmNyeXB0aW9uLlMzX01BTkFHRUQsXG4gICAgdmVyc2lvbmVkOiB0cnVlXG4gIH1cbn0pO1xuc3VwcHJlc3NBdXRvRGVsZXRlSGFuZGxlcldhcm5pbmdzKHN0YWNrKTtcblxuLy8gU3ludGhcbmFwcC5zeW50aCgpO1xuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2Z0YXBsYW0tY3VzdG9tQ2xvdWRmcm9udExvZ2dpbmdCdWNrZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5jZnRhcGxhbS1jdXN0b21DbG91ZGZyb250TG9nZ2luZ0J1Y2tldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7Ozs7Ozs7Ozs7O0dBV0c7O0FBRUgsZ0JBQWdCO0FBQ2hCLDZDQUF3RDtBQUN4RCxnQ0FBd0Q7QUFDeEQsaURBQWlEO0FBQ2pELCtDQUFzRDtBQUN0RCx5REFBZ0k7QUFDaEkseURBQXlEO0FBRXpELFFBQVE7QUFDUixNQUFNLEdBQUcsR0FBRyxJQUFJLGlCQUFHLEVBQUUsQ0FBQztBQUN0QixNQUFNLEtBQUssR0FBRyxJQUFJLG1CQUFLLENBQUMsR0FBRyxFQUFFLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7QUFDakUsS0FBSyxDQUFDLGVBQWUsQ0FBQyxXQUFXLEdBQUcsd0ZBQXdGLENBQUM7QUFFN0gsSUFBSSxvQ0FBOEIsQ0FBQyxLQUFLLEVBQUUsaUJBQWlCLEVBQUU7SUFDM0QsZUFBZSxFQUFFO1FBQ2Ysb0JBQW9CLEVBQUU7WUFDcEIsaUJBQWlCLEVBQUUsVUFBVSxDQUFDLGlCQUFpQixDQUFDLE1BQU07WUFDdEQsVUFBVSxFQUFFLDBCQUFtQixDQUFDLEtBQUssRUFBRSxHQUFHLDZCQUFzQixDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUM7U0FDM0Y7S0FDRjtJQUNELG1CQUFtQixFQUFFO1FBQ25CLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLFNBQVMsU0FBUyxDQUFDO1FBQ2xELE9BQU8sRUFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVc7UUFDbkMsT0FBTyxFQUFFLGVBQWU7S0FDekI7SUFDRCw0QkFBNEIsRUFBRTtRQUM1QixhQUFhLEVBQUUsMkJBQWEsQ0FBQyxPQUFPO1FBQ3BDLGlCQUFpQixFQUFFLElBQUk7UUFDdkIsVUFBVSxFQUFFLHlCQUFnQixDQUFDLFVBQVU7UUFDdkMsU0FBUyxFQUFFLElBQUk7S0FDaEI7Q0FDRixDQUFDLENBQUM7QUFDSCx3Q0FBaUMsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUV6QyxRQUFRO0FBQ1IsR0FBRyxDQUFDLEtBQUssRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiAgQ29weXJpZ2h0IEFtYXpvbi5jb20sIEluYy4gb3IgaXRzIGFmZmlsaWF0ZXMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2VcIikuIFlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2VcbiAqICB3aXRoIHRoZSBMaWNlbnNlLiBBIGNvcHkgb2YgdGhlIExpY2Vuc2UgaXMgbG9jYXRlZCBhdFxuICpcbiAqICAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogIG9yIGluIHRoZSAnbGljZW5zZScgZmlsZSBhY2NvbXBhbnlpbmcgdGhpcyBmaWxlLiBUaGlzIGZpbGUgaXMgZGlzdHJpYnV0ZWQgb24gYW4gJ0FTIElTJyBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTXG4gKiAgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZXhwcmVzcyBvciBpbXBsaWVkLiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnNcbiAqICBhbmQgbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cblxuLy8vICFjZGstaW50ZWcgKlxuaW1wb3J0IHsgQXBwLCBTdGFjaywgUmVtb3ZhbFBvbGljeSB9IGZyb20gXCJhd3MtY2RrLWxpYlwiO1xuaW1wb3J0IHsgQ2xvdWRGcm9udFRvQXBpR2F0ZXdheVRvTGFtYmRhIH0gZnJvbSBcIi4uL2xpYlwiO1xuaW1wb3J0ICogYXMgbGFtYmRhIGZyb20gJ2F3cy1jZGstbGliL2F3cy1sYW1iZGEnO1xuaW1wb3J0IHsgQnVja2V0RW5jcnlwdGlvbiB9IGZyb20gXCJhd3MtY2RrLWxpYi9hd3MtczNcIjtcbmltcG9ydCB7IGdlbmVyYXRlSW50ZWdTdGFja05hbWUsIHN1cHByZXNzQXV0b0RlbGV0ZUhhbmRsZXJXYXJuaW5ncywgQ3JlYXRlQXBpQXV0aG9yaXplciB9IGZyb20gJ0Bhd3Mtc29sdXRpb25zLWNvbnN0cnVjdHMvY29yZSc7XG5pbXBvcnQgKiBhcyBhcGlnYXRld2F5IGZyb20gJ2F3cy1jZGstbGliL2F3cy1hcGlnYXRld2F5JztcblxuLy8gU2V0dXBcbmNvbnN0IGFwcCA9IG5ldyBBcHAoKTtcbmNvbnN0IHN0YWNrID0gbmV3IFN0YWNrKGFwcCwgZ2VuZXJhdGVJbnRlZ1N0YWNrTmFtZShfX2ZpbGVuYW1lKSk7XG5zdGFjay50ZW1wbGF0ZU9wdGlvbnMuZGVzY3JpcHRpb24gPSAnSW50ZWdyYXRpb24gVGVzdCBmb3IgYXdzLWNsb3VkZnJvbnQtYXBpZ2F0ZXdheS1sYW1iZGEgY3VzdG9tIENsb3VkZnJvbnQgTG9nZ2luZyBCdWNrZXQnO1xuXG5uZXcgQ2xvdWRGcm9udFRvQXBpR2F0ZXdheVRvTGFtYmRhKHN0YWNrLCAnY2YtYXBpZ3ctbGFtYmRhJywge1xuICBhcGlHYXRld2F5UHJvcHM6IHtcbiAgICBkZWZhdWx0TWV0aG9kT3B0aW9uczoge1xuICAgICAgYXV0aG9yaXphdGlvblR5cGU6IGFwaWdhdGV3YXkuQXV0aG9yaXphdGlvblR5cGUuQ1VTVE9NLFxuICAgICAgYXV0aG9yaXplcjogQ3JlYXRlQXBpQXV0aG9yaXplcihzdGFjaywgYCR7Z2VuZXJhdGVJbnRlZ1N0YWNrTmFtZShfX2ZpbGVuYW1lKX0tYXV0aG9yaXplcmApXG4gICAgfSxcbiAgfSxcbiAgbGFtYmRhRnVuY3Rpb25Qcm9wczoge1xuICAgIGNvZGU6IGxhbWJkYS5Db2RlLmZyb21Bc3NldChgJHtfX2Rpcm5hbWV9L2xhbWJkYWApLFxuICAgIHJ1bnRpbWU6IGxhbWJkYS5SdW50aW1lLk5PREVKU18xNl9YLFxuICAgIGhhbmRsZXI6ICdpbmRleC5oYW5kbGVyJ1xuICB9LFxuICBjbG91ZEZyb250TG9nZ2luZ0J1Y2tldFByb3BzOiB7XG4gICAgcmVtb3ZhbFBvbGljeTogUmVtb3ZhbFBvbGljeS5ERVNUUk9ZLFxuICAgIGF1dG9EZWxldGVPYmplY3RzOiB0cnVlLFxuICAgIGVuY3J5cHRpb246IEJ1Y2tldEVuY3J5cHRpb24uUzNfTUFOQUdFRCxcbiAgICB2ZXJzaW9uZWQ6IHRydWVcbiAgfVxufSk7XG5zdXBwcmVzc0F1dG9EZWxldGVIYW5kbGVyV2FybmluZ3Moc3RhY2spO1xuXG4vLyBTeW50aFxuYXBwLnN5bnRoKCk7XG4iXX0=