UNPKG

28.9 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 var _e, _f, _g, _h;
17 super(scope, id, {
18 physicalName: props.originRequestPolicyName,
19 });
20 try {
21 jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_OriginRequestPolicyProps(props);
22 }
23 catch (error) {
24 if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
25 Error.captureStackTrace(error, this.constructor);
26 }
27 throw error;
28 }
29 const originRequestPolicyName = (_e = props.originRequestPolicyName) !== null && _e !== void 0 ? _e : core_1.Names.uniqueId(this);
30 if (!core_1.Token.isUnresolved(originRequestPolicyName) && !originRequestPolicyName.match(/^[\w-]+$/i)) {
31 throw new Error(`'originRequestPolicyName' can only include '-', '_', and alphanumeric characters, got: '${props.originRequestPolicyName}'`);
32 }
33 const cookies = (_f = props.cookieBehavior) !== null && _f !== void 0 ? _f : OriginRequestCookieBehavior.none();
34 const headers = (_g = props.headerBehavior) !== null && _g !== void 0 ? _g : OriginRequestHeaderBehavior.none();
35 const queryStrings = (_h = props.queryStringBehavior) !== null && _h !== void 0 ? _h : OriginRequestQueryStringBehavior.none();
36 const resource = new cloudfront_generated_1.CfnOriginRequestPolicy(this, 'Resource', {
37 originRequestPolicyConfig: {
38 name: originRequestPolicyName,
39 comment: props.comment,
40 cookiesConfig: {
41 cookieBehavior: cookies.behavior,
42 cookies: cookies.cookies,
43 },
44 headersConfig: {
45 headerBehavior: headers.behavior,
46 headers: headers.headers,
47 },
48 queryStringsConfig: {
49 queryStringBehavior: queryStrings.behavior,
50 queryStrings: queryStrings.queryStrings,
51 },
52 },
53 });
54 this.originRequestPolicyId = resource.ref;
55 }
56 /** Imports a Origin Request Policy from its id. */
57 static fromOriginRequestPolicyId(scope, id, originRequestPolicyId) {
58 return new class extends core_1.Resource {
59 constructor() {
60 super(...arguments);
61 this.originRequestPolicyId = originRequestPolicyId;
62 }
63 }(scope, id);
64 }
65 /** Use an existing managed origin request policy. */
66 static fromManagedOriginRequestPolicy(managedOriginRequestPolicyId) {
67 return new class {
68 constructor() {
69 this.originRequestPolicyId = managedOriginRequestPolicyId;
70 }
71 }();
72 }
73}
74exports.OriginRequestPolicy = OriginRequestPolicy;
75_a = JSII_RTTI_SYMBOL_1;
76OriginRequestPolicy[_a] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestPolicy", version: "1.157.0" };
77/** This policy includes only the User-Agent and Referer headers. It doesn’t include any query strings or cookies. */
78OriginRequestPolicy.USER_AGENT_REFERER_HEADERS = OriginRequestPolicy.fromManagedOriginRequestPolicy('acba4595-bd28-49b8-b9fe-13317c0390fa');
79/** This policy includes the header that enables cross-origin resource sharing (CORS) requests when the origin is a custom origin. */
80OriginRequestPolicy.CORS_CUSTOM_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('59781a5b-3903-41f3-afcb-af62929ccde1');
81/** This policy includes the headers that enable cross-origin resource sharing (CORS) requests when the origin is an Amazon S3 bucket. */
82OriginRequestPolicy.CORS_S3_ORIGIN = OriginRequestPolicy.fromManagedOriginRequestPolicy('88a5eaf4-2fd4-4709-b370-b4c650ea3fcf');
83/** This policy includes all values (query strings, headers, and cookies) in the viewer request. */
84OriginRequestPolicy.ALL_VIEWER = OriginRequestPolicy.fromManagedOriginRequestPolicy('216adef6-5c7f-47e4-b989-5492eafa07d3');
85/** This policy is designed for use with an origin that is an AWS Elemental MediaTailor endpoint. */
86OriginRequestPolicy.ELEMENTAL_MEDIA_TAILOR = OriginRequestPolicy.fromManagedOriginRequestPolicy('775133bc-15f2-49f9-abea-afb2e0bf67d2');
87/**
88 * Determines whether any cookies in viewer requests (and if so, which cookies)
89 * are included in requests that CloudFront sends to the origin.
90 */
91class OriginRequestCookieBehavior {
92 constructor(behavior, cookies) {
93 this.behavior = behavior;
94 this.cookies = cookies;
95 }
96 /**
97 * Cookies in viewer requests are not included in requests that CloudFront sends to the origin.
98 * Any cookies that are listed in a CachePolicy are still included in origin requests.
99 */
100 static none() { return new OriginRequestCookieBehavior('none'); }
101 /** All cookies in viewer requests are included in requests that CloudFront sends to the origin. */
102 static all() { return new OriginRequestCookieBehavior('all'); }
103 /** Only the provided `cookies` are included in requests that CloudFront sends to the origin. */
104 static allowList(...cookies) {
105 if (cookies.length === 0) {
106 throw new Error('At least one cookie to allow must be provided');
107 }
108 return new OriginRequestCookieBehavior('whitelist', cookies);
109 }
110}
111exports.OriginRequestCookieBehavior = OriginRequestCookieBehavior;
112_b = JSII_RTTI_SYMBOL_1;
113OriginRequestCookieBehavior[_b] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestCookieBehavior", version: "1.157.0" };
114/**
115 * Determines whether any HTTP headers (and if so, which headers) are included in requests that CloudFront sends to the origin.
116 */
117class OriginRequestHeaderBehavior {
118 constructor(behavior, headers) {
119 this.behavior = behavior;
120 this.headers = headers;
121 }
122 /**
123 * HTTP headers are not included in requests that CloudFront sends to the origin.
124 * Any headers that are listed in a CachePolicy are still included in origin requests.
125 */
126 static none() { return new OriginRequestHeaderBehavior('none'); }
127 /**
128 * All HTTP headers in viewer requests are included in requests that CloudFront sends to the origin.
129 * Additionally, any additional CloudFront headers provided are included; the additional headers are added by CloudFront.
130 * @see https://docs.aws.amazon.com/AmazonCloudFront/latest/DeveloperGuide/using-cloudfront-headers.html
131 */
132 static all(...cloudfrontHeaders) {
133 if (cloudfrontHeaders.length > 0) {
134 if (!cloudfrontHeaders.every(header => header.startsWith('CloudFront-'))) {
135 throw new Error('additional CloudFront headers passed to `OriginRequestHeaderBehavior.all()` must begin with \'CloudFront-\'');
136 }
137 return new OriginRequestHeaderBehavior('allViewerAndWhitelistCloudFront', cloudfrontHeaders);
138 }
139 else {
140 return new OriginRequestHeaderBehavior('allViewer');
141 }
142 }
143 /** Listed headers are included in requests that CloudFront sends to the origin. */
144 static allowList(...headers) {
145 if (headers.length === 0) {
146 throw new Error('At least one header to allow must be provided');
147 }
148 if (headers.map(header => header.toLowerCase()).some(header => ['authorization', 'accept-encoding'].includes(header))) {
149 throw new Error('you cannot pass `Authorization` or `Accept-Encoding` as header values; use a CachePolicy to forward these headers instead');
150 }
151 return new OriginRequestHeaderBehavior('whitelist', headers);
152 }
153}
154exports.OriginRequestHeaderBehavior = OriginRequestHeaderBehavior;
155_c = JSII_RTTI_SYMBOL_1;
156OriginRequestHeaderBehavior[_c] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestHeaderBehavior", version: "1.157.0" };
157/**
158 * Determines whether any URL query strings in viewer requests (and if so, which query strings)
159 * are included in requests that CloudFront sends to the origin.
160 */
161class OriginRequestQueryStringBehavior {
162 constructor(behavior, queryStrings) {
163 this.behavior = behavior;
164 this.queryStrings = queryStrings;
165 }
166 /**
167 * Query strings in viewer requests are not included in requests that CloudFront sends to the origin.
168 * Any query strings that are listed in a CachePolicy are still included in origin requests.
169 */
170 static none() { return new OriginRequestQueryStringBehavior('none'); }
171 /** All query strings in viewer requests are included in requests that CloudFront sends to the origin. */
172 static all() { return new OriginRequestQueryStringBehavior('all'); }
173 /** Only the provided `queryStrings` are included in requests that CloudFront sends to the origin. */
174 static allowList(...queryStrings) {
175 if (queryStrings.length === 0) {
176 throw new Error('At least one query string to allow must be provided');
177 }
178 return new OriginRequestQueryStringBehavior('whitelist', queryStrings);
179 }
180}
181exports.OriginRequestQueryStringBehavior = OriginRequestQueryStringBehavior;
182_d = JSII_RTTI_SYMBOL_1;
183OriginRequestQueryStringBehavior[_d] = { fqn: "@aws-cdk/aws-cloudfront.OriginRequestQueryStringBehavior", version: "1.157.0" };
184//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"origin-request-policy.js","sourceRoot":"","sources":["origin-request-policy.ts"],"names":[],"mappings":"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","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