Socket
Socket
Sign inDemoInstall

@aws-cdk/aws-cloudfront

Package Overview
Dependencies
Maintainers
4
Versions
288
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@aws-cdk/aws-cloudfront - npm Package Compare versions

Comparing version 0.9.2 to 0.10.0

21

lib/cloudfront.generated.d.ts

@@ -29,8 +29,9 @@ import cdk = require('@aws-cdk/cdk');

*
* @param parent the ``cdk.Construct`` this ``CloudFrontOriginAccessIdentityResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``CloudFrontOriginAccessIdentityResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``CloudFrontOriginAccessIdentityResource``
*/
constructor(parent: cdk.Construct, name: string, properties: CloudFrontOriginAccessIdentityResourceProps);
protected renderProperties(): {
readonly propertyOverrides: CloudFrontOriginAccessIdentityResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;

@@ -84,8 +85,9 @@ };

*
* @param parent the ``cdk.Construct`` this ``DistributionResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``DistributionResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``DistributionResource``
*/
constructor(parent: cdk.Construct, name: string, properties: DistributionResourceProps);
protected renderProperties(): {
readonly propertyOverrides: DistributionResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;

@@ -632,8 +634,9 @@ };

*
* @param parent the ``cdk.Construct`` this ``StreamingDistributionResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param parent the ``cdk.Construct`` this ``StreamingDistributionResource`` is a part of
* @param name the name of the resource in the ``cdk.Construct`` tree
* @param properties the properties of this ``StreamingDistributionResource``
*/
constructor(parent: cdk.Construct, name: string, properties: StreamingDistributionResourceProps);
protected renderProperties(): {
readonly propertyOverrides: StreamingDistributionResourceProps;
protected renderProperties(properties: any): {
[key: string]: any;

@@ -640,0 +643,0 @@ };

@@ -355,8 +355,8 @@ import s3 = require('@aws-cdk/aws-s3');

* originConfigs: [
* {
* s3OriginSource: {
* s3BucketSource: sourceBucket
* },
* behaviors : [ {isDefaultBehavior}]
* }
* {
* s3OriginSource: {
* s3BucketSource: sourceBucket
* },
* behaviors : [ {isDefaultBehavior}]
* }
* ]

@@ -363,0 +363,0 @@ * });

@@ -93,8 +93,8 @@ "use strict";

* originConfigs: [
* {
* s3OriginSource: {
* s3BucketSource: sourceBucket
* },
* behaviors : [ {isDefaultBehavior}]
* }
* {
* s3OriginSource: {
* s3BucketSource: sourceBucket
* },
* behaviors : [ {isDefaultBehavior}]
* }
* ]

@@ -243,2 +243,2 @@ * });

exports.CloudFrontWebDistribution = CloudFrontWebDistribution;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web_distribution.js","sourceRoot":"","sources":["web_distribution.ts"],"names":[],"mappings":"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","sourcesContent":["import s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { cloudformation } from './cloudfront.generated';\n\nexport enum HttpVersion {\n    HTTP1_1 = \"http1.1\",\n    HTTP2 = \"http2\"\n}\n\n/**\n * The price class determines how many edge locations CloudFront will use for your distribution.\n */\nexport enum PriceClass {\n    PriceClass100 = \"PriceClass_100\",\n    PriceClass200 = \"PriceClass_200\",\n    PriceClassAll = \"PriceClass_All\"\n}\n\n/**\n * How HTTPs should be handled with your distribution.\n */\nexport enum ViewerProtocolPolicy {\n    HTTPSOnly = \"https-only\",\n    RedirectToHTTPS = \"redirect-to-https\",\n    AllowAll = \"allow-all\"\n}\n\n/**\n * CloudFront can use a custom domain that you provide instead of a \"cloudfront.net\" domain.\n * To use this feature - you must provide the list of additional domains,\n * and the ACM Certificate that CloudFront should use for these additional domains.\n *\n * Note - CloudFront only accepts one additional certificate - therefore the certificate *must*\n * use have SANs (Subject Alternative Names) for all domains listed.\n *\n * sslMethod is optional - we default to SNI if not specified. See the notes on SSLMethod if you wish to use other SSL termination types.\n *\n * @default sslMethod: SNI by default\n */\nexport interface AliasConfiguration {\n    readonly names: string[],\n    readonly acmCertRef: string,\n    readonly sslMethod?: SSLMethod,\n}\n\n/**\n * The SSL method CloudFront will use for your distribution.\n *\n * Server Name Indication (SNI) - is an extension to the TLS computer networking protocol by which a client indicates\n *  which hostname it is attempting to connect to at the start of the handshaking process. This allows a server to present\n *  multiple certificates on the same IP address and TCP port number and hence allows multiple secure (HTTPS) websites\n * (or any other service over TLS) to be served by the same IP address without requiring all those sites to use the same certificate.\n *\n * CloudFront can use SNI to host multiple distributions on the same IP - which a large majority of clients will support.\n *\n * If your clients cannot support SNI however - CloudFront can use dedicated IPs for your distribution - but there is a prorated monthly charge for\n * using this feature. By default, we use SNI - but you can optionally enable dedicated IPs (VIP).\n *\n * See the CloudFront SSL for more details about pricing : https://aws.amazon.com/cloudfront/custom-ssl-domains/\n *\n */\nexport enum SSLMethod {\n    SNI = \"sni-only\",\n    VIP = \"vip\"\n}\n\n/**\n * CloudFront supports logging of incoming requests and can log details to a given S3 Bucket.\n *\n * If you wish to configure logging you can configure details about it.\n *\n * @default bucket: if you do not pass a bucket for logging - we'll create one\n * @default includeCookies: false by default\n * @default prefix: no prefix is set by default.\n */\nexport interface LoggingConfiguration {\n    readonly bucket?: s3.BucketRef,\n    readonly includeCookies?: boolean,\n    readonly prefix?: 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     * 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?: CustomOriginConfig,\n\n    /**\n     * The behaviors associated with this source.\n     * At least one (default) behavior must be included.\n     */\n    readonly behaviors: Behavior[];\n\n    /**\n     * The relative path to the origin root to use for sources.\n     *\n     * @default /\n     */\n    readonly originPath?: string,\n\n    /**\n     * Any additional headers to pass to the origin\n     *\n     * @default no additional headers are passed\n     */\n    readonly originHeaders?: {[key: string]: string};\n}\n\n/**\n * A custom origin configuration\n */\nexport interface CustomOriginConfig {\n    /**\n     * The domain name of the custom origin. Should not include the path - that should be in the parent SourceConfiguration\n     */\n    readonly domainName: string,\n\n    /**\n     * The origin HTTP port\n     *\n     * @default 80\n     */\n    readonly httpPort?: number,\n\n    /**\n     * The origin HTTPS port\n     *\n     * @default 443\n     */\n    readonly httpsPort?: number,\n\n    /**\n     * The keep alive timeout when making calls in seconds.\n     *\n     * @default: 5 seconds\n     */\n    readonly originKeepaliveTimeoutSeconds?: number,\n\n    /**\n     * The protocol (http or https) policy to use when interacting with the origin.\n     *\n     * @default: HttpsOnly\n     */\n    readonly originProtocolPolicy?: OriginProtocolPolicy,\n\n    /**\n     * The read timeout when calling the origin in seconds\n     *\n     * @default 30 seconds\n     */\n    readonly originReadTimeoutSeconds?: number\n\n    /**\n     * The SSL versions to use when interacting with the origin.\n     *\n     * @default [TLSv1_2]\n     */\n    readonly allowedOriginSSLVersions?: OriginSslPolicy[];\n\n}\n\nexport enum OriginSslPolicy {\n    SSLv3 = \"SSLv3\",\n    TLSv1 = \"TLSv1\",\n    TLSv1_1 = \"TLSv1.1\",\n    TLSv1_2 = \"TLSv1.2\",\n}\n\nexport enum OriginProtocolPolicy {\n    HttpOnly = \"http-only\",\n    MatchViewer = \"match-viewer\",\n    HttpsOnly = \"https-only\",\n}\n\nexport interface S3OriginConfig {\n    /**\n     * The source bucket to serve content from\n     */\n    readonly s3BucketSource: s3.Bucket,\n\n    /**\n     * The optional origin identity cloudfront will use when calling your s3 bucket.\n     */\n    readonly originAccessIdentity?: cloudformation.CloudFrontOriginAccessIdentityResource\n}\n\n/**\n * An enum for the supported methods to a CloudFront distribution.\n */\nexport enum CloudFrontAllowedMethods {\n    GET_HEAD = \"GH\",\n    GET_HEAD_OPTIONS = \"GHO\",\n    ALL = \"ALL\"\n}\n\n/**\n * Enums for the methods CloudFront can cache.\n */\nexport enum CloudFrontAllowedCachedMethods {\n    GET_HEAD = \"GH\",\n    GET_HEAD_OPTIONS = \"GHO\",\n}\n\n/**\n * A CloudFront behavior wrapper.\n */\nexport interface Behavior {\n\n    /**\n     * If CloudFront should automatically compress some content types.\n     *\n     * @default true\n     */\n    compress?: boolean;\n\n    /**\n     * If this behavior is the default behavior for the distribution.\n     *\n     * You must specify exactly one default distribution per CloudFront distribution.\n     * The default behavior is allowed to omit the \"path\" property.\n     */\n    isDefaultBehavior?: boolean;\n\n    /**\n     * Trusted signers is how CloudFront allows you to serve private content.\n     * The signers are the account IDs that are allowed to sign cookies/presigned URLs for this distribution.\n     *\n     * If you pass a non empty value, all requests for this behavior must be signed (no public access will be allowed)\n     */\n    trustedSigners?: string[];\n\n    /**\n     *\n     * The default amount of time CloudFront will cache an object.\n     *\n     * This value applies only when your custom origin does not add HTTP headers,\n     * such as Cache-Control max-age, Cache-Control s-maxage, and Expires to objects.\n     * @default 86400 (1 day)\n     *\n     */\n    defaultTtlSeconds?: number;\n\n    /**\n     * The method this CloudFront distribution responds do.\n     *\n     * @default GET_HEAD\n     */\n    allowedMethods?: CloudFrontAllowedMethods;\n\n    /**\n     * The path this behavior responds to.\n     * Required for all non-default behaviors. (The default behavior implicitly has \"*\" as the path pattern. )\n     *\n     */\n    pathPattern?: string;\n\n    /**\n     * Which methods are cached by CloudFront by default.\n     *\n     * @default GET_HEAD\n     */\n    cachedMethods?: CloudFrontAllowedCachedMethods;\n\n    /**\n     * The values CloudFront will forward to the origin when making a request.\n     *\n     * @default none (no cookies - no headers)\n     *\n     */\n    forwardedValues?: cloudformation.DistributionResource.ForwardedValuesProperty;\n\n    /**\n     * The minimum amount of time that you want objects to stay in the cache\n     * before CloudFront queries your origin.\n     */\n    minTtlSeconds?: number;\n\n    /**\n     * The max amount of time you want objects to stay in the cache\n     * before CloudFront queries your origin.\n     *\n     * @default 31536000 (one year)\n     */\n    maxTtlSeconds?: number;\n\n}\n\nexport interface ErrorConfiguration {\n    /**\n     * The error code matched from the origin\n     */\n    originErrorCode: number,\n    /**\n     * The error code that is sent to the caller.\n     */\n    respondWithErrorCode: number,\n    /**\n     * The path to service instead\n     */\n    respondWithPage: string,\n    /**\n     * How long before this error is retried.\n     */\n    cacheTtl?: number\n}\n\nexport interface CloudFrontWebDistributionProps {\n\n    /**\n     * AliasConfiguration is used to configured CloudFront to respond to requests on custom domain names.\n     *\n     * @default none\n     */\n    aliasConfiguration?: AliasConfiguration;\n\n    /**\n     * A comment for this distribution in the cloud front console.\n     */\n    comment?: string;\n\n    /**\n     * The default object to serve.\n     *\n     * @default \"index.html\"\n     */\n    defaultRootObject?: string;\n\n    /**\n     * If your distribution should have IPv6 enabled.\n     *\n     * @default true\n     */\n    enableIpV6?: boolean;\n\n    /**\n     * The max supported HTTP Versions.\n     *\n     * @default HttpVersion.HTTP2\n     */\n    httpVersion?: HttpVersion;\n\n    /**\n     * The price class for the distribution (this impacts how many locations CloudFront uses for your distribution, and billing)\n     *\n     * @default PriceClass_100: the cheapest option for CloudFront is picked by default.\n     */\n    priceClass?: PriceClass;\n\n    /**\n     * The default viewer policy for incoming clients.\n     *\n     * @default RedirectToHTTPs\n     */\n    viewerProtocolPolicy?: ViewerProtocolPolicy;\n\n    /**\n     * The origin configurations for this distribution. Behaviors are a part of the origin.\n     */\n    originConfigs: SourceConfiguration[];\n\n    /**\n     * Optional - if we should enable logging.\n     * You can pass an empty object ({}) to have us auto create a bucket for logging.\n     * Omission of this property indicates no logging is to be enabled.\n     *\n     * @default: no logging is enabled by default.\n     */\n    loggingConfig?: LoggingConfiguration;\n\n    /**\n     * How CloudFront should handle requests that are no successful (eg PageNotFound)\n     */\n    errorConfigurations?: cloudformation.DistributionResource.CustomErrorResponseProperty[];\n}\n\n/**\n * Internal only - just adds the originId string to the Behavior\n */\ninterface BehaviorWithOrigin extends Behavior {\n    targetOriginId: string;\n}\n\n/**\n * Amazon CloudFront is a global content delivery network (CDN) service that securely delivers data, videos,\n * applications, and APIs to your viewers with low latency and high transfer speeds.\n * CloudFront fronts user provided content and caches it at edge locations across the world.\n *\n * Here's how you can use this construct:\n *\n * ```ts\n * import { CloudFront } from '@aws-cdk/aws-cloudfront'\n *\n * const sourceBucket = new Bucket(this, 'Bucket');\n *\n * const distribution = new CloudFrontDistribution(this, 'MyDistribution', {\n *  originConfigs: [\n *      {\n *          s3OriginSource: {\n *            s3BucketSource: sourceBucket\n *          },\n *          behaviors : [ {isDefaultBehavior}]\n *      }\n *  ]\n * });\n * ```\n *\n * This will create a CloudFront distribution that uses your S3Bucket as it's origin.\n *\n * You can customize the distribution using additional properties from the CloudFrontWebDistributionProps interface.\n *\n *\n */\nexport class CloudFrontWebDistribution extends cdk.Construct {\n\n    /**\n     * The hosted zone Id if using an alias record in Route53.\n     * This value never changes.\n     */\n    public readonly aliasHostedZoneId: string = \"Z2FDTNDATAQYW2\";\n\n    /**\n     * The logging bucket for this CloudFront distribution.\n     * If logging is not enabled for this distribution - this property will be undefined.\n     */\n    public readonly loggingBucket?: s3.BucketRef;\n\n    /**\n     * The domain name created by CloudFront for this distribution.\n     * If you are using aliases for your distribution, this is the domainName your DNS records should point to.\n     * (In Route53, you could create an ALIAS record to this value, for example. )\n     */\n    public readonly domainName: string;\n\n    /**\n     * Maps our methods to the string arrays they are\n     */\n    private readonly METHOD_LOOKUP_MAP = {\n        GH: [\"GET\", \"HEAD\"],\n        GHO: [\"GET\", \"HEAD\", \"OPTIONS\"],\n        ALL: [\"DELETE\", \"GET\", \"HEAD\", \"OPTIONS\", \"PATCH\", \"POST\", \"PUT\"],\n    };\n\n    constructor(parent: cdk.Construct, name: string, props: CloudFrontWebDistributionProps) {\n        super(parent, name);\n\n        const distributionConfig: cloudformation.DistributionResource.DistributionConfigProperty = {\n            comment: props.comment,\n            enabled: true,\n            defaultRootObject: props.defaultRootObject || \"index.html\",\n            httpVersion: props.httpVersion || HttpVersion.HTTP2,\n            priceClass: props.priceClass || PriceClass.PriceClass100,\n            ipv6Enabled: props.enableIpV6 || true,\n            // tslint:disable-next-line:max-line-length\n            customErrorResponses: props.errorConfigurations, // TODO: validation : https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudfront-distribution-customerrorresponse.html#cfn-cloudfront-distribution-customerrorresponse-errorcachingminttl\n        };\n\n        const behaviors: BehaviorWithOrigin[] = [];\n\n        const origins: cloudformation.DistributionResource.OriginProperty[] = [];\n\n        let originIndex = 1;\n        for (const originConfig of props.originConfigs) {\n            const originId = `origin${originIndex}`;\n            if (!originConfig.s3OriginSource && !originConfig.customOriginSource) {\n                throw new Error(\"There must be at least one origin source - either an s3OriginSource or a customOriginSource\");\n            }\n            if (originConfig.customOriginSource && originConfig.s3OriginSource) {\n                throw new Error(\"There cannot be both an s3OriginSource and a customOriginSource in the same SourceConfiguration.\");\n            }\n\n            const originHeaders: cloudformation.DistributionResource.OriginCustomHeaderProperty[] = [];\n            if (originConfig.originHeaders) {\n                Object.keys(originConfig.originHeaders).forEach(key => {\n                    const oHeader: cloudformation.DistributionResource.OriginCustomHeaderProperty = {\n                        headerName: key,\n                        headerValue: originConfig.originHeaders![key]\n                    };\n                    originHeaders.push(oHeader);\n                });\n            }\n\n            const originProperty: cloudformation.DistributionResource.OriginProperty = {\n                id: originId,\n                domainName: originConfig.s3OriginSource ?\n                    originConfig.s3OriginSource.s3BucketSource.domainName :\n                    originConfig.customOriginSource!.domainName,\n                originPath: originConfig.originPath,\n                originCustomHeaders: originHeaders.length > 0 ? originHeaders : undefined,\n            };\n\n            if (originConfig.s3OriginSource && originConfig.s3OriginSource.originAccessIdentity) {\n                originProperty.s3OriginConfig = {\n                    originAccessIdentity: new cdk.FnConcat(\n                        \"origin-access-identity/cloudfront/\", originConfig.s3OriginSource.originAccessIdentity.ref\n                    ),\n                };\n            } else if (originConfig.s3OriginSource) {\n                originProperty.s3OriginConfig = {};\n            }\n\n            if (originConfig.customOriginSource) {\n                originProperty.customOriginConfig = {\n                    httpPort: originConfig.customOriginSource.httpPort || 80,\n                    httpsPort: originConfig.customOriginSource.httpsPort || 443,\n                    originKeepaliveTimeout: originConfig.customOriginSource.originKeepaliveTimeoutSeconds || 5,\n                    originReadTimeout: originConfig.customOriginSource.originReadTimeoutSeconds || 30,\n                    originProtocolPolicy: originConfig.customOriginSource.originProtocolPolicy || OriginProtocolPolicy.HttpsOnly,\n                    originSslProtocols: originConfig.customOriginSource.allowedOriginSSLVersions || [OriginSslPolicy.TLSv1_2]\n                };\n            }\n            for (const behavior of originConfig.behaviors) {\n                behaviors.push({...behavior, targetOriginId: originId});\n            }\n            origins.push(originProperty);\n            originIndex++;\n        }\n\n        origins.forEach(origin => {\n            if (!origin.s3OriginConfig && !origin.customOriginConfig) {\n                throw new Error(`Origin ${origin.domainName} is missing either S3OriginConfig or CustomOriginConfig. At least 1 must be specified.`);\n            }\n        });\n        distributionConfig.origins = origins;\n\n        const defaultBehaviors = behaviors.filter(behavior => behavior.isDefaultBehavior);\n        if (defaultBehaviors.length !== 1) {\n            throw new Error(\"There can only be one default behavior across all sources. [ One default behavior per distribution ].\");\n        }\n        distributionConfig.defaultCacheBehavior = this.toBehavior(defaultBehaviors[0]);\n        const otherBehaviors: cloudformation.DistributionResource.CacheBehaviorProperty[] = [];\n        for (const behavior of behaviors.filter(b => !b.isDefaultBehavior)) {\n            if (!behavior.pathPattern) {\n                throw new Error(\"pathPattern is required for all non-default behaviors\");\n            }\n            otherBehaviors.push(this.toBehavior(behavior) as cloudformation.DistributionResource.CacheBehaviorProperty);\n        }\n        distributionConfig.cacheBehaviors = otherBehaviors;\n\n        if (props.aliasConfiguration) {\n            distributionConfig.aliases = props.aliasConfiguration.names;\n            distributionConfig.viewerCertificate = {\n                acmCertificateArn: props.aliasConfiguration.acmCertRef,\n                sslSupportMethod: props.aliasConfiguration.sslMethod || SSLMethod.SNI,\n            };\n        } else {\n            distributionConfig.viewerCertificate = {\n                cloudFrontDefaultCertificate: true\n            };\n        }\n\n        const distribution = new cloudformation.DistributionResource(this, 'CFDistribution', {distributionConfig});\n        this.domainName = distribution.distributionDomainName;\n\n    }\n\n    private toBehavior(input: BehaviorWithOrigin, protoPolicy?: ViewerProtocolPolicy) {\n        let toReturn =  {\n            allowedMethods: this.METHOD_LOOKUP_MAP[input.allowedMethods || CloudFrontAllowedMethods.GET_HEAD],\n            cachedMethods: this.METHOD_LOOKUP_MAP[input.cachedMethods || CloudFrontAllowedCachedMethods.GET_HEAD],\n            compress: input.compress,\n            defaultTtl: input.defaultTtlSeconds,\n            forwardedValues: input.forwardedValues || { queryString: false, cookies: {forward: \"none\"} },\n            maxTtl: input.maxTtlSeconds,\n            minTtl: input.minTtlSeconds,\n            trustedSigners: input.trustedSigners,\n            targetOriginId: input.targetOriginId,\n            viewerProtocolPolicy: protoPolicy || ViewerProtocolPolicy.RedirectToHTTPS,\n        };\n        if (!input.isDefaultBehavior) {\n            toReturn = Object.assign(toReturn, {pathPattern: input.pathPattern});\n        }\n        return toReturn;\n    }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"web_distribution.js","sourceRoot":"","sources":["web_distribution.ts"],"names":[],"mappings":";;AACA,oCAAqC;AACrC,iEAAwD;AAExD,IAAY,WAGX;AAHD,WAAY,WAAW;IACrB,kCAAmB,CAAA;IACnB,8BAAe,CAAA;AACjB,CAAC,EAHW,WAAW,GAAX,mBAAW,KAAX,mBAAW,QAGtB;AAED;;GAEG;AACH,IAAY,UAIX;AAJD,WAAY,UAAU;IACpB,8CAAgC,CAAA;IAChC,8CAAgC,CAAA;IAChC,8CAAgC,CAAA;AAClC,CAAC,EAJW,UAAU,GAAV,kBAAU,KAAV,kBAAU,QAIrB;AAED;;GAEG;AACH,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC9B,gDAAwB,CAAA;IACxB,6DAAqC,CAAA;IACrC,8CAAsB,CAAA;AACxB,CAAC,EAJW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAI/B;AAoBD;;;;;;;;;;;;;;;GAeG;AACH,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,6BAAgB,CAAA;IAChB,wBAAW,CAAA;AACb,CAAC,EAHW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAGpB;AA8GD,IAAY,eAKX;AALD,WAAY,eAAe;IACzB,kCAAe,CAAA;IACf,kCAAe,CAAA;IACf,sCAAmB,CAAA;IACnB,sCAAmB,CAAA;AACrB,CAAC,EALW,eAAe,GAAf,uBAAe,KAAf,uBAAe,QAK1B;AAED,IAAY,oBAIX;AAJD,WAAY,oBAAoB;IAC9B,8CAAsB,CAAA;IACtB,oDAA4B,CAAA;IAC5B,gDAAwB,CAAA;AAC1B,CAAC,EAJW,oBAAoB,GAApB,4BAAoB,KAApB,4BAAoB,QAI/B;AAcD;;GAEG;AACH,IAAY,wBAIX;AAJD,WAAY,wBAAwB;IAClC,2CAAe,CAAA;IACf,oDAAwB,CAAA;IACxB,uCAAW,CAAA;AACb,CAAC,EAJW,wBAAwB,GAAxB,gCAAwB,KAAxB,gCAAwB,QAInC;AAED;;GAEG;AACH,IAAY,8BAGX;AAHD,WAAY,8BAA8B;IACxC,iDAAe,CAAA;IACf,0DAAwB,CAAA;AAC1B,CAAC,EAHW,8BAA8B,GAA9B,sCAA8B,KAA9B,sCAA8B,QAGzC;AAqLD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,MAAa,yBAA0B,SAAQ,GAAG,CAAC,SAAS;IA8B1D,YAAY,MAAqB,EAAE,IAAY,EAAE,KAAqC;QACpF,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QA7BtB;;;WAGG;QACa,sBAAiB,GAAW,gBAAgB,CAAC;QAe7D;;WAEG;QACc,sBAAiB,GAAG;YACnC,EAAE,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC;YACnB,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC;YAC/B,GAAG,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC;SAClE,CAAC;QAKA,MAAM,kBAAkB,GAAmE;YACzF,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,OAAO,EAAE,IAAI;YACb,iBAAiB,EAAE,KAAK,CAAC,iBAAiB,IAAI,YAAY;YAC1D,WAAW,EAAE,KAAK,CAAC,WAAW,IAAI,WAAW,CAAC,KAAK;YACnD,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,UAAU,CAAC,aAAa;YACxD,WAAW,EAAE,KAAK,CAAC,UAAU,IAAI,IAAI;YACrC,2CAA2C;YAC3C,oBAAoB,EAAE,KAAK,CAAC,mBAAmB;SAChD,CAAC;QAEF,MAAM,SAAS,GAAyB,EAAE,CAAC;QAE3C,MAAM,OAAO,GAAyD,EAAE,CAAC;QAEzE,IAAI,WAAW,GAAG,CAAC,CAAC;QACpB,KAAK,MAAM,YAAY,IAAI,KAAK,CAAC,aAAa,EAAE;YAC9C,MAAM,QAAQ,GAAG,SAAS,WAAW,EAAE,CAAC;YACxC,IAAI,CAAC,YAAY,CAAC,cAAc,IAAI,CAAC,YAAY,CAAC,kBAAkB,EAAE;gBACpE,MAAM,IAAI,KAAK,CAAC,6FAA6F,CAAC,CAAC;aAChH;YACD,IAAI,YAAY,CAAC,kBAAkB,IAAI,YAAY,CAAC,cAAc,EAAE;gBAClE,MAAM,IAAI,KAAK,CAAC,kGAAkG,CAAC,CAAC;aACrH;YAED,MAAM,aAAa,GAAqE,EAAE,CAAC;YAC3F,IAAI,YAAY,CAAC,aAAa,EAAE;gBAC9B,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;oBACpD,MAAM,OAAO,GAAmE;wBAC9E,UAAU,EAAE,GAAG;wBACf,WAAW,EAAE,YAAY,CAAC,aAAc,CAAC,GAAG,CAAC;qBAC9C,CAAC;oBACF,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBAC9B,CAAC,CAAC,CAAC;aACJ;YAED,MAAM,cAAc,GAAuD;gBACzE,EAAE,EAAE,QAAQ;gBACZ,UAAU,EAAE,YAAY,CAAC,cAAc,CAAC,CAAC;oBACvC,YAAY,CAAC,cAAc,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;oBACvD,YAAY,CAAC,kBAAmB,CAAC,UAAU;gBAC7C,UAAU,EAAE,YAAY,CAAC,UAAU;gBACnC,mBAAmB,EAAE,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS;aAC1E,CAAC;YAEF,IAAI,YAAY,CAAC,cAAc,IAAI,YAAY,CAAC,cAAc,CAAC,oBAAoB,EAAE;gBACnF,cAAc,CAAC,cAAc,GAAG;oBAC9B,oBAAoB,EAAE,IAAI,GAAG,CAAC,QAAQ,CACpC,oCAAoC,EAAE,YAAY,CAAC,cAAc,CAAC,oBAAoB,CAAC,GAAG,CAC3F;iBACF,CAAC;aACH;iBAAM,IAAI,YAAY,CAAC,cAAc,EAAE;gBACtC,cAAc,CAAC,cAAc,GAAG,EAAE,CAAC;aACpC;YAED,IAAI,YAAY,CAAC,kBAAkB,EAAE;gBACnC,cAAc,CAAC,kBAAkB,GAAG;oBAClC,QAAQ,EAAE,YAAY,CAAC,kBAAkB,CAAC,QAAQ,IAAI,EAAE;oBACxD,SAAS,EAAE,YAAY,CAAC,kBAAkB,CAAC,SAAS,IAAI,GAAG;oBAC3D,sBAAsB,EAAE,YAAY,CAAC,kBAAkB,CAAC,6BAA6B,IAAI,CAAC;oBAC1F,iBAAiB,EAAE,YAAY,CAAC,kBAAkB,CAAC,wBAAwB,IAAI,EAAE;oBACjF,oBAAoB,EAAE,YAAY,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,oBAAoB,CAAC,SAAS;oBAC5G,kBAAkB,EAAE,YAAY,CAAC,kBAAkB,CAAC,wBAAwB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC;iBAC1G,CAAC;aACH;YACD,KAAK,MAAM,QAAQ,IAAI,YAAY,CAAC,SAAS,EAAE;gBAC7C,SAAS,CAAC,IAAI,mBAAK,QAAQ,IAAE,cAAc,EAAE,QAAQ,IAAE,CAAC;aACzD;YACD,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC7B,WAAW,EAAE,CAAC;SACf;QAED,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;YACvB,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,MAAM,CAAC,kBAAkB,EAAE;gBACxD,MAAM,IAAI,KAAK,CAAC,UAAU,MAAM,CAAC,UAAU,wFAAwF,CAAC,CAAC;aACtI;QACH,CAAC,CAAC,CAAC;QACH,kBAAkB,CAAC,OAAO,GAAG,OAAO,CAAC;QAErC,MAAM,gBAAgB,GAAG,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;QAClF,IAAI,gBAAgB,CAAC,MAAM,KAAK,CAAC,EAAE;YACjC,MAAM,IAAI,KAAK,CAAC,uGAAuG,CAAC,CAAC;SAC1H;QACD,kBAAkB,CAAC,oBAAoB,GAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/E,MAAM,cAAc,GAAgE,EAAE,CAAC;QACvF,KAAK,MAAM,QAAQ,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,EAAE;YAClE,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE;gBACzB,MAAM,IAAI,KAAK,CAAC,uDAAuD,CAAC,CAAC;aAC1E;YACD,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAA8D,CAAC,CAAC;SAC7G;QACD,kBAAkB,CAAC,cAAc,GAAG,cAAc,CAAC;QAEnD,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC5B,kBAAkB,CAAC,OAAO,GAAG,KAAK,CAAC,kBAAkB,CAAC,KAAK,CAAC;YAC5D,kBAAkB,CAAC,iBAAiB,GAAG;gBACrC,iBAAiB,EAAE,KAAK,CAAC,kBAAkB,CAAC,UAAU;gBACtD,gBAAgB,EAAE,KAAK,CAAC,kBAAkB,CAAC,SAAS,IAAI,SAAS,CAAC,GAAG;aACtE,CAAC;SACH;aAAM;YACL,kBAAkB,CAAC,iBAAiB,GAAG;gBACrC,4BAA4B,EAAE,IAAI;aACnC,CAAC;SACH;QAED,MAAM,YAAY,GAAG,IAAI,qCAAc,CAAC,oBAAoB,CAAC,IAAI,EAAE,gBAAgB,EAAE,EAAC,kBAAkB,EAAC,CAAC,CAAC;QAC3G,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,sBAAsB,CAAC;IAExD,CAAC;IAEO,UAAU,CAAC,KAAyB,EAAE,WAAkC;QAC9E,IAAI,QAAQ,GAAI;YACd,cAAc,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,cAAc,IAAI,wBAAwB,CAAC,QAAQ,CAAC;YACjG,aAAa,EAAE,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,aAAa,IAAI,8BAA8B,CAAC,QAAQ,CAAC;YACrG,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,UAAU,EAAE,KAAK,CAAC,iBAAiB;YACnC,eAAe,EAAE,KAAK,CAAC,eAAe,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,EAAE,EAAC,OAAO,EAAE,MAAM,EAAC,EAAE;YAC5F,MAAM,EAAE,KAAK,CAAC,aAAa;YAC3B,MAAM,EAAE,KAAK,CAAC,aAAa;YAC3B,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,cAAc,EAAE,KAAK,CAAC,cAAc;YACpC,oBAAoB,EAAE,WAAW,IAAI,oBAAoB,CAAC,eAAe;SAC1E,CAAC;QACF,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE;YAC5B,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAC,CAAC,CAAC;SACtE;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;CACF;AAjKD,8DAiKC","sourcesContent":["import s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { cloudformation } from './cloudfront.generated';\n\nexport enum HttpVersion {\n  HTTP1_1 = \"http1.1\",\n  HTTP2 = \"http2\"\n}\n\n/**\n * The price class determines how many edge locations CloudFront will use for your distribution.\n */\nexport enum PriceClass {\n  PriceClass100 = \"PriceClass_100\",\n  PriceClass200 = \"PriceClass_200\",\n  PriceClassAll = \"PriceClass_All\"\n}\n\n/**\n * How HTTPs should be handled with your distribution.\n */\nexport enum ViewerProtocolPolicy {\n  HTTPSOnly = \"https-only\",\n  RedirectToHTTPS = \"redirect-to-https\",\n  AllowAll = \"allow-all\"\n}\n\n/**\n * CloudFront can use a custom domain that you provide instead of a \"cloudfront.net\" domain.\n * To use this feature - you must provide the list of additional domains,\n * and the ACM Certificate that CloudFront should use for these additional domains.\n *\n * Note - CloudFront only accepts one additional certificate - therefore the certificate *must*\n * use have SANs (Subject Alternative Names) for all domains listed.\n *\n * sslMethod is optional - we default to SNI if not specified. See the notes on SSLMethod if you wish to use other SSL termination types.\n *\n * @default sslMethod: SNI by default\n */\nexport interface AliasConfiguration {\n  readonly names: string[],\n  readonly acmCertRef: string,\n  readonly sslMethod?: SSLMethod,\n}\n\n/**\n * The SSL method CloudFront will use for your distribution.\n *\n * Server Name Indication (SNI) - is an extension to the TLS computer networking protocol by which a client indicates\n *  which hostname it is attempting to connect to at the start of the handshaking process. This allows a server to present\n *  multiple certificates on the same IP address and TCP port number and hence allows multiple secure (HTTPS) websites\n * (or any other service over TLS) to be served by the same IP address without requiring all those sites to use the same certificate.\n *\n * CloudFront can use SNI to host multiple distributions on the same IP - which a large majority of clients will support.\n *\n * If your clients cannot support SNI however - CloudFront can use dedicated IPs for your distribution - but there is a prorated monthly charge for\n * using this feature. By default, we use SNI - but you can optionally enable dedicated IPs (VIP).\n *\n * See the CloudFront SSL for more details about pricing : https://aws.amazon.com/cloudfront/custom-ssl-domains/\n *\n */\nexport enum SSLMethod {\n  SNI = \"sni-only\",\n  VIP = \"vip\"\n}\n\n/**\n * CloudFront supports logging of incoming requests and can log details to a given S3 Bucket.\n *\n * If you wish to configure logging you can configure details about it.\n *\n * @default bucket: if you do not pass a bucket for logging - we'll create one\n * @default includeCookies: false by default\n * @default prefix: no prefix is set by default.\n */\nexport interface LoggingConfiguration {\n  readonly bucket?: s3.BucketRef,\n  readonly includeCookies?: boolean,\n  readonly prefix?: 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   * 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?: CustomOriginConfig,\n\n  /**\n   * The behaviors associated with this source.\n   * At least one (default) behavior must be included.\n   */\n  readonly behaviors: Behavior[];\n\n  /**\n   * The relative path to the origin root to use for sources.\n   *\n   * @default /\n   */\n  readonly originPath?: string,\n\n  /**\n   * Any additional headers to pass to the origin\n   *\n   * @default no additional headers are passed\n   */\n  readonly originHeaders?: {[key: string]: string};\n}\n\n/**\n * A custom origin configuration\n */\nexport interface CustomOriginConfig {\n  /**\n   * The domain name of the custom origin. Should not include the path - that should be in the parent SourceConfiguration\n   */\n  readonly domainName: string,\n\n  /**\n   * The origin HTTP port\n   *\n   * @default 80\n   */\n  readonly httpPort?: number,\n\n  /**\n   * The origin HTTPS port\n   *\n   * @default 443\n   */\n  readonly httpsPort?: number,\n\n  /**\n   * The keep alive timeout when making calls in seconds.\n   *\n   * @default: 5 seconds\n   */\n  readonly originKeepaliveTimeoutSeconds?: number,\n\n  /**\n   * The protocol (http or https) policy to use when interacting with the origin.\n   *\n   * @default: HttpsOnly\n   */\n  readonly originProtocolPolicy?: OriginProtocolPolicy,\n\n  /**\n   * The read timeout when calling the origin in seconds\n   *\n   * @default 30 seconds\n   */\n  readonly originReadTimeoutSeconds?: number\n\n  /**\n   * The SSL versions to use when interacting with the origin.\n   *\n   * @default [TLSv1_2]\n   */\n  readonly allowedOriginSSLVersions?: OriginSslPolicy[];\n\n}\n\nexport enum OriginSslPolicy {\n  SSLv3 = \"SSLv3\",\n  TLSv1 = \"TLSv1\",\n  TLSv1_1 = \"TLSv1.1\",\n  TLSv1_2 = \"TLSv1.2\",\n}\n\nexport enum OriginProtocolPolicy {\n  HttpOnly = \"http-only\",\n  MatchViewer = \"match-viewer\",\n  HttpsOnly = \"https-only\",\n}\n\nexport interface S3OriginConfig {\n  /**\n   * The source bucket to serve content from\n   */\n  readonly s3BucketSource: s3.Bucket,\n\n  /**\n   * The optional origin identity cloudfront will use when calling your s3 bucket.\n   */\n  readonly originAccessIdentity?: cloudformation.CloudFrontOriginAccessIdentityResource\n}\n\n/**\n * An enum for the supported methods to a CloudFront distribution.\n */\nexport enum CloudFrontAllowedMethods {\n  GET_HEAD = \"GH\",\n  GET_HEAD_OPTIONS = \"GHO\",\n  ALL = \"ALL\"\n}\n\n/**\n * Enums for the methods CloudFront can cache.\n */\nexport enum CloudFrontAllowedCachedMethods {\n  GET_HEAD = \"GH\",\n  GET_HEAD_OPTIONS = \"GHO\",\n}\n\n/**\n * A CloudFront behavior wrapper.\n */\nexport interface Behavior {\n\n  /**\n   * If CloudFront should automatically compress some content types.\n   *\n   * @default true\n   */\n  compress?: boolean;\n\n  /**\n   * If this behavior is the default behavior for the distribution.\n   *\n   * You must specify exactly one default distribution per CloudFront distribution.\n   * The default behavior is allowed to omit the \"path\" property.\n   */\n  isDefaultBehavior?: boolean;\n\n  /**\n   * Trusted signers is how CloudFront allows you to serve private content.\n   * The signers are the account IDs that are allowed to sign cookies/presigned URLs for this distribution.\n   *\n   * If you pass a non empty value, all requests for this behavior must be signed (no public access will be allowed)\n   */\n  trustedSigners?: string[];\n\n  /**\n   *\n   * The default amount of time CloudFront will cache an object.\n   *\n   * This value applies only when your custom origin does not add HTTP headers,\n   * such as Cache-Control max-age, Cache-Control s-maxage, and Expires to objects.\n   * @default 86400 (1 day)\n   *\n   */\n  defaultTtlSeconds?: number;\n\n  /**\n   * The method this CloudFront distribution responds do.\n   *\n   * @default GET_HEAD\n   */\n  allowedMethods?: CloudFrontAllowedMethods;\n\n  /**\n   * The path this behavior responds to.\n   * Required for all non-default behaviors. (The default behavior implicitly has \"*\" as the path pattern. )\n   *\n   */\n  pathPattern?: string;\n\n  /**\n   * Which methods are cached by CloudFront by default.\n   *\n   * @default GET_HEAD\n   */\n  cachedMethods?: CloudFrontAllowedCachedMethods;\n\n  /**\n   * The values CloudFront will forward to the origin when making a request.\n   *\n   * @default none (no cookies - no headers)\n   *\n   */\n  forwardedValues?: cloudformation.DistributionResource.ForwardedValuesProperty;\n\n  /**\n   * The minimum amount of time that you want objects to stay in the cache\n   * before CloudFront queries your origin.\n   */\n  minTtlSeconds?: number;\n\n  /**\n   * The max amount of time you want objects to stay in the cache\n   * before CloudFront queries your origin.\n   *\n   * @default 31536000 (one year)\n   */\n  maxTtlSeconds?: number;\n\n}\n\nexport interface ErrorConfiguration {\n  /**\n   * The error code matched from the origin\n   */\n  originErrorCode: number,\n  /**\n   * The error code that is sent to the caller.\n   */\n  respondWithErrorCode: number,\n  /**\n   * The path to service instead\n   */\n  respondWithPage: string,\n  /**\n   * How long before this error is retried.\n   */\n  cacheTtl?: number\n}\n\nexport interface CloudFrontWebDistributionProps {\n\n  /**\n   * AliasConfiguration is used to configured CloudFront to respond to requests on custom domain names.\n   *\n   * @default none\n   */\n  aliasConfiguration?: AliasConfiguration;\n\n  /**\n   * A comment for this distribution in the cloud front console.\n   */\n  comment?: string;\n\n  /**\n   * The default object to serve.\n   *\n   * @default \"index.html\"\n   */\n  defaultRootObject?: string;\n\n  /**\n   * If your distribution should have IPv6 enabled.\n   *\n   * @default true\n   */\n  enableIpV6?: boolean;\n\n  /**\n   * The max supported HTTP Versions.\n   *\n   * @default HttpVersion.HTTP2\n   */\n  httpVersion?: HttpVersion;\n\n  /**\n   * The price class for the distribution (this impacts how many locations CloudFront uses for your distribution, and billing)\n   *\n   * @default PriceClass_100: the cheapest option for CloudFront is picked by default.\n   */\n  priceClass?: PriceClass;\n\n  /**\n   * The default viewer policy for incoming clients.\n   *\n   * @default RedirectToHTTPs\n   */\n  viewerProtocolPolicy?: ViewerProtocolPolicy;\n\n  /**\n   * The origin configurations for this distribution. Behaviors are a part of the origin.\n   */\n  originConfigs: SourceConfiguration[];\n\n  /**\n   * Optional - if we should enable logging.\n   * You can pass an empty object ({}) to have us auto create a bucket for logging.\n   * Omission of this property indicates no logging is to be enabled.\n   *\n   * @default: no logging is enabled by default.\n   */\n  loggingConfig?: LoggingConfiguration;\n\n  /**\n   * How CloudFront should handle requests that are no successful (eg PageNotFound)\n   */\n  errorConfigurations?: cloudformation.DistributionResource.CustomErrorResponseProperty[];\n}\n\n/**\n * Internal only - just adds the originId string to the Behavior\n */\ninterface BehaviorWithOrigin extends Behavior {\n  targetOriginId: string;\n}\n\n/**\n * Amazon CloudFront is a global content delivery network (CDN) service that securely delivers data, videos,\n * applications, and APIs to your viewers with low latency and high transfer speeds.\n * CloudFront fronts user provided content and caches it at edge locations across the world.\n *\n * Here's how you can use this construct:\n *\n * ```ts\n * import { CloudFront } from '@aws-cdk/aws-cloudfront'\n *\n * const sourceBucket = new Bucket(this, 'Bucket');\n *\n * const distribution = new CloudFrontDistribution(this, 'MyDistribution', {\n *  originConfigs: [\n *    {\n *      s3OriginSource: {\n *      s3BucketSource: sourceBucket\n *      },\n *      behaviors : [ {isDefaultBehavior}]\n *    }\n *  ]\n * });\n * ```\n *\n * This will create a CloudFront distribution that uses your S3Bucket as it's origin.\n *\n * You can customize the distribution using additional properties from the CloudFrontWebDistributionProps interface.\n *\n *\n */\nexport class CloudFrontWebDistribution extends cdk.Construct {\n\n  /**\n   * The hosted zone Id if using an alias record in Route53.\n   * This value never changes.\n   */\n  public readonly aliasHostedZoneId: string = \"Z2FDTNDATAQYW2\";\n\n  /**\n   * The logging bucket for this CloudFront distribution.\n   * If logging is not enabled for this distribution - this property will be undefined.\n   */\n  public readonly loggingBucket?: s3.BucketRef;\n\n  /**\n   * The domain name created by CloudFront for this distribution.\n   * If you are using aliases for your distribution, this is the domainName your DNS records should point to.\n   * (In Route53, you could create an ALIAS record to this value, for example. )\n   */\n  public readonly domainName: string;\n\n  /**\n   * Maps our methods to the string arrays they are\n   */\n  private readonly METHOD_LOOKUP_MAP = {\n    GH: [\"GET\", \"HEAD\"],\n    GHO: [\"GET\", \"HEAD\", \"OPTIONS\"],\n    ALL: [\"DELETE\", \"GET\", \"HEAD\", \"OPTIONS\", \"PATCH\", \"POST\", \"PUT\"],\n  };\n\n  constructor(parent: cdk.Construct, name: string, props: CloudFrontWebDistributionProps) {\n    super(parent, name);\n\n    const distributionConfig: cloudformation.DistributionResource.DistributionConfigProperty = {\n      comment: props.comment,\n      enabled: true,\n      defaultRootObject: props.defaultRootObject || \"index.html\",\n      httpVersion: props.httpVersion || HttpVersion.HTTP2,\n      priceClass: props.priceClass || PriceClass.PriceClass100,\n      ipv6Enabled: props.enableIpV6 || true,\n      // tslint:disable-next-line:max-line-length\n      customErrorResponses: props.errorConfigurations, // TODO: validation : https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-properties-cloudfront-distribution-customerrorresponse.html#cfn-cloudfront-distribution-customerrorresponse-errorcachingminttl\n    };\n\n    const behaviors: BehaviorWithOrigin[] = [];\n\n    const origins: cloudformation.DistributionResource.OriginProperty[] = [];\n\n    let originIndex = 1;\n    for (const originConfig of props.originConfigs) {\n      const originId = `origin${originIndex}`;\n      if (!originConfig.s3OriginSource && !originConfig.customOriginSource) {\n        throw new Error(\"There must be at least one origin source - either an s3OriginSource or a customOriginSource\");\n      }\n      if (originConfig.customOriginSource && originConfig.s3OriginSource) {\n        throw new Error(\"There cannot be both an s3OriginSource and a customOriginSource in the same SourceConfiguration.\");\n      }\n\n      const originHeaders: cloudformation.DistributionResource.OriginCustomHeaderProperty[] = [];\n      if (originConfig.originHeaders) {\n        Object.keys(originConfig.originHeaders).forEach(key => {\n          const oHeader: cloudformation.DistributionResource.OriginCustomHeaderProperty = {\n            headerName: key,\n            headerValue: originConfig.originHeaders![key]\n          };\n          originHeaders.push(oHeader);\n        });\n      }\n\n      const originProperty: cloudformation.DistributionResource.OriginProperty = {\n        id: originId,\n        domainName: originConfig.s3OriginSource ?\n          originConfig.s3OriginSource.s3BucketSource.domainName :\n          originConfig.customOriginSource!.domainName,\n        originPath: originConfig.originPath,\n        originCustomHeaders: originHeaders.length > 0 ? originHeaders : undefined,\n      };\n\n      if (originConfig.s3OriginSource && originConfig.s3OriginSource.originAccessIdentity) {\n        originProperty.s3OriginConfig = {\n          originAccessIdentity: new cdk.FnConcat(\n            \"origin-access-identity/cloudfront/\", originConfig.s3OriginSource.originAccessIdentity.ref\n          ),\n        };\n      } else if (originConfig.s3OriginSource) {\n        originProperty.s3OriginConfig = {};\n      }\n\n      if (originConfig.customOriginSource) {\n        originProperty.customOriginConfig = {\n          httpPort: originConfig.customOriginSource.httpPort || 80,\n          httpsPort: originConfig.customOriginSource.httpsPort || 443,\n          originKeepaliveTimeout: originConfig.customOriginSource.originKeepaliveTimeoutSeconds || 5,\n          originReadTimeout: originConfig.customOriginSource.originReadTimeoutSeconds || 30,\n          originProtocolPolicy: originConfig.customOriginSource.originProtocolPolicy || OriginProtocolPolicy.HttpsOnly,\n          originSslProtocols: originConfig.customOriginSource.allowedOriginSSLVersions || [OriginSslPolicy.TLSv1_2]\n        };\n      }\n      for (const behavior of originConfig.behaviors) {\n        behaviors.push({...behavior, targetOriginId: originId});\n      }\n      origins.push(originProperty);\n      originIndex++;\n    }\n\n    origins.forEach(origin => {\n      if (!origin.s3OriginConfig && !origin.customOriginConfig) {\n        throw new Error(`Origin ${origin.domainName} is missing either S3OriginConfig or CustomOriginConfig. At least 1 must be specified.`);\n      }\n    });\n    distributionConfig.origins = origins;\n\n    const defaultBehaviors = behaviors.filter(behavior => behavior.isDefaultBehavior);\n    if (defaultBehaviors.length !== 1) {\n      throw new Error(\"There can only be one default behavior across all sources. [ One default behavior per distribution ].\");\n    }\n    distributionConfig.defaultCacheBehavior = this.toBehavior(defaultBehaviors[0]);\n    const otherBehaviors: cloudformation.DistributionResource.CacheBehaviorProperty[] = [];\n    for (const behavior of behaviors.filter(b => !b.isDefaultBehavior)) {\n      if (!behavior.pathPattern) {\n        throw new Error(\"pathPattern is required for all non-default behaviors\");\n      }\n      otherBehaviors.push(this.toBehavior(behavior) as cloudformation.DistributionResource.CacheBehaviorProperty);\n    }\n    distributionConfig.cacheBehaviors = otherBehaviors;\n\n    if (props.aliasConfiguration) {\n      distributionConfig.aliases = props.aliasConfiguration.names;\n      distributionConfig.viewerCertificate = {\n        acmCertificateArn: props.aliasConfiguration.acmCertRef,\n        sslSupportMethod: props.aliasConfiguration.sslMethod || SSLMethod.SNI,\n      };\n    } else {\n      distributionConfig.viewerCertificate = {\n        cloudFrontDefaultCertificate: true\n      };\n    }\n\n    const distribution = new cloudformation.DistributionResource(this, 'CFDistribution', {distributionConfig});\n    this.domainName = distribution.distributionDomainName;\n\n  }\n\n  private toBehavior(input: BehaviorWithOrigin, protoPolicy?: ViewerProtocolPolicy) {\n    let toReturn =  {\n      allowedMethods: this.METHOD_LOOKUP_MAP[input.allowedMethods || CloudFrontAllowedMethods.GET_HEAD],\n      cachedMethods: this.METHOD_LOOKUP_MAP[input.cachedMethods || CloudFrontAllowedCachedMethods.GET_HEAD],\n      compress: input.compress,\n      defaultTtl: input.defaultTtlSeconds,\n      forwardedValues: input.forwardedValues || { queryString: false, cookies: {forward: \"none\"} },\n      maxTtl: input.maxTtlSeconds,\n      minTtl: input.minTtlSeconds,\n      trustedSigners: input.trustedSigners,\n      targetOriginId: input.targetOriginId,\n      viewerProtocolPolicy: protoPolicy || ViewerProtocolPolicy.RedirectToHTTPS,\n    };\n    if (!input.isDefaultBehavior) {\n      toReturn = Object.assign(toReturn, {pathPattern: input.pathPattern});\n    }\n    return toReturn;\n  }\n}\n"]}
{
"name": "@aws-cdk/aws-cloudfront",
"version": "0.9.2",
"version": "0.10.0",
"description": "CDK Constructs for AWS CloudFront",

@@ -55,17 +55,17 @@ "main": "lib/index.js",

"devDependencies": {
"@aws-cdk/assert": "^0.9.2",
"@aws-cdk/assert": "^0.10.0",
"aws-sdk": "^2.259.1",
"cdk-build-tools": "^0.9.2",
"cdk-integ-tools": "^0.9.2",
"cfn2ts": "^0.9.2",
"pkglint": "^0.9.2"
"cdk-build-tools": "^0.10.0",
"cdk-integ-tools": "^0.10.0",
"cfn2ts": "^0.10.0",
"pkglint": "^0.10.0"
},
"dependencies": {
"@aws-cdk/aws-certificatemanager": "^0.9.2",
"@aws-cdk/aws-iam": "^0.9.2",
"@aws-cdk/aws-kms": "^0.9.2",
"@aws-cdk/aws-s3": "^0.9.2",
"@aws-cdk/cdk": "^0.9.2"
"@aws-cdk/aws-certificatemanager": "^0.10.0",
"@aws-cdk/aws-iam": "^0.10.0",
"@aws-cdk/aws-kms": "^0.10.0",
"@aws-cdk/aws-s3": "^0.10.0",
"@aws-cdk/cdk": "^0.10.0"
},
"homepage": "https://github.com/awslabs/aws-cdk"
}

@@ -25,2 +25,2 @@ "use strict";

process.stdout.write(app.run());
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2xvdWRmcm9udC1jdXN0b20uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5jbG91ZGZyb250LWN1c3RvbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLG9DQUFxQztBQUNyQyxxQ0FBc0M7QUFFdEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUV0QyxNQUFNLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDLENBQUM7QUFFOUQsSUFBSSxVQUFVLENBQUMseUJBQXlCLENBQUMsS0FBSyxFQUFFLDBCQUEwQixFQUFFO0lBQ3hFLGFBQWEsRUFBRTtRQUNYO1lBQ0ksYUFBYSxFQUFFO2dCQUNiLGlCQUFpQixFQUFFLFdBQVc7YUFDL0I7WUFDRCxrQkFBa0IsRUFBRTtnQkFDbEIsVUFBVSxFQUFFLGtCQUFrQjthQUMvQjtZQUNELFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxpQkFBaUIsRUFBRSxJQUFJO2lCQUN4QjthQUNGO1NBQ0o7S0FDSjtDQUNKLENBQUMsQ0FBQztBQUVILE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgY2xvdWRmcm9udCA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcChwcm9jZXNzLmFyZ3YpO1xuXG5jb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soYXBwLCAnYXdzLWNkay1jbG91ZGZyb250LWN1c3RvbScpO1xuXG5uZXcgY2xvdWRmcm9udC5DbG91ZEZyb250V2ViRGlzdHJpYnV0aW9uKHN0YWNrLCAnQW5BbWF6aW5nV2Vic2l0ZVByb2JhYmx5Jywge1xuICAgIG9yaWdpbkNvbmZpZ3M6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgb3JpZ2luSGVhZGVyczoge1xuICAgICAgICAgICAgICBcIlgtQ3VzdG9tLUhlYWRlclwiOiBcInNvbWV2YWx1ZVwiLFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIGN1c3RvbU9yaWdpblNvdXJjZToge1xuICAgICAgICAgICAgICBkb21haW5OYW1lOiBcImJyZWxhbmRtLmEyei5jb21cIixcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBiZWhhdmlvcnM6IFtcbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIGlzRGVmYXVsdEJlaGF2aW9yOiB0cnVlLFxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICBdXG4gICAgICAgIH1cbiAgICBdXG59KTtcblxucHJvY2Vzcy5zdGRvdXQud3JpdGUoYXBwLnJ1bigpKTtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2xvdWRmcm9udC1jdXN0b20uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyJpbnRlZy5jbG91ZGZyb250LWN1c3RvbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUNBLG9DQUFxQztBQUNyQyxxQ0FBc0M7QUFFdEMsTUFBTSxHQUFHLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUV0QyxNQUFNLEtBQUssR0FBRyxJQUFJLEdBQUcsQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLDJCQUEyQixDQUFDLENBQUM7QUFFOUQsSUFBSSxVQUFVLENBQUMseUJBQXlCLENBQUMsS0FBSyxFQUFFLDBCQUEwQixFQUFFO0lBQzFFLGFBQWEsRUFBRTtRQUNiO1lBQ0UsYUFBYSxFQUFFO2dCQUNiLGlCQUFpQixFQUFFLFdBQVc7YUFDL0I7WUFDRCxrQkFBa0IsRUFBRTtnQkFDbEIsVUFBVSxFQUFFLGtCQUFrQjthQUMvQjtZQUNELFNBQVMsRUFBRTtnQkFDVDtvQkFDQSxpQkFBaUIsRUFBRSxJQUFJO2lCQUN0QjthQUNGO1NBQ0Y7S0FDRjtDQUNGLENBQUMsQ0FBQztBQUVILE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgY2RrID0gcmVxdWlyZSgnQGF3cy1jZGsvY2RrJyk7XG5pbXBvcnQgY2xvdWRmcm9udCA9IHJlcXVpcmUoJy4uL2xpYicpO1xuXG5jb25zdCBhcHAgPSBuZXcgY2RrLkFwcChwcm9jZXNzLmFyZ3YpO1xuXG5jb25zdCBzdGFjayA9IG5ldyBjZGsuU3RhY2soYXBwLCAnYXdzLWNkay1jbG91ZGZyb250LWN1c3RvbScpO1xuXG5uZXcgY2xvdWRmcm9udC5DbG91ZEZyb250V2ViRGlzdHJpYnV0aW9uKHN0YWNrLCAnQW5BbWF6aW5nV2Vic2l0ZVByb2JhYmx5Jywge1xuICBvcmlnaW5Db25maWdzOiBbXG4gICAge1xuICAgICAgb3JpZ2luSGVhZGVyczoge1xuICAgICAgICBcIlgtQ3VzdG9tLUhlYWRlclwiOiBcInNvbWV2YWx1ZVwiLFxuICAgICAgfSxcbiAgICAgIGN1c3RvbU9yaWdpblNvdXJjZToge1xuICAgICAgICBkb21haW5OYW1lOiBcImJyZWxhbmRtLmEyei5jb21cIixcbiAgICAgIH0sXG4gICAgICBiZWhhdmlvcnM6IFtcbiAgICAgICAge1xuICAgICAgICBpc0RlZmF1bHRCZWhhdmlvcjogdHJ1ZSxcbiAgICAgICAgfVxuICAgICAgXVxuICAgIH1cbiAgXVxufSk7XG5cbnByb2Nlc3Muc3Rkb3V0LndyaXRlKGFwcC5ydW4oKSk7XG4iXX0=

@@ -20,2 +20,2 @@ "use strict";

process.stdout.write(app.run());
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2xvdWRmcm9udC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmNsb3VkZnJvbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxzQ0FBdUM7QUFDdkMsb0NBQXFDO0FBQ3JDLHFDQUFzQztBQUV0QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBRXRDLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztBQUV2RCxNQUFNLFlBQVksR0FBRyxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBRXBELElBQUksVUFBVSxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsRUFBRTtJQUM5RCxhQUFhLEVBQUU7UUFDWDtZQUNJLGNBQWMsRUFBRTtnQkFDWixjQUFjLEVBQUUsWUFBWTthQUMvQjtZQUNELFNBQVMsRUFBRyxDQUFFLEVBQUMsaUJBQWlCLEVBQUUsSUFBSSxFQUFDLENBQUM7U0FDM0M7S0FDSjtDQUNILENBQUMsQ0FBQztBQUVKLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgczMgPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtczMnKTtcbmltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBjbG91ZGZyb250ID0gcmVxdWlyZSgnLi4vbGliJyk7XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKHByb2Nlc3MuYXJndik7XG5cbmNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjayhhcHAsICdhd3MtY2RrLWNsb3VkZnJvbnQnKTtcblxuY29uc3Qgc291cmNlQnVja2V0ID0gbmV3IHMzLkJ1Y2tldChzdGFjaywgJ0J1Y2tldCcpO1xuXG5uZXcgY2xvdWRmcm9udC5DbG91ZEZyb250V2ViRGlzdHJpYnV0aW9uKHN0YWNrLCAnTXlEaXN0cmlidXRpb24nLCB7XG4gICAgb3JpZ2luQ29uZmlnczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBzM09yaWdpblNvdXJjZToge1xuICAgICAgICAgICAgICAgIHMzQnVja2V0U291cmNlOiBzb3VyY2VCdWNrZXRcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBiZWhhdmlvcnMgOiBbIHtpc0RlZmF1bHRCZWhhdmlvcjogdHJ1ZX1dXG4gICAgICAgIH1cbiAgICBdXG4gfSk7XG5cbnByb2Nlc3Muc3Rkb3V0LndyaXRlKGFwcC5ydW4oKSk7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZWcuY2xvdWRmcm9udC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbImludGVnLmNsb3VkZnJvbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFDQSxzQ0FBdUM7QUFDdkMsb0NBQXFDO0FBQ3JDLHFDQUFzQztBQUV0QyxNQUFNLEdBQUcsR0FBRyxJQUFJLEdBQUcsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBRXRDLE1BQU0sS0FBSyxHQUFHLElBQUksR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsb0JBQW9CLENBQUMsQ0FBQztBQUV2RCxNQUFNLFlBQVksR0FBRyxJQUFJLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDO0FBRXBELElBQUksVUFBVSxDQUFDLHlCQUF5QixDQUFDLEtBQUssRUFBRSxnQkFBZ0IsRUFBRTtJQUNoRSxhQUFhLEVBQUU7UUFDYjtZQUNFLGNBQWMsRUFBRTtnQkFDZCxjQUFjLEVBQUUsWUFBWTthQUM3QjtZQUNELFNBQVMsRUFBRyxDQUFFLEVBQUMsaUJBQWlCLEVBQUUsSUFBSSxFQUFDLENBQUM7U0FDekM7S0FDRjtDQUNELENBQUMsQ0FBQztBQUVKLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiXG5pbXBvcnQgczMgPSByZXF1aXJlKCdAYXdzLWNkay9hd3MtczMnKTtcbmltcG9ydCBjZGsgPSByZXF1aXJlKCdAYXdzLWNkay9jZGsnKTtcbmltcG9ydCBjbG91ZGZyb250ID0gcmVxdWlyZSgnLi4vbGliJyk7XG5cbmNvbnN0IGFwcCA9IG5ldyBjZGsuQXBwKHByb2Nlc3MuYXJndik7XG5cbmNvbnN0IHN0YWNrID0gbmV3IGNkay5TdGFjayhhcHAsICdhd3MtY2RrLWNsb3VkZnJvbnQnKTtcblxuY29uc3Qgc291cmNlQnVja2V0ID0gbmV3IHMzLkJ1Y2tldChzdGFjaywgJ0J1Y2tldCcpO1xuXG5uZXcgY2xvdWRmcm9udC5DbG91ZEZyb250V2ViRGlzdHJpYnV0aW9uKHN0YWNrLCAnTXlEaXN0cmlidXRpb24nLCB7XG4gIG9yaWdpbkNvbmZpZ3M6IFtcbiAgICB7XG4gICAgICBzM09yaWdpblNvdXJjZToge1xuICAgICAgICBzM0J1Y2tldFNvdXJjZTogc291cmNlQnVja2V0XG4gICAgICB9LFxuICAgICAgYmVoYXZpb3JzIDogWyB7aXNEZWZhdWx0QmVoYXZpb3I6IHRydWV9XVxuICAgIH1cbiAgXVxuIH0pO1xuXG5wcm9jZXNzLnN0ZG91dC53cml0ZShhcHAucnVuKCkpO1xuIl19

@@ -233,2 +233,2 @@ "use strict";

};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.basic.js","sourceRoot":"","sources":["test.basic.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect } from '@aws-cdk/assert';\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { Test } from 'nodeunit';\nimport { CloudFrontWebDistribution } from '../lib';\n\n// tslint:disable:object-literal-key-quotes\n\nexport = {\n\n    'distribution with custom origin adds custom origin'(test: Test) {\n      const stack = new cdk.Stack();\n\n      new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n          originConfigs: [\n              {\n                  originHeaders: {\n                    \"X-Custom-Header\": \"somevalue\",\n                  },\n                  customOriginSource: {\n                    domainName: \"myorigin.com\",\n                  },\n                  behaviors: [\n                    {\n                      isDefaultBehavior: true,\n                    }\n                  ],\n              }\n          ]\n      });\n\n      expect(stack).toMatch(\n        {\n          \"Resources\": {\n          \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n            \"Type\": \"AWS::CloudFront::Distribution\",\n            \"Properties\": {\n              \"DistributionConfig\": {\n                \"CacheBehaviors\": [],\n                \"DefaultCacheBehavior\": {\n                  \"AllowedMethods\": [\n                    \"GET\",\n                    \"HEAD\"\n                  ],\n                  \"CachedMethods\": [\n                    \"GET\",\n                    \"HEAD\"\n                  ],\n                  \"ForwardedValues\": {\n                    \"Cookies\": {\n                      \"Forward\": \"none\"\n                    },\n                    \"QueryString\": false\n                  },\n                  \"TargetOriginId\": \"origin1\",\n                  \"ViewerProtocolPolicy\": \"redirect-to-https\"\n                },\n                \"DefaultRootObject\": \"index.html\",\n                \"Enabled\": true,\n                \"HttpVersion\": \"http2\",\n                \"IPV6Enabled\": true,\n                \"Origins\": [\n                  {\n                    \"CustomOriginConfig\": {\n                      \"HTTPPort\": 80,\n                      \"HTTPSPort\": 443,\n                      \"OriginKeepaliveTimeout\": 5,\n                      \"OriginProtocolPolicy\": \"https-only\",\n                      \"OriginReadTimeout\": 30,\n                      \"OriginSSLProtocols\": [\n                        \"TLSv1.2\"\n                      ]\n                    },\n                    \"DomainName\": \"myorigin.com\",\n                    \"Id\": \"origin1\",\n                    \"OriginCustomHeaders\": [\n                      {\n                        \"HeaderName\": \"X-Custom-Header\",\n                        \"HeaderValue\": \"somevalue\"\n                      }\n                    ]\n                  }\n                ],\n                \"PriceClass\": \"PriceClass_100\",\n                \"ViewerCertificate\": {\n                  \"CloudFrontDefaultCertificate\": true\n                }\n              }\n            }\n          }\n        }\n      }\n      );\n\n      test.done();\n    },\n\n    'most basic distribution'(test: Test) {\n        const stack = new cdk.Stack();\n        const sourceBucket = new s3.Bucket(stack, 'Bucket');\n\n        new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n            originConfigs: [\n                {\n                    s3OriginSource: {\n                        s3BucketSource: sourceBucket\n                    },\n                    behaviors: [\n                        {\n                            isDefaultBehavior: true,\n                        }\n                    ]\n                }\n            ]\n        });\n\n        expect(stack).toMatch({\n            \"Resources\": {\n              \"Bucket83908E77\": {\n                \"Type\": \"AWS::S3::Bucket\"\n              },\n              \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n                \"Type\": \"AWS::CloudFront::Distribution\",\n                \"Properties\": {\n                  \"DistributionConfig\": {\n                    \"DefaultRootObject\": \"index.html\",\n                    \"Origins\": [\n                      {\n                        \"DomainName\": {\n                          \"Fn::GetAtt\": [\n                            \"Bucket83908E77\",\n                            \"DomainName\"\n                          ]\n                        },\n                        \"Id\": \"origin1\",\n                        \"S3OriginConfig\": {}\n                      }\n                    ],\n                    \"ViewerCertificate\": {\n                      \"CloudFrontDefaultCertificate\": true\n                    },\n                    \"PriceClass\": \"PriceClass_100\",\n                    \"DefaultCacheBehavior\": {\n                      \"AllowedMethods\": [\n                        \"GET\",\n                        \"HEAD\"\n                      ],\n                      \"CachedMethods\": [\n                        \"GET\",\n                        \"HEAD\"\n                      ],\n                      \"TargetOriginId\": \"origin1\",\n                      \"ViewerProtocolPolicy\": \"redirect-to-https\",\n                      \"ForwardedValues\": {\n                        \"QueryString\": false,\n                        \"Cookies\" : { \"Forward\" : \"none\"}\n                      }\n                    },\n                    \"Enabled\": true,\n                    \"IPV6Enabled\": true,\n                    \"HttpVersion\": \"http2\",\n                    \"CacheBehaviors\": []\n                  }\n                }\n              }\n            }\n          });\n        test.done();\n    },\n\n    'distribution with trusted signers on default distribution'(test: Test) {\n        const stack = new cdk.Stack();\n        const sourceBucket = new s3.Bucket(stack, 'Bucket');\n\n        new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n            originConfigs: [\n                {\n                    s3OriginSource: {\n                        s3BucketSource: sourceBucket\n                    },\n                    behaviors: [\n                        {\n                            isDefaultBehavior: true,\n                            trustedSigners: [ \"1234\" ],\n                        },\n                    ]\n                }\n            ]\n        });\n\n        expect(stack).toMatch({\n            \"Resources\": {\n              \"Bucket83908E77\": {\n                \"Type\": \"AWS::S3::Bucket\"\n              },\n              \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n                \"Type\": \"AWS::CloudFront::Distribution\",\n                \"Properties\": {\n                  \"DistributionConfig\": {\n                    \"DefaultRootObject\": \"index.html\",\n                    \"Origins\": [\n                      {\n                        \"DomainName\": {\n                          \"Fn::GetAtt\": [\n                            \"Bucket83908E77\",\n                            \"DomainName\"\n                          ]\n                        },\n                        \"Id\": \"origin1\",\n                        \"S3OriginConfig\": {}\n                      }\n                    ],\n                    \"ViewerCertificate\": {\n                      \"CloudFrontDefaultCertificate\": true\n                    },\n                    \"PriceClass\": \"PriceClass_100\",\n                    \"DefaultCacheBehavior\": {\n                      \"AllowedMethods\": [\n                        \"GET\",\n                        \"HEAD\"\n                      ],\n                      \"CachedMethods\": [\n                        \"GET\",\n                        \"HEAD\"\n                      ],\n                      \"TargetOriginId\": \"origin1\",\n                      \"ViewerProtocolPolicy\": \"redirect-to-https\",\n                      \"ForwardedValues\": {\n                        \"QueryString\": false,\n                        \"Cookies\" : { \"Forward\" : \"none\"}\n                      },\n                      \"TrustedSigners\" : [\n                          \"1234\"\n                      ]\n                    },\n                    \"Enabled\": true,\n                    \"IPV6Enabled\": true,\n                    \"HttpVersion\": \"http2\",\n                    \"CacheBehaviors\": []\n                  }\n                }\n              }\n            }\n          });\n        test.done();\n    },\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"test.basic.js","sourceRoot":"","sources":["test.basic.ts"],"names":[],"mappings":"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","sourcesContent":["import { expect } from '@aws-cdk/assert';\nimport s3 = require('@aws-cdk/aws-s3');\nimport cdk = require('@aws-cdk/cdk');\nimport { Test } from 'nodeunit';\nimport { CloudFrontWebDistribution } from '../lib';\n\n// tslint:disable:object-literal-key-quotes\n\nexport = {\n\n  'distribution with custom origin adds custom origin'(test: Test) {\n    const stack = new cdk.Stack();\n\n    new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n      originConfigs: [\n        {\n          originHeaders: {\n          \"X-Custom-Header\": \"somevalue\",\n          },\n          customOriginSource: {\n          domainName: \"myorigin.com\",\n          },\n          behaviors: [\n          {\n            isDefaultBehavior: true,\n          }\n          ],\n        }\n      ]\n    });\n\n    expect(stack).toMatch(\n    {\n      \"Resources\": {\n      \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n      \"Type\": \"AWS::CloudFront::Distribution\",\n      \"Properties\": {\n        \"DistributionConfig\": {\n        \"CacheBehaviors\": [],\n        \"DefaultCacheBehavior\": {\n          \"AllowedMethods\": [\n          \"GET\",\n          \"HEAD\"\n          ],\n          \"CachedMethods\": [\n          \"GET\",\n          \"HEAD\"\n          ],\n          \"ForwardedValues\": {\n          \"Cookies\": {\n            \"Forward\": \"none\"\n          },\n          \"QueryString\": false\n          },\n          \"TargetOriginId\": \"origin1\",\n          \"ViewerProtocolPolicy\": \"redirect-to-https\"\n        },\n        \"DefaultRootObject\": \"index.html\",\n        \"Enabled\": true,\n        \"HttpVersion\": \"http2\",\n        \"IPV6Enabled\": true,\n        \"Origins\": [\n          {\n          \"CustomOriginConfig\": {\n            \"HTTPPort\": 80,\n            \"HTTPSPort\": 443,\n            \"OriginKeepaliveTimeout\": 5,\n            \"OriginProtocolPolicy\": \"https-only\",\n            \"OriginReadTimeout\": 30,\n            \"OriginSSLProtocols\": [\n            \"TLSv1.2\"\n            ]\n          },\n          \"DomainName\": \"myorigin.com\",\n          \"Id\": \"origin1\",\n          \"OriginCustomHeaders\": [\n            {\n            \"HeaderName\": \"X-Custom-Header\",\n            \"HeaderValue\": \"somevalue\"\n            }\n          ]\n          }\n        ],\n        \"PriceClass\": \"PriceClass_100\",\n        \"ViewerCertificate\": {\n          \"CloudFrontDefaultCertificate\": true\n        }\n        }\n      }\n      }\n    }\n    }\n    );\n\n    test.done();\n  },\n\n  'most basic distribution'(test: Test) {\n    const stack = new cdk.Stack();\n    const sourceBucket = new s3.Bucket(stack, 'Bucket');\n\n    new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n      originConfigs: [\n        {\n          s3OriginSource: {\n            s3BucketSource: sourceBucket\n          },\n          behaviors: [\n            {\n              isDefaultBehavior: true,\n            }\n          ]\n        }\n      ]\n    });\n\n    expect(stack).toMatch({\n      \"Resources\": {\n        \"Bucket83908E77\": {\n        \"Type\": \"AWS::S3::Bucket\"\n        },\n        \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n        \"Type\": \"AWS::CloudFront::Distribution\",\n        \"Properties\": {\n          \"DistributionConfig\": {\n          \"DefaultRootObject\": \"index.html\",\n          \"Origins\": [\n            {\n            \"DomainName\": {\n              \"Fn::GetAtt\": [\n              \"Bucket83908E77\",\n              \"DomainName\"\n              ]\n            },\n            \"Id\": \"origin1\",\n            \"S3OriginConfig\": {}\n            }\n          ],\n          \"ViewerCertificate\": {\n            \"CloudFrontDefaultCertificate\": true\n          },\n          \"PriceClass\": \"PriceClass_100\",\n          \"DefaultCacheBehavior\": {\n            \"AllowedMethods\": [\n            \"GET\",\n            \"HEAD\"\n            ],\n            \"CachedMethods\": [\n            \"GET\",\n            \"HEAD\"\n            ],\n            \"TargetOriginId\": \"origin1\",\n            \"ViewerProtocolPolicy\": \"redirect-to-https\",\n            \"ForwardedValues\": {\n            \"QueryString\": false,\n            \"Cookies\" : { \"Forward\" : \"none\"}\n            }\n          },\n          \"Enabled\": true,\n          \"IPV6Enabled\": true,\n          \"HttpVersion\": \"http2\",\n          \"CacheBehaviors\": []\n          }\n        }\n        }\n      }\n      });\n    test.done();\n  },\n\n  'distribution with trusted signers on default distribution'(test: Test) {\n    const stack = new cdk.Stack();\n    const sourceBucket = new s3.Bucket(stack, 'Bucket');\n\n    new CloudFrontWebDistribution(stack, 'AnAmazingWebsiteProbably', {\n      originConfigs: [\n        {\n          s3OriginSource: {\n            s3BucketSource: sourceBucket\n          },\n          behaviors: [\n            {\n              isDefaultBehavior: true,\n              trustedSigners: [ \"1234\" ],\n            },\n          ]\n        }\n      ]\n    });\n\n    expect(stack).toMatch({\n      \"Resources\": {\n        \"Bucket83908E77\": {\n        \"Type\": \"AWS::S3::Bucket\"\n        },\n        \"AnAmazingWebsiteProbablyCFDistribution47E3983B\": {\n        \"Type\": \"AWS::CloudFront::Distribution\",\n        \"Properties\": {\n          \"DistributionConfig\": {\n          \"DefaultRootObject\": \"index.html\",\n          \"Origins\": [\n            {\n            \"DomainName\": {\n              \"Fn::GetAtt\": [\n              \"Bucket83908E77\",\n              \"DomainName\"\n              ]\n            },\n            \"Id\": \"origin1\",\n            \"S3OriginConfig\": {}\n            }\n          ],\n          \"ViewerCertificate\": {\n            \"CloudFrontDefaultCertificate\": true\n          },\n          \"PriceClass\": \"PriceClass_100\",\n          \"DefaultCacheBehavior\": {\n            \"AllowedMethods\": [\n            \"GET\",\n            \"HEAD\"\n            ],\n            \"CachedMethods\": [\n            \"GET\",\n            \"HEAD\"\n            ],\n            \"TargetOriginId\": \"origin1\",\n            \"ViewerProtocolPolicy\": \"redirect-to-https\",\n            \"ForwardedValues\": {\n            \"QueryString\": false,\n            \"Cookies\" : { \"Forward\" : \"none\"}\n            },\n            \"TrustedSigners\" : [\n              \"1234\"\n            ]\n          },\n          \"Enabled\": true,\n          \"IPV6Enabled\": true,\n          \"HttpVersion\": \"http2\",\n          \"CacheBehaviors\": []\n          }\n        }\n        }\n      }\n      });\n    test.done();\n  },\n};\n"]}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc