UNPKG

32.8 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c, _d;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.CacheQueryStringBehavior = exports.CacheHeaderBehavior = exports.CacheCookieBehavior = exports.CachePolicy = void 0;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const core_1 = require("@aws-cdk/core");
8const cloudfront_generated_1 = require("./cloudfront.generated");
9/**
10 * A Cache Policy configuration.
11 *
12 * @resource AWS::CloudFront::CachePolicy
13 * @link https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/using-managed-cache-policies.html
14 */
15class CachePolicy extends core_1.Resource {
16 constructor(scope, id, props = {}) {
17 var _e, _f, _g, _h;
18 super(scope, id, {
19 physicalName: props.cachePolicyName,
20 });
21 try {
22 jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_CachePolicyProps(props);
23 }
24 catch (error) {
25 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
26 Error.captureStackTrace(error, this.constructor);
27 }
28 throw error;
29 }
30 const cachePolicyName = (_e = props.cachePolicyName) !== null && _e !== void 0 ? _e : `${core_1.Names.uniqueId(this).slice(0, 110)}-${core_1.Stack.of(this).region}`;
31 if (!core_1.Token.isUnresolved(cachePolicyName) && !cachePolicyName.match(/^[\w-]+$/i)) {
32 throw new Error(`'cachePolicyName' can only include '-', '_', and alphanumeric characters, got: '${cachePolicyName}'`);
33 }
34 if (cachePolicyName.length > 128) {
35 throw new Error(`'cachePolicyName' cannot be longer than 128 characters, got: '${cachePolicyName.length}'`);
36 }
37 const minTtl = ((_f = props.minTtl) !== null && _f !== void 0 ? _f : core_1.Duration.seconds(0)).toSeconds();
38 const defaultTtl = Math.max(((_g = props.defaultTtl) !== null && _g !== void 0 ? _g : core_1.Duration.days(1)).toSeconds(), minTtl);
39 const maxTtl = Math.max(((_h = props.maxTtl) !== null && _h !== void 0 ? _h : core_1.Duration.days(365)).toSeconds(), defaultTtl);
40 const resource = new cloudfront_generated_1.CfnCachePolicy(this, 'Resource', {
41 cachePolicyConfig: {
42 name: cachePolicyName,
43 comment: props.comment,
44 minTtl,
45 maxTtl,
46 defaultTtl,
47 parametersInCacheKeyAndForwardedToOrigin: this.renderCacheKey(props),
48 },
49 });
50 this.cachePolicyId = resource.ref;
51 }
52 /** Imports a Cache Policy from its id. */
53 static fromCachePolicyId(scope, id, cachePolicyId) {
54 return new class extends core_1.Resource {
55 constructor() {
56 super(...arguments);
57 this.cachePolicyId = cachePolicyId;
58 }
59 }(scope, id);
60 }
61 /** Use an existing managed cache policy. */
62 static fromManagedCachePolicy(managedCachePolicyId) {
63 return new class {
64 constructor() {
65 this.cachePolicyId = managedCachePolicyId;
66 }
67 }();
68 }
69 renderCacheKey(props) {
70 var _e, _f, _g, _h, _j;
71 const cookies = (_e = props.cookieBehavior) !== null && _e !== void 0 ? _e : CacheCookieBehavior.none();
72 const headers = (_f = props.headerBehavior) !== null && _f !== void 0 ? _f : CacheHeaderBehavior.none();
73 const queryStrings = (_g = props.queryStringBehavior) !== null && _g !== void 0 ? _g : CacheQueryStringBehavior.none();
74 return {
75 cookiesConfig: {
76 cookieBehavior: cookies.behavior,
77 cookies: cookies.cookies,
78 },
79 headersConfig: {
80 headerBehavior: headers.behavior,
81 headers: headers.headers,
82 },
83 enableAcceptEncodingGzip: (_h = props.enableAcceptEncodingGzip) !== null && _h !== void 0 ? _h : false,
84 enableAcceptEncodingBrotli: (_j = props.enableAcceptEncodingBrotli) !== null && _j !== void 0 ? _j : false,
85 queryStringsConfig: {
86 queryStringBehavior: queryStrings.behavior,
87 queryStrings: queryStrings.queryStrings,
88 },
89 };
90 }
91}
92exports.CachePolicy = CachePolicy;
93_a = JSII_RTTI_SYMBOL_1;
94CachePolicy[_a] = { fqn: "@aws-cdk/aws-cloudfront.CachePolicy", version: "1.157.0" };
95/**
96 * This policy is designed for use with an origin that is an AWS Amplify web app.
97 */
98CachePolicy.AMPLIFY = CachePolicy.fromManagedCachePolicy('2e54312d-136d-493c-8eb9-b001f22f67d2');
99/**
100 * Optimize cache efficiency by minimizing the values that CloudFront includes in the cache key.
101 * Query strings and cookies are not included in the cache key, and only the normalized 'Accept-Encoding' header is included.
102 */
103CachePolicy.CACHING_OPTIMIZED = CachePolicy.fromManagedCachePolicy('658327ea-f89d-4fab-a63d-7e88639e58f6');
104/**
105 * Optimize cache efficiency by minimizing the values that CloudFront includes in the cache key.
106 * Query strings and cookies are not included in the cache key, and only the normalized 'Accept-Encoding' header is included.
107 * Disables cache compression.
108 */
109CachePolicy.CACHING_OPTIMIZED_FOR_UNCOMPRESSED_OBJECTS = CachePolicy.fromManagedCachePolicy('b2884449-e4de-46a7-ac36-70bc7f1ddd6d');
110/** Disables caching. This policy is useful for dynamic content and for requests that are not cacheable. */
111CachePolicy.CACHING_DISABLED = CachePolicy.fromManagedCachePolicy('4135ea2d-6df8-44a3-9df3-4b5a84be39ad');
112/** Designed for use with an origin that is an AWS Elemental MediaPackage endpoint. */
113CachePolicy.ELEMENTAL_MEDIA_PACKAGE = CachePolicy.fromManagedCachePolicy('08627262-05a9-4f76-9ded-b50ca2e3a84f');
114/**
115 * Determines whether any cookies in viewer requests are included in the cache key and
116 * automatically included in requests that CloudFront sends to the origin.
117 */
118class CacheCookieBehavior {
119 constructor(behavior, cookies) {
120 this.behavior = behavior;
121 this.cookies = cookies;
122 }
123 /**
124 * Cookies in viewer requests are not included in the cache key and
125 * are not automatically included in requests that CloudFront sends to the origin.
126 */
127 static none() { return new CacheCookieBehavior('none'); }
128 /**
129 * All cookies in viewer requests are included in the cache key and are automatically included in requests that CloudFront sends to the origin.
130 */
131 static all() { return new CacheCookieBehavior('all'); }
132 /**
133 * Only the provided `cookies` are included in the cache key and automatically included in requests that CloudFront sends to the origin.
134 */
135 static allowList(...cookies) {
136 if (cookies.length === 0) {
137 throw new Error('At least one cookie to allow must be provided');
138 }
139 return new CacheCookieBehavior('whitelist', cookies);
140 }
141 /**
142 * All cookies except the provided `cookies` are included in the cache key and
143 * automatically included in requests that CloudFront sends to the origin.
144 */
145 static denyList(...cookies) {
146 if (cookies.length === 0) {
147 throw new Error('At least one cookie to deny must be provided');
148 }
149 return new CacheCookieBehavior('allExcept', cookies);
150 }
151}
152exports.CacheCookieBehavior = CacheCookieBehavior;
153_b = JSII_RTTI_SYMBOL_1;
154CacheCookieBehavior[_b] = { fqn: "@aws-cdk/aws-cloudfront.CacheCookieBehavior", version: "1.157.0" };
155/**
156 * Determines whether any HTTP headers are included in the cache key and automatically included in requests that CloudFront sends to the origin.
157 */
158class CacheHeaderBehavior {
159 constructor(behavior, headers) {
160 this.behavior = behavior;
161 this.headers = headers;
162 }
163 /** HTTP headers are not included in the cache key and are not automatically included in requests that CloudFront sends to the origin. */
164 static none() { return new CacheHeaderBehavior('none'); }
165 /** Listed headers are included in the cache key and are automatically included in requests that CloudFront sends to the origin. */
166 static allowList(...headers) {
167 if (headers.length === 0) {
168 throw new Error('At least one header to allow must be provided');
169 }
170 return new CacheHeaderBehavior('whitelist', headers);
171 }
172}
173exports.CacheHeaderBehavior = CacheHeaderBehavior;
174_c = JSII_RTTI_SYMBOL_1;
175CacheHeaderBehavior[_c] = { fqn: "@aws-cdk/aws-cloudfront.CacheHeaderBehavior", version: "1.157.0" };
176/**
177 * Determines whether any URL query strings in viewer requests are included in the cache key
178 * and automatically included in requests that CloudFront sends to the origin.
179 */
180class CacheQueryStringBehavior {
181 constructor(behavior, queryStrings) {
182 this.behavior = behavior;
183 this.queryStrings = queryStrings;
184 }
185 /**
186 * Query strings in viewer requests are not included in the cache key and
187 * are not automatically included in requests that CloudFront sends to the origin.
188 */
189 static none() { return new CacheQueryStringBehavior('none'); }
190 /**
191 * All query strings in viewer requests are included in the cache key and are automatically included in requests that CloudFront sends to the origin.
192 */
193 static all() { return new CacheQueryStringBehavior('all'); }
194 /**
195 * Only the provided `queryStrings` are included in the cache key and automatically included in requests that CloudFront sends to the origin.
196 */
197 static allowList(...queryStrings) {
198 if (queryStrings.length === 0) {
199 throw new Error('At least one query string to allow must be provided');
200 }
201 return new CacheQueryStringBehavior('whitelist', queryStrings);
202 }
203 /**
204 * All query strings except the provided `queryStrings` are included in the cache key and
205 * automatically included in requests that CloudFront sends to the origin.
206 */
207 static denyList(...queryStrings) {
208 if (queryStrings.length === 0) {
209 throw new Error('At least one query string to deny must be provided');
210 }
211 return new CacheQueryStringBehavior('allExcept', queryStrings);
212 }
213}
214exports.CacheQueryStringBehavior = CacheQueryStringBehavior;
215_d = JSII_RTTI_SYMBOL_1;
216CacheQueryStringBehavior[_d] = { fqn: "@aws-cdk/aws-cloudfront.CacheQueryStringBehavior", version: "1.157.0" };
217//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cache-policy.js","sourceRoot":"","sources":["cache-policy.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAwE;AAExE,iEAAwD;AAiFxD;;;;;GAKG;AACH,MAAa,WAAY,SAAQ,eAAQ;IAqCvC,YAAY,KAAgB,EAAE,EAAU,EAAE,QAA0B,EAAE;;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,CAAC,eAAe;SACpC,CAAC,CAAC;;;;;;;;;;QAEH,MAAM,eAAe,SAAG,KAAK,CAAC,eAAe,mCAAI,GAAG,YAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,YAAK,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;QAElH,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE;YAC/E,MAAM,IAAI,KAAK,CAAC,mFAAmF,eAAe,GAAG,CAAC,CAAC;SACxH;QAED,IAAI,eAAe,CAAC,MAAM,GAAG,GAAG,EAAE;YAChC,MAAM,IAAI,KAAK,CAAC,iEAAiE,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;SAC7G;QAED,MAAM,MAAM,GAAG,OAAC,KAAK,CAAC,MAAM,mCAAI,eAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;QACjE,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,OAAC,KAAK,CAAC,UAAU,mCAAI,eAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,EAAE,MAAM,CAAC,CAAC;QACxF,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAC,KAAK,CAAC,MAAM,mCAAI,eAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,EAAE,UAAU,CAAC,CAAC;QAEtF,MAAM,QAAQ,GAAG,IAAI,qCAAc,CAAC,IAAI,EAAE,UAAU,EAAE;YACpD,iBAAiB,EAAE;gBACjB,IAAI,EAAE,eAAe;gBACrB,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,MAAM;gBACN,MAAM;gBACN,UAAU;gBACV,wCAAwC,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;aACrE;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,GAAG,CAAC;KACnC;IA/CD,0CAA0C;IACnC,MAAM,CAAC,iBAAiB,CAAC,KAAgB,EAAE,EAAU,EAAE,aAAqB;QACjF,OAAO,IAAI,KAAM,SAAQ,eAAQ;YAAtB;;gBACO,kBAAa,GAAG,aAAa,CAAC;YAChD,CAAC;SAAA,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KACd;IAED,4CAA4C;IACpC,MAAM,CAAC,sBAAsB,CAAC,oBAA4B;QAChE,OAAO,IAAI;YAAA;gBACO,kBAAa,GAAG,oBAAoB,CAAC;YACvD,CAAC;SAAA,EAAE,CAAC;KACL;IAqCO,cAAc,CAAC,KAAuB;;QAC5C,MAAM,OAAO,SAAG,KAAK,CAAC,cAAc,mCAAI,mBAAmB,CAAC,IAAI,EAAE,CAAC;QACnE,MAAM,OAAO,SAAG,KAAK,CAAC,cAAc,mCAAI,mBAAmB,CAAC,IAAI,EAAE,CAAC;QACnE,MAAM,YAAY,SAAG,KAAK,CAAC,mBAAmB,mCAAI,wBAAwB,CAAC,IAAI,EAAE,CAAC;QAElF,OAAO;YACL,aAAa,EAAE;gBACb,cAAc,EAAE,OAAO,CAAC,QAAQ;gBAChC,OAAO,EAAE,OAAO,CAAC,OAAO;aACzB;YACD,aAAa,EAAE;gBACb,cAAc,EAAE,OAAO,CAAC,QAAQ;gBAChC,OAAO,EAAE,OAAO,CAAC,OAAO;aACzB;YACD,wBAAwB,QAAE,KAAK,CAAC,wBAAwB,mCAAI,KAAK;YACjE,0BAA0B,QAAE,KAAK,CAAC,0BAA0B,mCAAI,KAAK;YACrE,kBAAkB,EAAE;gBAClB,mBAAmB,EAAE,YAAY,CAAC,QAAQ;gBAC1C,YAAY,EAAE,YAAY,CAAC,YAAY;aACxC;SACF,CAAC;KACH;;AA3FH,kCA4FC;;;AA3FC;;GAEG;AACoB,mBAAO,GAAG,WAAW,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC;AAC5G;;;GAGG;AACoB,6BAAiB,GAAG,WAAW,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC;AACtH;;;;GAIG;AACoB,sDAA0C,GAAG,WAAW,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC;AAC/I,2GAA2G;AACpF,4BAAgB,GAAG,WAAW,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC;AACrH,sFAAsF;AAC/D,mCAAuB,GAAG,WAAW,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC;AA2E9H;;;GAGG;AACH,MAAa,mBAAmB;IAsC9B,YAAoB,QAAgB,EAAE,OAAkB;QACtD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;KACxB;IAxCD;;;OAGG;IACI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,mBAAmB,CAAC,MAAM,CAAC,CAAC,EAAE;IAEhE;;OAEG;IACI,MAAM,CAAC,GAAG,KAAK,OAAO,IAAI,mBAAmB,CAAC,KAAK,CAAC,CAAC,EAAE;IAE9D;;OAEG;IACI,MAAM,CAAC,SAAS,CAAC,GAAG,OAAiB;QAC1C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QACD,OAAO,IAAI,mBAAmB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;KACtD;IAED;;;OAGG;IACI,MAAM,CAAC,QAAQ,CAAC,GAAG,OAAiB;QACzC,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,8CAA8C,CAAC,CAAC;SACjE;QACD,OAAO,IAAI,mBAAmB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;KACtD;;AA/BH,kDA0CC;;;AAED;;GAEG;AACH,MAAa,mBAAmB;IAgB9B,YAAoB,QAAgB,EAAE,OAAkB;QACtD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;KACxB;IAlBD,yIAAyI;IAClI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,mBAAmB,CAAC,MAAM,CAAC,CAAC,EAAE;IAChE,mIAAmI;IAC5H,MAAM,CAAC,SAAS,CAAC,GAAG,OAAiB;QAC1C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;SAClE;QACD,OAAO,IAAI,mBAAmB,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;KACtD;;AATH,kDAoBC;;;AAED;;;GAGG;AACH,MAAa,wBAAwB;IAsCnC,YAAoB,QAAgB,EAAE,YAAuB;QAC3D,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;KAClC;IAxCD;;;OAGG;IACI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,wBAAwB,CAAC,MAAM,CAAC,CAAC,EAAE;IAErE;;OAEG;IACI,MAAM,CAAC,GAAG,KAAK,OAAO,IAAI,wBAAwB,CAAC,KAAK,CAAC,CAAC,EAAE;IAEnE;;OAEG;IACI,MAAM,CAAC,SAAS,CAAC,GAAG,YAAsB;QAC/C,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,qDAAqD,CAAC,CAAC;SACxE;QACD,OAAO,IAAI,wBAAwB,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;KAChE;IAED;;;OAGG;IACI,MAAM,CAAC,QAAQ,CAAC,GAAG,YAAsB;QAC9C,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE;YAC7B,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;SACvE;QACD,OAAO,IAAI,wBAAwB,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;KAChE;;AA/BH,4DA0CC","sourcesContent":["import { Duration, Names, Resource, Stack, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnCachePolicy } from './cloudfront.generated';\n\n/**\n * Represents a Cache Policy\n */\nexport interface ICachePolicy {\n  /**\n   * The ID of the cache policy\n   * @attribute\n   */\n  readonly cachePolicyId: string;\n}\n\n/**\n * Properties for creating a Cache Policy\n */\nexport interface CachePolicyProps {\n  /**\n   * A unique name to identify the cache policy.\n   * The name must only include '-', '_', or alphanumeric characters.\n   * @default - generated from the `id`\n   */\n  readonly cachePolicyName?: string;\n\n  /**\n   * A comment to describe the cache policy.\n   * @default - no comment\n   */\n  readonly comment?: string;\n\n  /**\n   * The default amount of time for objects to stay in the CloudFront cache.\n   * Only used when the origin does not send Cache-Control or Expires headers with the object.\n   * @default - The greater of 1 day and ``minTtl``\n   */\n  readonly defaultTtl?: Duration;\n\n  /**\n   * The minimum amount of time for objects to stay in the CloudFront cache.\n   * @default Duration.seconds(0)\n   */\n  readonly minTtl?: Duration;\n\n  /**\n   * The maximum amount of time for objects to stay in the CloudFront cache.\n   * CloudFront uses this value only when the origin sends Cache-Control or Expires headers with the object.\n   * @default - The greater of 1 year and ``defaultTtl``\n   */\n  readonly maxTtl?: Duration;\n\n  /**\n   * Determines whether any cookies in viewer requests are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n   * @default CacheCookieBehavior.none()\n   */\n  readonly cookieBehavior?: CacheCookieBehavior;\n\n  /**\n   * Determines whether any HTTP headers are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n   * @default CacheHeaderBehavior.none()\n   */\n  readonly headerBehavior?: CacheHeaderBehavior;\n\n  /**\n   * Determines whether any query strings are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n   * @default CacheQueryStringBehavior.none()\n   */\n  readonly queryStringBehavior?: CacheQueryStringBehavior;\n\n  /**\n   * Whether to normalize and include the `Accept-Encoding` header in the cache key when the `Accept-Encoding` header is 'gzip'.\n   * @default false\n   */\n  readonly enableAcceptEncodingGzip?: boolean;\n\n  /**\n   * Whether to normalize and include the `Accept-Encoding` header in the cache key when the `Accept-Encoding` header is 'br'.\n   * @default false\n   */\n  readonly enableAcceptEncodingBrotli?: boolean;\n}\n\n/**\n * A Cache Policy configuration.\n *\n * @resource AWS::CloudFront::CachePolicy\n * @link https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/using-managed-cache-policies.html\n */\nexport class CachePolicy extends Resource implements ICachePolicy {\n  /**\n   * This policy is designed for use with an origin that is an AWS Amplify web app.\n   */\n  public static readonly AMPLIFY = CachePolicy.fromManagedCachePolicy('2e54312d-136d-493c-8eb9-b001f22f67d2');\n  /**\n   * Optimize cache efficiency by minimizing the values that CloudFront includes in the cache key.\n   * Query strings and cookies are not included in the cache key, and only the normalized 'Accept-Encoding' header is included.\n   */\n  public static readonly CACHING_OPTIMIZED = CachePolicy.fromManagedCachePolicy('658327ea-f89d-4fab-a63d-7e88639e58f6');\n  /**\n   * Optimize cache efficiency by minimizing the values that CloudFront includes in the cache key.\n   * Query strings and cookies are not included in the cache key, and only the normalized 'Accept-Encoding' header is included.\n   * Disables cache compression.\n   */\n  public static readonly CACHING_OPTIMIZED_FOR_UNCOMPRESSED_OBJECTS = CachePolicy.fromManagedCachePolicy('b2884449-e4de-46a7-ac36-70bc7f1ddd6d');\n  /** Disables caching. This policy is useful for dynamic content and for requests that are not cacheable. */\n  public static readonly CACHING_DISABLED = CachePolicy.fromManagedCachePolicy('4135ea2d-6df8-44a3-9df3-4b5a84be39ad');\n  /** Designed for use with an origin that is an AWS Elemental MediaPackage endpoint. */\n  public static readonly ELEMENTAL_MEDIA_PACKAGE = CachePolicy.fromManagedCachePolicy('08627262-05a9-4f76-9ded-b50ca2e3a84f');\n\n  /** Imports a Cache Policy from its id. */\n  public static fromCachePolicyId(scope: Construct, id: string, cachePolicyId: string): ICachePolicy {\n    return new class extends Resource implements ICachePolicy {\n      public readonly cachePolicyId = cachePolicyId;\n    }(scope, id);\n  }\n\n  /** Use an existing managed cache policy. */\n  private static fromManagedCachePolicy(managedCachePolicyId: string): ICachePolicy {\n    return new class implements ICachePolicy {\n      public readonly cachePolicyId = managedCachePolicyId;\n    }();\n  }\n\n  public readonly cachePolicyId: string;\n\n  constructor(scope: Construct, id: string, props: CachePolicyProps = {}) {\n    super(scope, id, {\n      physicalName: props.cachePolicyName,\n    });\n\n    const cachePolicyName = props.cachePolicyName ?? `${Names.uniqueId(this).slice(0, 110)}-${Stack.of(this).region}`;\n\n    if (!Token.isUnresolved(cachePolicyName) && !cachePolicyName.match(/^[\\w-]+$/i)) {\n      throw new Error(`'cachePolicyName' can only include '-', '_', and alphanumeric characters, got: '${cachePolicyName}'`);\n    }\n\n    if (cachePolicyName.length > 128) {\n      throw new Error(`'cachePolicyName' cannot be longer than 128 characters, got: '${cachePolicyName.length}'`);\n    }\n\n    const minTtl = (props.minTtl ?? Duration.seconds(0)).toSeconds();\n    const defaultTtl = Math.max((props.defaultTtl ?? Duration.days(1)).toSeconds(), minTtl);\n    const maxTtl = Math.max((props.maxTtl ?? Duration.days(365)).toSeconds(), defaultTtl);\n\n    const resource = new CfnCachePolicy(this, 'Resource', {\n      cachePolicyConfig: {\n        name: cachePolicyName,\n        comment: props.comment,\n        minTtl,\n        maxTtl,\n        defaultTtl,\n        parametersInCacheKeyAndForwardedToOrigin: this.renderCacheKey(props),\n      },\n    });\n\n    this.cachePolicyId = resource.ref;\n  }\n\n  private renderCacheKey(props: CachePolicyProps): CfnCachePolicy.ParametersInCacheKeyAndForwardedToOriginProperty {\n    const cookies = props.cookieBehavior ?? CacheCookieBehavior.none();\n    const headers = props.headerBehavior ?? CacheHeaderBehavior.none();\n    const queryStrings = props.queryStringBehavior ?? CacheQueryStringBehavior.none();\n\n    return {\n      cookiesConfig: {\n        cookieBehavior: cookies.behavior,\n        cookies: cookies.cookies,\n      },\n      headersConfig: {\n        headerBehavior: headers.behavior,\n        headers: headers.headers,\n      },\n      enableAcceptEncodingGzip: props.enableAcceptEncodingGzip ?? false,\n      enableAcceptEncodingBrotli: props.enableAcceptEncodingBrotli ?? false,\n      queryStringsConfig: {\n        queryStringBehavior: queryStrings.behavior,\n        queryStrings: queryStrings.queryStrings,\n      },\n    };\n  }\n}\n\n/**\n * Determines whether any cookies in viewer requests are included in the cache key and\n * automatically included in requests that CloudFront sends to the origin.\n */\nexport class CacheCookieBehavior {\n  /**\n   * Cookies in viewer requests are not included in the cache key and\n   * are not automatically included in requests that CloudFront sends to the origin.\n   */\n  public static none() { return new CacheCookieBehavior('none'); }\n\n  /**\n   * All cookies in viewer requests are included in the cache key and are automatically included in requests that CloudFront sends to the origin.\n   */\n  public static all() { return new CacheCookieBehavior('all'); }\n\n  /**\n   * Only the provided `cookies` are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n   */\n  public static allowList(...cookies: string[]) {\n    if (cookies.length === 0) {\n      throw new Error('At least one cookie to allow must be provided');\n    }\n    return new CacheCookieBehavior('whitelist', cookies);\n  }\n\n  /**\n   * All cookies except the provided `cookies` are included in the cache key and\n   * automatically included in requests that CloudFront sends to the origin.\n   */\n  public static denyList(...cookies: string[]) {\n    if (cookies.length === 0) {\n      throw new Error('At least one cookie to deny must be provided');\n    }\n    return new CacheCookieBehavior('allExcept', cookies);\n  }\n\n  /** The behavior of cookies: allow all, none, an allow list, or a deny list. */\n  public readonly behavior: string;\n  /** The cookies to allow or deny, if the behavior is an allow or deny list. */\n  public readonly cookies?: string[];\n\n  private constructor(behavior: string, cookies?: string[]) {\n    this.behavior = behavior;\n    this.cookies = cookies;\n  }\n}\n\n/**\n * Determines whether any HTTP headers are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n */\nexport class CacheHeaderBehavior {\n  /** HTTP headers are not included in the cache key and are not automatically included in requests that CloudFront sends to the origin. */\n  public static none() { return new CacheHeaderBehavior('none'); }\n  /** Listed headers are included in the cache key and are automatically included in requests that CloudFront sends to the origin. */\n  public static allowList(...headers: string[]) {\n    if (headers.length === 0) {\n      throw new Error('At least one header to allow must be provided');\n    }\n    return new CacheHeaderBehavior('whitelist', headers);\n  }\n\n  /** If no headers will be passed, or an allow list of headers. */\n  public readonly behavior: string;\n  /** The headers for the allow/deny list, if applicable. */\n  public readonly headers?: string[];\n\n  private constructor(behavior: string, headers?: string[]) {\n    this.behavior = behavior;\n    this.headers = headers;\n  }\n}\n\n/**\n * Determines whether any URL query strings in viewer requests are included in the cache key\n * and automatically included in requests that CloudFront sends to the origin.\n */\nexport class CacheQueryStringBehavior {\n  /**\n   * Query strings in viewer requests are not included in the cache key and\n   * are not automatically included in requests that CloudFront sends to the origin.\n   */\n  public static none() { return new CacheQueryStringBehavior('none'); }\n\n  /**\n   * All query strings in viewer requests are included in the cache key and are automatically included in requests that CloudFront sends to the origin.\n   */\n  public static all() { return new CacheQueryStringBehavior('all'); }\n\n  /**\n   * Only the provided `queryStrings` are included in the cache key and automatically included in requests that CloudFront sends to the origin.\n   */\n  public static allowList(...queryStrings: string[]) {\n    if (queryStrings.length === 0) {\n      throw new Error('At least one query string to allow must be provided');\n    }\n    return new CacheQueryStringBehavior('whitelist', queryStrings);\n  }\n\n  /**\n   * All query strings except the provided `queryStrings` are included in the cache key and\n   * automatically included in requests that CloudFront sends to the origin.\n   */\n  public static denyList(...queryStrings: string[]) {\n    if (queryStrings.length === 0) {\n      throw new Error('At least one query string to deny must be provided');\n    }\n    return new CacheQueryStringBehavior('allExcept', queryStrings);\n  }\n\n  /** The behavior of query strings -- allow all, none, only an allow list, or a deny list. */\n  public readonly behavior: string;\n  /** The query strings to allow or deny, if the behavior is an allow or deny list. */\n  public readonly queryStrings?: string[];\n\n  private constructor(behavior: string, queryStrings?: string[]) {\n    this.behavior = behavior;\n    this.queryStrings = queryStrings;\n  }\n}\n"]}
\No newline at end of file