UNPKG

@aws-cdk/aws-cloudfront

Version:

The CDK Construct Library for AWS::CloudFront

519 lines 97.5 kB
"use strict"; var _a, _b; Object.defineProperty(exports, "__esModule", { value: true }); exports.CloudFrontWebDistribution = exports.ViewerCertificate = exports.CloudFrontAllowedCachedMethods = exports.CloudFrontAllowedMethods = exports.OriginSslPolicy = exports.FailoverStatusCode = void 0; const jsiiDeprecationWarnings = require("../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const certificatemanager = require("@aws-cdk/aws-certificatemanager"); const iam = require("@aws-cdk/aws-iam"); const s3 = require("@aws-cdk/aws-s3"); const cdk = require("@aws-cdk/core"); const cloudfront_generated_1 = require("./cloudfront.generated"); const distribution_1 = require("./distribution"); /** * HTTP status code to failover to second origin */ var FailoverStatusCode; (function (FailoverStatusCode) { /** * Forbidden (403) */ FailoverStatusCode[FailoverStatusCode["FORBIDDEN"] = 403] = "FORBIDDEN"; /** * Not found (404) */ FailoverStatusCode[FailoverStatusCode["NOT_FOUND"] = 404] = "NOT_FOUND"; /** * Internal Server Error (500) */ FailoverStatusCode[FailoverStatusCode["INTERNAL_SERVER_ERROR"] = 500] = "INTERNAL_SERVER_ERROR"; /** * Bad Gateway (502) */ FailoverStatusCode[FailoverStatusCode["BAD_GATEWAY"] = 502] = "BAD_GATEWAY"; /** * Service Unavailable (503) */ FailoverStatusCode[FailoverStatusCode["SERVICE_UNAVAILABLE"] = 503] = "SERVICE_UNAVAILABLE"; /** * Gateway Timeout (504) */ FailoverStatusCode[FailoverStatusCode["GATEWAY_TIMEOUT"] = 504] = "GATEWAY_TIMEOUT"; })(FailoverStatusCode = exports.FailoverStatusCode || (exports.FailoverStatusCode = {})); var OriginSslPolicy; (function (OriginSslPolicy) { OriginSslPolicy["SSL_V3"] = "SSLv3"; OriginSslPolicy["TLS_V1"] = "TLSv1"; OriginSslPolicy["TLS_V1_1"] = "TLSv1.1"; OriginSslPolicy["TLS_V1_2"] = "TLSv1.2"; })(OriginSslPolicy = exports.OriginSslPolicy || (exports.OriginSslPolicy = {})); /** * An enum for the supported methods to a CloudFront distribution. */ var CloudFrontAllowedMethods; (function (CloudFrontAllowedMethods) { CloudFrontAllowedMethods["GET_HEAD"] = "GH"; CloudFrontAllowedMethods["GET_HEAD_OPTIONS"] = "GHO"; CloudFrontAllowedMethods["ALL"] = "ALL"; })(CloudFrontAllowedMethods = exports.CloudFrontAllowedMethods || (exports.CloudFrontAllowedMethods = {})); /** * Enums for the methods CloudFront can cache. */ var CloudFrontAllowedCachedMethods; (function (CloudFrontAllowedCachedMethods) { CloudFrontAllowedCachedMethods["GET_HEAD"] = "GH"; CloudFrontAllowedCachedMethods["GET_HEAD_OPTIONS"] = "GHO"; })(CloudFrontAllowedCachedMethods = exports.CloudFrontAllowedCachedMethods || (exports.CloudFrontAllowedCachedMethods = {})); /** * Viewer certificate configuration class */ class ViewerCertificate { constructor(props, aliases = []) { this.props = props; this.aliases = aliases; } /** * Generate an AWS Certificate Manager (ACM) viewer certificate configuration * * @param certificate AWS Certificate Manager (ACM) certificate. * Your certificate must be located in the us-east-1 (US East (N. Virginia)) region to be accessed by CloudFront * @param options certificate configuration options */ static fromAcmCertificate(certificate, options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_ViewerCertificateOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromAcmCertificate); } throw error; } const { sslMethod: sslSupportMethod = distribution_1.SSLMethod.SNI, securityPolicy: minimumProtocolVersion, aliases, } = options; return new ViewerCertificate({ acmCertificateArn: certificate.certificateArn, sslSupportMethod, minimumProtocolVersion, }, aliases); } /** * Generate an IAM viewer certificate configuration * * @param iamCertificateId Identifier of the IAM certificate * @param options certificate configuration options */ static fromIamCertificate(iamCertificateId, options = {}) { try { jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_ViewerCertificateOptions(options); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromIamCertificate); } throw error; } const { sslMethod: sslSupportMethod = distribution_1.SSLMethod.SNI, securityPolicy: minimumProtocolVersion, aliases, } = options; return new ViewerCertificate({ iamCertificateId, sslSupportMethod, minimumProtocolVersion, }, aliases); } /** * Generate a viewer certifcate configuration using * the CloudFront default certificate (e.g. d111111abcdef8.cloudfront.net) * and a {@link SecurityPolicyProtocol.TLS_V1} security policy. * * @param aliases Alternative CNAME aliases * You also must create a CNAME record with your DNS service to route queries */ static fromCloudFrontDefaultCertificate(...aliases) { return new ViewerCertificate({ cloudFrontDefaultCertificate: true }, aliases); } } exports.ViewerCertificate = ViewerCertificate; _a = JSII_RTTI_SYMBOL_1; ViewerCertificate[_a] = { fqn: "@aws-cdk/aws-cloudfront.ViewerCertificate", version: "1.204.0" }; /** * Amazon CloudFront is a global content delivery network (CDN) service that securely delivers data, videos, * applications, and APIs to your viewers with low latency and high transfer speeds. * CloudFront fronts user provided content and caches it at edge locations across the world. * * Here's how you can use this construct: * * ```ts * const sourceBucket = new s3.Bucket(this, 'Bucket'); * * const distribution = new cloudfront.CloudFrontWebDistribution(this, 'MyDistribution', { * originConfigs: [ * { * s3OriginSource: { * s3BucketSource: sourceBucket, * }, * behaviors : [ {isDefaultBehavior: true}], * }, * ], * }); * ``` * * This will create a CloudFront distribution that uses your S3Bucket as it's origin. * * You can customize the distribution using additional properties from the CloudFrontWebDistributionProps interface. * * @resource AWS::CloudFront::Distribution */ class CloudFrontWebDistribution extends cdk.Resource { constructor(scope, id, props) { super(scope, id); /** * Maps our methods to the string arrays they are */ this.METHOD_LOOKUP_MAP = { GH: ['GET', 'HEAD'], GHO: ['GET', 'HEAD', 'OPTIONS'], ALL: ['DELETE', 'GET', 'HEAD', 'OPTIONS', 'PATCH', 'POST', 'PUT'], }; /** * Maps for which SecurityPolicyProtocol are available to which SSLMethods */ this.VALID_SSL_PROTOCOLS = { [distribution_1.SSLMethod.SNI]: [ distribution_1.SecurityPolicyProtocol.TLS_V1, distribution_1.SecurityPolicyProtocol.TLS_V1_1_2016, distribution_1.SecurityPolicyProtocol.TLS_V1_2016, distribution_1.SecurityPolicyProtocol.TLS_V1_2_2018, distribution_1.SecurityPolicyProtocol.TLS_V1_2_2019, distribution_1.SecurityPolicyProtocol.TLS_V1_2_2021, ], [distribution_1.SSLMethod.VIP]: [distribution_1.SecurityPolicyProtocol.SSL_V3, distribution_1.SecurityPolicyProtocol.TLS_V1], }; try { jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_CloudFrontWebDistributionProps(props); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, CloudFrontWebDistribution); } throw error; } // Comments have an undocumented limit of 128 characters const trimmedComment = props.comment && props.comment.length > 128 ? `${props.comment.slice(0, 128 - 3)}...` : props.comment; const behaviors = []; const origins = []; const originGroups = []; let originIndex = 1; for (const originConfig of props.originConfigs) { let originId = `origin${originIndex}`; const originProperty = this.toOriginProperty(originConfig, originId); if (originConfig.failoverCustomOriginSource || originConfig.failoverS3OriginSource) { const originSecondaryId = `originSecondary${originIndex}`; const originSecondaryProperty = this.toOriginProperty({ s3OriginSource: originConfig.failoverS3OriginSource, customOriginSource: originConfig.failoverCustomOriginSource, originPath: originConfig.originPath, originHeaders: originConfig.originHeaders, originShieldRegion: originConfig.originShieldRegion, }, originSecondaryId); const originGroupsId = `OriginGroup${originIndex}`; const failoverCodes = originConfig.failoverCriteriaStatusCodes ?? [500, 502, 503, 504]; originGroups.push({ id: originGroupsId, members: { items: [{ originId }, { originId: originSecondaryId }], quantity: 2, }, failoverCriteria: { statusCodes: { items: failoverCodes, quantity: failoverCodes.length, }, }, }); originId = originGroupsId; origins.push(originSecondaryProperty); } for (const behavior of originConfig.behaviors) { behaviors.push({ ...behavior, targetOriginId: originId }); } origins.push(originProperty); originIndex++; } origins.forEach(origin => { if (!origin.s3OriginConfig && !origin.customOriginConfig) { throw new Error(`Origin ${origin.domainName} is missing either S3OriginConfig or CustomOriginConfig. At least 1 must be specified.`); } }); const originGroupsDistConfig = originGroups.length > 0 ? { items: originGroups, quantity: originGroups.length, } : undefined; const defaultBehaviors = behaviors.filter(behavior => behavior.isDefaultBehavior); if (defaultBehaviors.length !== 1) { throw new Error('There can only be one default behavior across all sources. [ One default behavior per distribution ].'); } const otherBehaviors = []; for (const behavior of behaviors.filter(b => !b.isDefaultBehavior)) { if (!behavior.pathPattern) { throw new Error('pathPattern is required for all non-default behaviors'); } otherBehaviors.push(this.toBehavior(behavior, props.viewerProtocolPolicy)); } let distributionConfig = { comment: trimmedComment, enabled: props.enabled ?? true, defaultRootObject: props.defaultRootObject ?? 'index.html', httpVersion: props.httpVersion || distribution_1.HttpVersion.HTTP2, priceClass: props.priceClass || distribution_1.PriceClass.PRICE_CLASS_100, ipv6Enabled: props.enableIpV6 ?? true, // eslint-disable-next-line max-len customErrorResponses: props.errorConfigurations, webAclId: props.webACLId, origins, originGroups: originGroupsDistConfig, defaultCacheBehavior: this.toBehavior(defaultBehaviors[0], props.viewerProtocolPolicy), cacheBehaviors: otherBehaviors.length > 0 ? otherBehaviors : undefined, }; if (props.aliasConfiguration && props.viewerCertificate) { throw new Error([ 'You cannot set both aliasConfiguration and viewerCertificate properties.', 'Please only use viewerCertificate, as aliasConfiguration is deprecated.', ].join(' ')); } let _viewerCertificate = props.viewerCertificate; if (props.aliasConfiguration) { const { acmCertRef, securityPolicy, sslMethod, names: aliases } = props.aliasConfiguration; _viewerCertificate = ViewerCertificate.fromAcmCertificate(certificatemanager.Certificate.fromCertificateArn(this, 'AliasConfigurationCert', acmCertRef), { securityPolicy, sslMethod, aliases }); } if (_viewerCertificate) { const { props: viewerCertificate, aliases } = _viewerCertificate; Object.assign(distributionConfig, { aliases, viewerCertificate }); const { minimumProtocolVersion, sslSupportMethod } = viewerCertificate; if (minimumProtocolVersion != null && sslSupportMethod != null) { const validProtocols = this.VALID_SSL_PROTOCOLS[sslSupportMethod]; if (validProtocols.indexOf(minimumProtocolVersion.toString()) === -1) { // eslint-disable-next-line max-len throw new Error(`${minimumProtocolVersion} is not compabtible with sslMethod ${sslSupportMethod}.\n\tValid Protocols are: ${validProtocols.join(', ')}`); } } } else { distributionConfig = { ...distributionConfig, viewerCertificate: { cloudFrontDefaultCertificate: true }, }; } if (props.loggingConfig) { this.loggingBucket = props.loggingConfig.bucket || new s3.Bucket(this, 'LoggingBucket', { encryption: s3.BucketEncryption.S3_MANAGED, }); distributionConfig = { ...distributionConfig, logging: { bucket: this.loggingBucket.bucketRegionalDomainName, includeCookies: props.loggingConfig.includeCookies || false, prefix: props.loggingConfig.prefix, }, }; } if (props.geoRestriction) { distributionConfig = { ...distributionConfig, restrictions: { geoRestriction: { restrictionType: props.geoRestriction.restrictionType, locations: props.geoRestriction.locations, }, }, }; } const distribution = new cloudfront_generated_1.CfnDistribution(this, 'CFDistribution', { distributionConfig }); this.node.defaultChild = distribution; this.domainName = distribution.attrDomainName; this.distributionDomainName = distribution.attrDomainName; this.distributionId = distribution.ref; } /** * Creates a construct that represents an external (imported) distribution. */ static fromDistributionAttributes(scope, id, attrs) { try { jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_CloudFrontWebDistributionAttributes(attrs); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.fromDistributionAttributes); } throw error; } return new class extends cdk.Resource { constructor() { super(scope, id); this.domainName = attrs.domainName; this.distributionDomainName = attrs.domainName; this.distributionId = attrs.distributionId; } }(); } toBehavior(input, protoPolicy) { let toReturn = { allowedMethods: this.METHOD_LOOKUP_MAP[input.allowedMethods || CloudFrontAllowedMethods.GET_HEAD], cachedMethods: this.METHOD_LOOKUP_MAP[input.cachedMethods || CloudFrontAllowedCachedMethods.GET_HEAD], compress: input.compress !== false, defaultTtl: input.defaultTtl && input.defaultTtl.toSeconds(), forwardedValues: input.forwardedValues || { queryString: false, cookies: { forward: 'none' } }, maxTtl: input.maxTtl && input.maxTtl.toSeconds(), minTtl: input.minTtl && input.minTtl.toSeconds(), trustedKeyGroups: input.trustedKeyGroups?.map(key => key.keyGroupId), trustedSigners: input.trustedSigners, targetOriginId: input.targetOriginId, viewerProtocolPolicy: input.viewerProtocolPolicy || protoPolicy || distribution_1.ViewerProtocolPolicy.REDIRECT_TO_HTTPS, }; if (!input.isDefaultBehavior) { toReturn = Object.assign(toReturn, { pathPattern: input.pathPattern }); } if (input.functionAssociations) { toReturn = Object.assign(toReturn, { functionAssociations: input.functionAssociations.map(association => ({ functionArn: association.function.functionArn, eventType: association.eventType.toString(), })), }); } if (input.lambdaFunctionAssociations) { const includeBodyEventTypes = [distribution_1.LambdaEdgeEventType.ORIGIN_REQUEST, distribution_1.LambdaEdgeEventType.VIEWER_REQUEST]; if (input.lambdaFunctionAssociations.some(fna => fna.includeBody && !includeBodyEventTypes.includes(fna.eventType))) { throw new Error('\'includeBody\' can only be true for ORIGIN_REQUEST or VIEWER_REQUEST event types.'); } toReturn = Object.assign(toReturn, { lambdaFunctionAssociations: input.lambdaFunctionAssociations .map(fna => ({ eventType: fna.eventType, lambdaFunctionArn: fna.lambdaFunction && fna.lambdaFunction.edgeArn, includeBody: fna.includeBody, })), }); // allow edgelambda.amazonaws.com to assume the functions' execution role. for (const a of input.lambdaFunctionAssociations) { if (a.lambdaFunction.role && a.lambdaFunction.role instanceof iam.Role && a.lambdaFunction.role.assumeRolePolicy) { a.lambdaFunction.role.assumeRolePolicy.addStatements(new iam.PolicyStatement({ actions: ['sts:AssumeRole'], principals: [new iam.ServicePrincipal('edgelambda.amazonaws.com')], })); } } } return toReturn; } toOriginProperty(originConfig, originId) { if (!originConfig.s3OriginSource && !originConfig.customOriginSource) { throw new Error('There must be at least one origin source - either an s3OriginSource, a customOriginSource'); } if (originConfig.customOriginSource && originConfig.s3OriginSource) { throw new Error('There cannot be both an s3OriginSource and a customOriginSource in the same SourceConfiguration.'); } if ([ originConfig.originHeaders, originConfig.s3OriginSource?.originHeaders, originConfig.customOriginSource?.originHeaders, ].filter(x => x).length > 1) { throw new Error('Only one originHeaders field allowed across origin and failover origins'); } if ([ originConfig.originPath, originConfig.s3OriginSource?.originPath, originConfig.customOriginSource?.originPath, ].filter(x => x).length > 1) { throw new Error('Only one originPath field allowed across origin and failover origins'); } if ([ originConfig.originShieldRegion, originConfig.s3OriginSource?.originShieldRegion, originConfig.customOriginSource?.originShieldRegion, ].filter(x => x).length > 1) { throw new Error('Only one originShieldRegion field allowed across origin and failover origins'); } const headers = originConfig.originHeaders ?? originConfig.s3OriginSource?.originHeaders ?? originConfig.customOriginSource?.originHeaders; const originHeaders = []; if (headers) { Object.keys(headers).forEach((key) => { const oHeader = { headerName: key, headerValue: headers[key], }; originHeaders.push(oHeader); }); } let s3OriginConfig; if (originConfig.s3OriginSource) { // first case for backwards compatibility if (originConfig.s3OriginSource.originAccessIdentity) { // grant CloudFront OriginAccessIdentity read access to S3 bucket // Used rather than `grantRead` because `grantRead` will grant overly-permissive policies. // Only GetObject is needed to retrieve objects for the distribution. // This also excludes KMS permissions; currently, OAI only supports SSE-S3 for buckets. // Source: https://aws.amazon.com/blogs/networking-and-content-delivery/serving-sse-kms-encrypted-content-from-s3-using-cloudfront/ originConfig.s3OriginSource.s3BucketSource.addToResourcePolicy(new iam.PolicyStatement({ resources: [originConfig.s3OriginSource.s3BucketSource.arnForObjects('*')], actions: ['s3:GetObject'], principals: [originConfig.s3OriginSource.originAccessIdentity.grantPrincipal], })); s3OriginConfig = { originAccessIdentity: `origin-access-identity/cloudfront/${originConfig.s3OriginSource.originAccessIdentity.originAccessIdentityName}`, }; } else { s3OriginConfig = {}; } } const connectionAttempts = originConfig.connectionAttempts ?? 3; if (connectionAttempts < 1 || 3 < connectionAttempts || !Number.isInteger(connectionAttempts)) { throw new Error('connectionAttempts: You can specify 1, 2, or 3 as the number of attempts.'); } const connectionTimeout = (originConfig.connectionTimeout || cdk.Duration.seconds(10)).toSeconds(); if (connectionTimeout < 1 || 10 < connectionTimeout || !Number.isInteger(connectionTimeout)) { throw new Error('connectionTimeout: You can specify a number of seconds between 1 and 10 (inclusive).'); } const originProperty = { id: originId, domainName: originConfig.s3OriginSource ? originConfig.s3OriginSource.s3BucketSource.bucketRegionalDomainName : originConfig.customOriginSource.domainName, originPath: originConfig.originPath ?? originConfig.customOriginSource?.originPath ?? originConfig.s3OriginSource?.originPath, originCustomHeaders: originHeaders.length > 0 ? originHeaders : undefined, s3OriginConfig, originShield: this.toOriginShieldProperty(originConfig), customOriginConfig: originConfig.customOriginSource ? { httpPort: originConfig.customOriginSource.httpPort || 80, httpsPort: originConfig.customOriginSource.httpsPort || 443, originKeepaliveTimeout: (originConfig.customOriginSource.originKeepaliveTimeout && originConfig.customOriginSource.originKeepaliveTimeout.toSeconds()) || 5, originReadTimeout: (originConfig.customOriginSource.originReadTimeout && originConfig.customOriginSource.originReadTimeout.toSeconds()) || 30, originProtocolPolicy: originConfig.customOriginSource.originProtocolPolicy || distribution_1.OriginProtocolPolicy.HTTPS_ONLY, originSslProtocols: originConfig.customOriginSource .allowedOriginSSLVersions || [OriginSslPolicy.TLS_V1_2], } : undefined, connectionAttempts, connectionTimeout, }; return originProperty; } /** * Takes origin shield region from props and converts to CfnDistribution.OriginShieldProperty */ toOriginShieldProperty(originConfig) { const originShieldRegion = originConfig.originShieldRegion ?? originConfig.customOriginSource?.originShieldRegion ?? originConfig.s3OriginSource?.originShieldRegion; return originShieldRegion ? { enabled: true, originShieldRegion } : undefined; } } exports.CloudFrontWebDistribution = CloudFrontWebDistribution; _b = JSII_RTTI_SYMBOL_1; CloudFrontWebDistribution[_b] = { fqn: "@aws-cdk/aws-cloudfront.CloudFrontWebDistribution", version: "1.204.0" }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web-distribution.js","sourceRoot":"","sources":["web-distribution.ts"],"names":[],"mappings":"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","sourcesContent":["import * as certificatemanager from '@aws-cdk/aws-certificatemanager';\nimport * as iam from '@aws-cdk/aws-iam';\nimport * as lambda from '@aws-cdk/aws-lambda';\nimport * as s3 from '@aws-cdk/aws-s3';\nimport * as cdk from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnDistribution } from './cloudfront.generated';\nimport { HttpVersion, IDistribution, LambdaEdgeEventType, OriginProtocolPolicy, PriceClass, ViewerProtocolPolicy, SSLMethod, SecurityPolicyProtocol } from './distribution';\nimport { FunctionAssociation } from './function';\nimport { GeoRestriction } from './geo-restriction';\nimport { IKeyGroup } from './key-group';\nimport { IOriginAccessIdentity } from './origin-access-identity';\n\n/**\n * HTTP status code to failover to second origin\n */\nexport enum FailoverStatusCode {\n  /**\n   * Forbidden (403)\n   */\n  FORBIDDEN = 403,\n\n  /**\n   * Not found (404)\n   */\n  NOT_FOUND = 404,\n\n  /**\n   * Internal Server Error (500)\n   */\n  INTERNAL_SERVER_ERROR = 500,\n\n  /**\n   * Bad Gateway (502)\n   */\n  BAD_GATEWAY = 502,\n\n  /**\n   * Service Unavailable (503)\n   */\n  SERVICE_UNAVAILABLE = 503,\n\n  /**\n   * Gateway Timeout (504)\n   */\n  GATEWAY_TIMEOUT = 504,\n}\n\n/**\n * Configuration for custom domain names\n *\n * CloudFront can use a custom domain that you provide instead of a\n * \"cloudfront.net\" domain. To use this feature you must provide the list of\n * additional domains, and the ACM Certificate that CloudFront should use for\n * these additional domains.\n * @deprecated see {@link CloudFrontWebDistributionProps#viewerCertificate} with {@link ViewerCertificate#acmCertificate}\n */\nexport interface AliasConfiguration {\n  /**\n   * ARN of an AWS Certificate Manager (ACM) certificate.\n   */\n  readonly acmCertRef: string;\n\n  /**\n   * Domain names on the certificate\n   *\n   * Both main domain name and Subject Alternative Names.\n   */\n  readonly names: string[];\n\n  /**\n   * How CloudFront should serve HTTPS requests.\n   *\n   * See the notes on SSLMethod if you wish to use other SSL termination types.\n   *\n   * @default SSLMethod.SNI\n   * @see https://docs.aws.amazon.com/cloudfront/latest/APIReference/API_ViewerCertificate.html\n   */\n  readonly sslMethod?: SSLMethod;\n\n  /**\n   * The minimum version of the SSL protocol that you want CloudFront to use for HTTPS connections.\n   *\n   * CloudFront serves your objects only to browsers or devices that support at\n   * least the SSL version that you specify.\n   *\n   * @default - SSLv3 if sslMethod VIP, TLSv1 if sslMethod SNI\n   */\n  readonly securityPolicy?: SecurityPolicyProtocol;\n}\n\n/**\n * Logging configuration for incoming requests\n */\nexport interface LoggingConfiguration {\n  /**\n   * Bucket to log requests to\n   *\n   * @default - A logging bucket is automatically created.\n   */\n  readonly bucket?: s3.IBucket,\n\n  /**\n   * Whether to include the cookies in the logs\n   *\n   * @default false\n   */\n  readonly includeCookies?: boolean,\n\n  /**\n   * Where in the bucket to store logs\n   *\n   * @default - No prefix.\n   */\n  readonly prefix?: string\n}\n\n// Subset of SourceConfiguration for rendering properties internally\ninterface SourceConfigurationRender {\n  readonly connectionAttempts?: number;\n  readonly connectionTimeout?: cdk.Duration;\n  readonly s3OriginSource?: S3OriginConfig;\n  readonly customOriginSource?: CustomOriginConfig;\n  readonly originPath?: string;\n  readonly originHeaders?: { [key: string]: string };\n  readonly originShieldRegion?: string\n}\n\n/**\n * A source configuration is a wrapper for CloudFront origins and behaviors.\n * An origin is what CloudFront will \"be in front of\" - that is, CloudFront will pull it's assets from an origin.\n *\n * If you're using s3 as a source - pass the `s3Origin` property, otherwise, pass the `customOriginSource` property.\n *\n * One or the other must be passed, and it is invalid to pass both in the same SourceConfiguration.\n */\nexport interface SourceConfiguration {\n  /**\n   * The number of times that CloudFront attempts to connect to the origin.\n   * You can specify 1, 2, or 3 as the number of attempts.\n   *\n   * @default 3\n   */\n  readonly connectionAttempts?: number;\n\n  /**\n   * The number of seconds that CloudFront waits when trying to establish a connection to the origin.\n   * You can specify a number of seconds between 1 and 10 (inclusive).\n   *\n   * @default cdk.Duration.seconds(10)\n   */\n  readonly connectionTimeout?: cdk.Duration;\n\n  /**\n   * An s3 origin source - if you're using s3 for your assets\n   */\n  readonly s3OriginSource?: S3OriginConfig;\n\n  /**\n   * A custom origin source - for all non-s3 sources.\n   */\n  readonly customOriginSource?: Custom