UNPKG

28.7 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c, _d;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.OriginRequestQueryStringBehavior = exports.OriginRequestHeaderBehavior = exports.OriginRequestCookieBehavior = exports.OriginRequestPolicy = 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 Origin Request Policy configuration.
11 *
12 * @resource AWS::CloudFront::OriginRequestPolicy
13 */
14class OriginRequestPolicy extends core_1.Resource {
15 constructor(scope, id, props = {}) {
16 super(scope, id, {
17 physicalName: props.originRequestPolicyName,
18 });
19 try {
20 jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_OriginRequestPolicyProps(props);
21 }
22 catch (error) {
23 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
24 Error.captureStackTrace(error, OriginRequestPolicy);
25 }
26 throw error;
27 }
28 const originRequestPolicyName = props.originRequestPolicyName ?? core_1.Names.uniqueId(this);
29 if (!core_1.Token.isUnresolved(originRequestPolicyName) && !originRequestPolicyName.match(/^[\w-]+$/i)) {
30 throw new Error(`'originRequestPolicyName' can only include '-', '_', and alphanumeric characters, got: '${props.originRequestPolicyName}'`);
31 }
32 const cookies = props.cookieBehavior ?? OriginRequestCookieBehavior.none();
33 const headers = props.headerBehavior ?? OriginRequestHeaderBehavior.none();
34 const queryStrings = props.queryStringBehavior ?? OriginRequestQueryStringBehavior.none();
35 const resource = new cloudfront_generated_1.CfnOriginRequestPolicy(this, 'Resource', {
36 originRequestPolicyConfig: {
37 name: originRequestPolicyName,
38 comment: props.comment,
39 cookiesConfig: {
40 cookieBehavior: cookies.behavior,
41 cookies: cookies.cookies,
42 },
43 headersConfig: {
44 headerBehavior: headers.behavior,
45 headers: headers.headers,
46 },
47 queryStringsConfig: {
48 queryStringBehavior: queryStrings.behavior,
49 queryStrings: queryStrings.queryStrings,
50 },
51 },
52 });
53 this.originRequestPolicyId = resource.ref;
54 }
55 /** Imports a Origin Request Policy from its id. */
56 static fromOriginRequestPolicyId(scope, id, originRequestPolicyId) {
57 return new class extends core_1.Resource {
58 constructor() {
59 super(...arguments);
60 this.originRequestPolicyId = originRequestPolicyId;
61 }
62 }(scope, id);
63 }
64 /** Use an existing managed origin request policy. */
65 static fromManagedOriginRequestPolicy(managedOriginRequestPolicyId) {
66 return new class {
67 constructor() {
68 this.originRequestPolicyId = managedOriginRequestPolicyId;
69 }
70 }();
71 }
72}
73exports.OriginRequestPolicy = OriginRequestPolicy;
74_a = JSII_RTTI_SYMBOL_1;
75OriginRequestPolicy[_a] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestPolicy", version: "1.161.0" };
76/** This policy includes only the User-Agent and Referer headers. It doesn’t include any query strings or cookies. */
77OriginRequestPolicy.USER_AGENT_REFERER_HEADERS = OriginRequestPolicy.fromManagedOriginRequestPolicy('acba4595-bd28-49b8-b9fe-13317c0390fa');
78/** This policy includes the header that enables cross-origin resource sharing (CORS) requests when the origin is a custom origin. */
79OriginRequestPolicy.CORS_CUSTOM_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('59781a5b-3903-41f3-afcb-af62929ccde1');
80/** This policy includes the headers that enable cross-origin resource sharing (CORS) requests when the origin is an Amazon S3 bucket. */
81OriginRequestPolicy.CORS_S3_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('88a5eaf4-2fd4-4709-b370-b4c650ea3fcf');
82/** This policy includes all values (query strings, headers, and cookies) in the viewer request. */
83OriginRequestPolicy.ALL_VIEWER = OriginRequestPolicy.fromManagedOriginRequestPolicy('216adef6-5c7f-47e4-b989-5492eafa07d3');
84/** This policy is designed for use with an origin that is an AWS Elemental MediaTailor endpoint. */
85OriginRequestPolicy.ELEMENTAL_MEDIA_TAILOR = OriginRequestPolicy.fromManagedOriginRequestPolicy('775133bc-15f2-49f9-abea-afb2e0bf67d2');
86/**
87 * Determines whether any cookies in viewer requests (and if so, which cookies)
88 * are included in requests that CloudFront sends to the origin.
89 */
90class OriginRequestCookieBehavior {
91 constructor(behavior, cookies) {
92 this.behavior = behavior;
93 this.cookies = cookies;
94 }
95 /**
96 * Cookies in viewer requests are not included in requests that CloudFront sends to the origin.
97 * Any cookies that are listed in a CachePolicy are still included in origin requests.
98 */
99 static none() { return new OriginRequestCookieBehavior('none'); }
100 /** All cookies in viewer requests are included in requests that CloudFront sends to the origin. */
101 static all() { return new OriginRequestCookieBehavior('all'); }
102 /** Only the provided `cookies` are included in requests that CloudFront sends to the origin. */
103 static allowList(...cookies) {
104 if (cookies.length === 0) {
105 throw new Error('At least one cookie to allow must be provided');
106 }
107 return new OriginRequestCookieBehavior('whitelist', cookies);
108 }
109}
110exports.OriginRequestCookieBehavior = OriginRequestCookieBehavior;
111_b = JSII_RTTI_SYMBOL_1;
112OriginRequestCookieBehavior[_b] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestCookieBehavior", version: "1.161.0" };
113/**
114 * Determines whether any HTTP headers (and if so, which headers) are included in requests that CloudFront sends to the origin.
115 */
116class OriginRequestHeaderBehavior {
117 constructor(behavior, headers) {
118 this.behavior = behavior;
119 this.headers = headers;
120 }
121 /**
122 * HTTP headers are not included in requests that CloudFront sends to the origin.
123 * Any headers that are listed in a CachePolicy are still included in origin requests.
124 */
125 static none() { return new OriginRequestHeaderBehavior('none'); }
126 /**
127 * All HTTP headers in viewer requests are included in requests that CloudFront sends to the origin.
128 * Additionally, any additional CloudFront headers provided are included; the additional headers are added by CloudFront.
129 * @see https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/using-cloudfront-headers.html
130 */
131 static all(...cloudfrontHeaders) {
132 if (cloudfrontHeaders.length > 0) {
133 if (!cloudfrontHeaders.every(header => header.startsWith('CloudFront-'))) {
134 throw new Error('additional CloudFront headers passed to `OriginRequestHeaderBehavior.all()` must begin with \'CloudFront-\'');
135 }
136 return new OriginRequestHeaderBehavior('allViewerAndWhitelistCloudFront', cloudfrontHeaders);
137 }
138 else {
139 return new OriginRequestHeaderBehavior('allViewer');
140 }
141 }
142 /** Listed headers are included in requests that CloudFront sends to the origin. */
143 static allowList(...headers) {
144 if (headers.length === 0) {
145 throw new Error('At least one header to allow must be provided');
146 }
147 if (headers.map(header => header.toLowerCase()).some(header => ['authorization', 'accept-encoding'].includes(header))) {
148 throw new Error('you cannot pass `Authorization` or `Accept-Encoding` as header values; use a CachePolicy to forward these headers instead');
149 }
150 return new OriginRequestHeaderBehavior('whitelist', headers);
151 }
152}
153exports.OriginRequestHeaderBehavior = OriginRequestHeaderBehavior;
154_c = JSII_RTTI_SYMBOL_1;
155OriginRequestHeaderBehavior[_c] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestHeaderBehavior", version: "1.161.0" };
156/**
157 * Determines whether any URL query strings in viewer requests (and if so, which query strings)
158 * are included in requests that CloudFront sends to the origin.
159 */
160class OriginRequestQueryStringBehavior {
161 constructor(behavior, queryStrings) {
162 this.behavior = behavior;
163 this.queryStrings = queryStrings;
164 }
165 /**
166 * Query strings in viewer requests are not included in requests that CloudFront sends to the origin.
167 * Any query strings that are listed in a CachePolicy are still included in origin requests.
168 */
169 static none() { return new OriginRequestQueryStringBehavior('none'); }
170 /** All query strings in viewer requests are included in requests that CloudFront sends to the origin. */
171 static all() { return new OriginRequestQueryStringBehavior('all'); }
172 /** Only the provided `queryStrings` are included in requests that CloudFront sends to the origin. */
173 static allowList(...queryStrings) {
174 if (queryStrings.length === 0) {
175 throw new Error('At least one query string to allow must be provided');
176 }
177 return new OriginRequestQueryStringBehavior('whitelist', queryStrings);
178 }
179}
180exports.OriginRequestQueryStringBehavior = OriginRequestQueryStringBehavior;
181_d = JSII_RTTI_SYMBOL_1;
182OriginRequestQueryStringBehavior[_d] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestQueryStringBehavior", version: "1.161.0" };
183//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"origin-request-policy.js","sourceRoot":"","sources":["origin-request-policy.ts"],"names":[],"mappings":";;;;;;AAAA,wCAAuD;AAEvD,iEAAgE;AAiDhE;;;;GAIG;AACH,MAAa,mBAAoB,SAAQ,eAAQ;IA6B/C,YAAY,KAAgB,EAAE,EAAU,EAAE,QAAkC,EAAE;QAC5E,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,YAAY,EAAE,KAAK,CAAC,uBAAuB;SAC5C,CAAC,CAAC;;;;;;+CAhCM,mBAAmB;;;;QAkC5B,MAAM,uBAAuB,GAAG,KAAK,CAAC,uBAAuB,IAAI,YAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtF,IAAI,CAAC,YAAK,CAAC,YAAY,CAAC,uBAAuB,CAAC,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,WAAW,CAAC,EAAE;YAC/F,MAAM,IAAI,KAAK,CAAC,2FAA2F,KAAK,CAAC,uBAAuB,GAAG,CAAC,CAAC;SAC9I;QAED,MAAM,OAAO,GAAG,KAAK,CAAC,cAAc,IAAI,2BAA2B,CAAC,IAAI,EAAE,CAAC;QAC3E,MAAM,OAAO,GAAG,KAAK,CAAC,cAAc,IAAI,2BAA2B,CAAC,IAAI,EAAE,CAAC;QAC3E,MAAM,YAAY,GAAG,KAAK,CAAC,mBAAmB,IAAI,gCAAgC,CAAC,IAAI,EAAE,CAAC;QAE1F,MAAM,QAAQ,GAAG,IAAI,6CAAsB,CAAC,IAAI,EAAE,UAAU,EAAE;YAC5D,yBAAyB,EAAE;gBACzB,IAAI,EAAE,uBAAuB;gBAC7B,OAAO,EAAE,KAAK,CAAC,OAAO;gBACtB,aAAa,EAAE;oBACb,cAAc,EAAE,OAAO,CAAC,QAAQ;oBAChC,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB;gBACD,aAAa,EAAE;oBACb,cAAc,EAAE,OAAO,CAAC,QAAQ;oBAChC,OAAO,EAAE,OAAO,CAAC,OAAO;iBACzB;gBACD,kBAAkB,EAAE;oBAClB,mBAAmB,EAAE,YAAY,CAAC,QAAQ;oBAC1C,YAAY,EAAE,YAAY,CAAC,YAAY;iBACxC;aACF;SACF,CAAC,CAAC;QAEH,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,GAAG,CAAC;KAC3C;IAlDD,mDAAmD;IAC5C,MAAM,CAAC,yBAAyB,CAAC,KAAgB,EAAE,EAAU,EAAE,qBAA6B;QACjG,OAAO,IAAI,KAAM,SAAQ,eAAQ;YAAtB;;gBACO,0BAAqB,GAAG,qBAAqB,CAAC;YAChE,CAAC;SAAA,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;KACd;IAED,qDAAqD;IAC7C,MAAM,CAAC,8BAA8B,CAAC,4BAAoC;QAChF,OAAO,IAAI;YAAA;gBACO,0BAAqB,GAAG,4BAA4B,CAAC;YACvE,CAAC;SAAA,EAAE,CAAC;KACL;;AAzBH,kDAgEC;;;AA9DC,qHAAqH;AAC9F,8CAA0B,GAAG,mBAAmB,CAAC,8BAA8B,CAAC,sCAAsC,CAAC,CAAC;AAC/I,qIAAqI;AAC9G,sCAAkB,GAAG,mBAAmB,CAAC,8BAA8B,CAAC,sCAAsC,CAAC,CAAC;AACvI,yIAAyI;AAClH,kCAAc,GAAG,mBAAmB,CAAC,8BAA8B,CAAC,sCAAsC,CAAC,CAAC;AACnI,mGAAmG;AAC5E,8BAAU,GAAG,mBAAmB,CAAC,8BAA8B,CAAC,sCAAsC,CAAC,CAAC;AAC/H,oGAAoG;AAC7E,0CAAsB,GAAG,mBAAmB,CAAC,8BAA8B,CAAC,sCAAsC,CAAC,CAAC;AAuD7I;;;GAGG;AACH,MAAa,2BAA2B;IAuBtC,YAAoB,QAAgB,EAAE,OAAkB;QACtD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;KACxB;IAzBD;;;OAGG;IACI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,2BAA2B,CAAC,MAAM,CAAC,CAAC,EAAE;IAExE,mGAAmG;IAC5F,MAAM,CAAC,GAAG,KAAK,OAAO,IAAI,2BAA2B,CAAC,KAAK,CAAC,CAAC,EAAE;IAEtE,gGAAgG;IACzF,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,2BAA2B,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;KAC9D;;AAhBH,kEA2BC;;;AAED;;GAEG;AACH,MAAa,2BAA2B;IAuCtC,YAAoB,QAAgB,EAAE,OAAkB;QACtD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;KACxB;IAzCD;;;OAGG;IACI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,2BAA2B,CAAC,MAAM,CAAC,CAAC,EAAE;IAExE;;;;OAIG;IACI,MAAM,CAAC,GAAG,CAAC,GAAG,iBAA2B;QAC9C,IAAI,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;YAChC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,EAAE;gBACxE,MAAM,IAAI,KAAK,CAAC,6GAA6G,CAAC,CAAC;aAChI;YACD,OAAO,IAAI,2BAA2B,CAAC,iCAAiC,EAAE,iBAAiB,CAAC,CAAC;SAC9F;aAAM;YACL,OAAO,IAAI,2BAA2B,CAAC,WAAW,CAAC,CAAC;SACrD;KACF;IAED,mFAAmF;IAC5E,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,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,eAAe,EAAE,iBAAiB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE;YACrH,MAAM,IAAI,KAAK,CAAC,2HAA2H,CAAC,CAAC;SAC9I;QACD,OAAO,IAAI,2BAA2B,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC;KAC9D;;AAhCH,kEA2CC;;;AAED;;;GAGG;AACH,MAAa,gCAAgC;IAuB3C,YAAoB,QAAgB,EAAE,YAAuB;QAC3D,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;KAClC;IAzBD;;;OAGG;IACI,MAAM,CAAC,IAAI,KAAK,OAAO,IAAI,gCAAgC,CAAC,MAAM,CAAC,CAAC,EAAE;IAE7E,yGAAyG;IAClG,MAAM,CAAC,GAAG,KAAK,OAAO,IAAI,gCAAgC,CAAC,KAAK,CAAC,CAAC,EAAE;IAE3E,qGAAqG;IAC9F,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,gCAAgC,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;KACxE;;AAhBH,4EA2BC","sourcesContent":["import { Names, Resource, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnOriginRequestPolicy } from './cloudfront.generated';\n\n/**\n * Represents a Origin Request Policy\n */\nexport interface IOriginRequestPolicy {\n  /**\n   * The ID of the origin request policy\n   * @attribute\n   */\n  readonly originRequestPolicyId: string;\n}\n\n/**\n * Properties for creating a Origin Request Policy\n */\nexport interface OriginRequestPolicyProps {\n  /**\n   * A unique name to identify the origin request policy.\n   * The name must only include '-', '_', or alphanumeric characters.\n   * @default - generated from the `id`\n   */\n  readonly originRequestPolicyName?: string;\n\n  /**\n   * A comment to describe the origin request policy.\n   * @default - no comment\n   */\n  readonly comment?: string;\n\n  /**\n   * The cookies from viewer requests to include in origin requests.\n   * @default OriginRequestCookieBehavior.none()\n   */\n  readonly cookieBehavior?: OriginRequestCookieBehavior;\n\n  /**\n   * The HTTP headers to include in origin requests. These can include headers from viewer requests and additional headers added by CloudFront.\n   * @default OriginRequestHeaderBehavior.none()\n   */\n  readonly headerBehavior?: OriginRequestHeaderBehavior;\n\n  /**\n   * The URL query strings from viewer requests to include in origin requests.\n   * @default OriginRequestQueryStringBehavior.none()\n   */\n  readonly queryStringBehavior?: OriginRequestQueryStringBehavior;\n}\n\n/**\n * A Origin Request Policy configuration.\n *\n * @resource AWS::CloudFront::OriginRequestPolicy\n */\nexport class OriginRequestPolicy extends Resource implements IOriginRequestPolicy {\n\n  /** This policy includes only the User-Agent and Referer headers. It doesn’t include any query strings or cookies. */\n  public static readonly USER_AGENT_REFERER_HEADERS = OriginRequestPolicy.fromManagedOriginRequestPolicy('acba4595-bd28-49b8-b9fe-13317c0390fa');\n  /** This policy includes the header that enables cross-origin resource sharing (CORS) requests when the origin is a custom origin. */\n  public static readonly CORS_CUSTOM_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('59781a5b-3903-41f3-afcb-af62929ccde1');\n  /** This policy includes the headers that enable cross-origin resource sharing (CORS) requests when the origin is an Amazon S3 bucket. */\n  public static readonly CORS_S3_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('88a5eaf4-2fd4-4709-b370-b4c650ea3fcf');\n  /** This policy includes all values (query strings, headers, and cookies) in the viewer request. */\n  public static readonly ALL_VIEWER = OriginRequestPolicy.fromManagedOriginRequestPolicy('216adef6-5c7f-47e4-b989-5492eafa07d3');\n  /** This policy is designed for use with an origin that is an AWS Elemental MediaTailor endpoint. */\n  public static readonly ELEMENTAL_MEDIA_TAILOR = OriginRequestPolicy.fromManagedOriginRequestPolicy('775133bc-15f2-49f9-abea-afb2e0bf67d2');\n\n  /** Imports a Origin Request Policy from its id. */\n  public static fromOriginRequestPolicyId(scope: Construct, id: string, originRequestPolicyId: string): IOriginRequestPolicy {\n    return new class extends Resource implements IOriginRequestPolicy {\n      public readonly originRequestPolicyId = originRequestPolicyId;\n    }(scope, id);\n  }\n\n  /** Use an existing managed origin request policy. */\n  private static fromManagedOriginRequestPolicy(managedOriginRequestPolicyId: string): IOriginRequestPolicy {\n    return new class implements IOriginRequestPolicy {\n      public readonly originRequestPolicyId = managedOriginRequestPolicyId;\n    }();\n  }\n\n  public readonly originRequestPolicyId: string;\n\n  constructor(scope: Construct, id: string, props: OriginRequestPolicyProps = {}) {\n    super(scope, id, {\n      physicalName: props.originRequestPolicyName,\n    });\n\n    const originRequestPolicyName = props.originRequestPolicyName ?? Names.uniqueId(this);\n    if (!Token.isUnresolved(originRequestPolicyName) && !originRequestPolicyName.match(/^[\\w-]+$/i)) {\n      throw new Error(`'originRequestPolicyName' can only include '-', '_', and alphanumeric characters, got: '${props.originRequestPolicyName}'`);\n    }\n\n    const cookies = props.cookieBehavior ?? OriginRequestCookieBehavior.none();\n    const headers = props.headerBehavior ?? OriginRequestHeaderBehavior.none();\n    const queryStrings = props.queryStringBehavior ?? OriginRequestQueryStringBehavior.none();\n\n    const resource = new CfnOriginRequestPolicy(this, 'Resource', {\n      originRequestPolicyConfig: {\n        name: originRequestPolicyName,\n        comment: props.comment,\n        cookiesConfig: {\n          cookieBehavior: cookies.behavior,\n          cookies: cookies.cookies,\n        },\n        headersConfig: {\n          headerBehavior: headers.behavior,\n          headers: headers.headers,\n        },\n        queryStringsConfig: {\n          queryStringBehavior: queryStrings.behavior,\n          queryStrings: queryStrings.queryStrings,\n        },\n      },\n    });\n\n    this.originRequestPolicyId = resource.ref;\n  }\n}\n\n/**\n * Determines whether any cookies in viewer requests (and if so, which cookies)\n * are included in requests that CloudFront sends to the origin.\n */\nexport class OriginRequestCookieBehavior {\n  /**\n   * Cookies in viewer requests are not included in requests that CloudFront sends to the origin.\n   * Any cookies that are listed in a CachePolicy are still included in origin requests.\n   */\n  public static none() { return new OriginRequestCookieBehavior('none'); }\n\n  /** All cookies in viewer requests are included in requests that CloudFront sends to the origin. */\n  public static all() { return new OriginRequestCookieBehavior('all'); }\n\n  /** Only the provided `cookies` are included in requests that CloudFront sends to the origin. */\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 OriginRequestCookieBehavior('whitelist', cookies);\n  }\n\n  /** The behavior of cookies: allow all, none or an allow list. */\n  public readonly behavior: string;\n  /** The cookies to allow, if the behavior is an allow 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 (and if so, which headers) are included in requests that CloudFront sends to the origin.\n */\nexport class OriginRequestHeaderBehavior {\n  /**\n   * HTTP headers are not included in requests that CloudFront sends to the origin.\n   * Any headers that are listed in a CachePolicy are still included in origin requests.\n   */\n  public static none() { return new OriginRequestHeaderBehavior('none'); }\n\n  /**\n   * All HTTP headers in viewer requests are included in requests that CloudFront sends to the origin.\n   * Additionally, any additional CloudFront headers provided are included; the additional headers are added by CloudFront.\n   * @see https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/using-cloudfront-headers.html\n   */\n  public static all(...cloudfrontHeaders: string[]) {\n    if (cloudfrontHeaders.length > 0) {\n      if (!cloudfrontHeaders.every(header => header.startsWith('CloudFront-'))) {\n        throw new Error('additional CloudFront headers passed to `OriginRequestHeaderBehavior.all()` must begin with \\'CloudFront-\\'');\n      }\n      return new OriginRequestHeaderBehavior('allViewerAndWhitelistCloudFront', cloudfrontHeaders);\n    } else {\n      return new OriginRequestHeaderBehavior('allViewer');\n    }\n  }\n\n  /** Listed headers are 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    if (headers.map(header => header.toLowerCase()).some(header => ['authorization', 'accept-encoding'].includes(header))) {\n      throw new Error('you cannot pass `Authorization` or `Accept-Encoding` as header values; use a CachePolicy to forward these headers instead');\n    }\n    return new OriginRequestHeaderBehavior('whitelist', headers);\n  }\n\n  /** The behavior of headers: allow all, none or an allow list. */\n  public readonly behavior: string;\n  /** The headers for the allow list or the included CloudFront headers, 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 (and if so, which query strings)\n * are included in requests that CloudFront sends to the origin.\n */\nexport class OriginRequestQueryStringBehavior {\n  /**\n   * Query strings in viewer requests are not included in requests that CloudFront sends to the origin.\n   * Any query strings that are listed in a CachePolicy are still included in origin requests.\n   */\n  public static none() { return new OriginRequestQueryStringBehavior('none'); }\n\n  /** All query strings in viewer requests are included in requests that CloudFront sends to the origin. */\n  public static all() { return new OriginRequestQueryStringBehavior('all'); }\n\n  /** Only the provided `queryStrings` are included in requests that CloudFront sends to the origin. */\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 OriginRequestQueryStringBehavior('whitelist', queryStrings);\n  }\n\n  /** The behavior of query strings -- allow all, none, or only an allow list. */\n  public readonly behavior: string;\n  /** The query strings to allow, if the behavior is an allow 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