UNPKG

@aws-solutions-constructs/core

Version:
99 lines 15.2 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 }); exports.DefaultCloudFrontWebDistributionForApiGatewayProps = DefaultCloudFrontWebDistributionForApiGatewayProps; exports.DefaultCloudFrontWebDistributionForS3Props = DefaultCloudFrontWebDistributionForS3Props; exports.DefaultCloudFrontDistributionForMediaStoreProps = DefaultCloudFrontDistributionForMediaStoreProps; const cloudfront = require("aws-cdk-lib/aws-cloudfront"); const aws_cloudfront_1 = require("aws-cdk-lib/aws-cloudfront"); const origins = require("aws-cdk-lib/aws-cloudfront-origins"); const cdk = require("aws-cdk-lib"); /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function DefaultCloudFrontWebDistributionForApiGatewayProps(apiEndPoint, loggingBucket, setHttpSecurityHeaders, cfFunction, responseHeadersPolicy) { const apiEndPointUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split("://", apiEndPoint.url)); const apiEndPointDomainName = cdk.Fn.select(0, cdk.Fn.split("/", apiEndPointUrlWithoutProtocol)); let defaultBehavior = { origin: new origins.HttpOrigin(apiEndPointDomainName, { originPath: `/${apiEndPoint.deploymentStage.stageName}` }), ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction), viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS, }; if (responseHeadersPolicy) { defaultBehavior = { ...defaultBehavior, responseHeadersPolicy }; } return { defaultBehavior, enableLogging: true, logBucket: loggingBucket, }; } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function DefaultCloudFrontWebDistributionForS3Props(origin, loggingBucket, setHttpSecurityHeaders, cfFunction, responseHeadersPolicy) { let defaultBehavior = { origin, viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS, ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction) }; if (responseHeadersPolicy) { defaultBehavior = { ...defaultBehavior, responseHeadersPolicy }; } return { defaultBehavior, enableLogging: true, logBucket: loggingBucket, defaultRootObject: 'index.html' }; } /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. */ function DefaultCloudFrontDistributionForMediaStoreProps(mediastoreContainer, loggingBucket, originRequestPolicy, setHttpSecurityHeaders, customHeaders, cfFunction, responseHeadersPolicy) { const mediaStoreContainerUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split('://', mediastoreContainer.attrEndpoint)); const mediaStoreContainerDomainName = cdk.Fn.select(0, cdk.Fn.split('/', mediaStoreContainerUrlWithoutProtocol)); const httpOrigin = customHeaders ? new origins.HttpOrigin(mediaStoreContainerDomainName, { customHeaders }) : new origins.HttpOrigin(mediaStoreContainerDomainName); let defaultBehavior = { origin: httpOrigin, viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS, allowedMethods: cloudfront.AllowedMethods.ALLOW_GET_HEAD_OPTIONS, cachedMethods: cloudfront.CachedMethods.CACHE_GET_HEAD_OPTIONS, originRequestPolicy, ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction), }; if (responseHeadersPolicy) { defaultBehavior = { ...defaultBehavior, responseHeadersPolicy }; } return { defaultBehavior, enableLogging: true, logBucket: loggingBucket }; } function getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction) { return (setHttpSecurityHeaders && cfFunction) ? { functionAssociations: [ { eventType: aws_cloudfront_1.FunctionEventType.VIEWER_RESPONSE, function: cfFunction } ] } : {}; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cloudfront-distribution-defaults.js","sourceRoot":"","sources":["cloudfront-distribution-defaults.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/*\n *  The functions found here in the core library are for internal use and can be changed\n *  or removed outside of a major release. We recommend against calling them directly from client code.\n */\n\nimport * as api from 'aws-cdk-lib/aws-apigateway';\nimport * as cloudfront from 'aws-cdk-lib/aws-cloudfront';\nimport { FunctionEventType, IOrigin } from 'aws-cdk-lib/aws-cloudfront';\nimport * as origins from 'aws-cdk-lib/aws-cloudfront-origins';\nimport * as mediastore from 'aws-cdk-lib/aws-mediastore';\nimport * as s3 from 'aws-cdk-lib/aws-s3';\nimport * as cdk from 'aws-cdk-lib';\nimport {BehaviorOptions} from \"aws-cdk-lib/aws-cloudfront/lib/distribution\";\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function DefaultCloudFrontWebDistributionForApiGatewayProps(apiEndPoint: api.RestApi,\n  loggingBucket: s3.Bucket | undefined,\n  setHttpSecurityHeaders: boolean,\n  cfFunction?: cloudfront.IFunction,\n  responseHeadersPolicy?: cloudfront.ResponseHeadersPolicy,\n): cloudfront.DistributionProps {\n\n  const apiEndPointUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split(\"://\", apiEndPoint.url));\n  const apiEndPointDomainName = cdk.Fn.select(0, cdk.Fn.split(\"/\", apiEndPointUrlWithoutProtocol));\n\n  let defaultBehavior: BehaviorOptions = {\n    origin: new origins.HttpOrigin(apiEndPointDomainName, {\n      originPath: `/${apiEndPoint.deploymentStage.stageName}`\n    }),\n    ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction),\n    viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n  };\n  if (responseHeadersPolicy) {\n    defaultBehavior = {...defaultBehavior, responseHeadersPolicy };\n  }\n  return {\n    defaultBehavior,\n    enableLogging: true,\n    logBucket: loggingBucket,\n  };\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function DefaultCloudFrontWebDistributionForS3Props(\n  origin: IOrigin,\n  loggingBucket: s3.Bucket | undefined,\n  setHttpSecurityHeaders: boolean,\n  cfFunction?: cloudfront.IFunction,\n  responseHeadersPolicy?: cloudfront.ResponseHeadersPolicy,\n): cloudfront.DistributionProps {\n\n  let defaultBehavior: BehaviorOptions = {\n    origin,\n    viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction)\n  };\n\n  if (responseHeadersPolicy) {\n    defaultBehavior = {...defaultBehavior, responseHeadersPolicy };\n  }\n  return {\n    defaultBehavior,\n    enableLogging: true,\n    logBucket: loggingBucket,\n    defaultRootObject: 'index.html'\n  };\n}\n\n/**\n * @internal This is an internal core function and should not be called directly by Solutions Constructs clients.\n */\nexport function DefaultCloudFrontDistributionForMediaStoreProps(mediastoreContainer: mediastore.CfnContainer,\n  loggingBucket: s3.Bucket | undefined,\n  originRequestPolicy: cloudfront.OriginRequestPolicy,\n  setHttpSecurityHeaders: boolean,\n  customHeaders?: Record<string, string>,\n  cfFunction?: cloudfront.IFunction,\n  responseHeadersPolicy?: cloudfront.ResponseHeadersPolicy\n): cloudfront.DistributionProps {\n\n  const mediaStoreContainerUrlWithoutProtocol = cdk.Fn.select(1, cdk.Fn.split('://', mediastoreContainer.attrEndpoint));\n  const mediaStoreContainerDomainName = cdk.Fn.select(0, cdk.Fn.split('/', mediaStoreContainerUrlWithoutProtocol));\n\n  const httpOrigin: origins.HttpOrigin = customHeaders ?\n    new origins.HttpOrigin(mediaStoreContainerDomainName, { customHeaders }) :\n    new origins.HttpOrigin(mediaStoreContainerDomainName);\n\n  let defaultBehavior: BehaviorOptions = {\n    origin: httpOrigin,\n    viewerProtocolPolicy: cloudfront.ViewerProtocolPolicy.REDIRECT_TO_HTTPS,\n    allowedMethods: cloudfront.AllowedMethods.ALLOW_GET_HEAD_OPTIONS,\n    cachedMethods: cloudfront.CachedMethods.CACHE_GET_HEAD_OPTIONS,\n    originRequestPolicy,\n    ...getFunctionAssociationsProp(setHttpSecurityHeaders, cfFunction),\n  };\n  if (responseHeadersPolicy) {\n    defaultBehavior = {...defaultBehavior, responseHeadersPolicy };\n  }\n  return {\n    defaultBehavior,\n    enableLogging: true,\n    logBucket: loggingBucket\n  };\n}\n\nfunction getFunctionAssociationsProp(setHttpSecurityHeaders: boolean, cfFunction: cloudfront.IFunction | undefined) {\n  return (setHttpSecurityHeaders && cfFunction) ? {\n    functionAssociations: [\n      {\n        eventType: FunctionEventType.VIEWER_RESPONSE,\n        function: cfFunction\n      }\n    ]\n  } : {};\n}\n"]}