UNPKG

34 kBJavaScriptView Raw
1"use strict";
2var _a;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.HeadersReferrerPolicy = exports.HeadersFrameOption = exports.ResponseHeadersPolicy = 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 Response Headers Policy configuration
11 *
12 * @resource AWS::CloudFront::ResponseHeadersPolicy
13 */
14class ResponseHeadersPolicy extends core_1.Resource {
15 constructor(scope, id, props = {}) {
16 var _b;
17 super(scope, id, {
18 physicalName: props.responseHeadersPolicyName,
19 });
20 try {
21 jsiiDeprecationWarnings._aws_cdk_aws_cloudfront_ResponseHeadersPolicyProps(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 responseHeadersPolicyName = (_b = props.responseHeadersPolicyName) !== null && _b !== void 0 ? _b : core_1.Names.uniqueId(this);
30 const resource = new cloudfront_generated_1.CfnResponseHeadersPolicy(this, 'Resource', {
31 responseHeadersPolicyConfig: {
32 name: responseHeadersPolicyName,
33 comment: props.comment,
34 corsConfig: props.corsBehavior ? this._renderCorsConfig(props.corsBehavior) : undefined,
35 customHeadersConfig: props.customHeadersBehavior ? this._renderCustomHeadersConfig(props.customHeadersBehavior) : undefined,
36 securityHeadersConfig: props.securityHeadersBehavior ? this._renderSecurityHeadersConfig(props.securityHeadersBehavior) : undefined,
37 },
38 });
39 this.responseHeadersPolicyId = resource.ref;
40 }
41 /**
42 * Import an existing Response Headers Policy from its ID.
43 */
44 static fromResponseHeadersPolicyId(scope, id, responseHeadersPolicyId) {
45 class Import extends core_1.Resource {
46 constructor() {
47 super(...arguments);
48 this.responseHeadersPolicyId = responseHeadersPolicyId;
49 }
50 }
51 return new Import(scope, id);
52 }
53 static fromManagedResponseHeadersPolicy(managedResponseHeadersPolicyId) {
54 return new class {
55 constructor() {
56 this.responseHeadersPolicyId = managedResponseHeadersPolicyId;
57 }
58 };
59 }
60 _renderCorsConfig(behavior) {
61 return {
62 accessControlAllowCredentials: behavior.accessControlAllowCredentials,
63 accessControlAllowHeaders: { items: behavior.accessControlAllowHeaders },
64 accessControlAllowMethods: { items: behavior.accessControlAllowMethods },
65 accessControlAllowOrigins: { items: behavior.accessControlAllowOrigins },
66 accessControlExposeHeaders: behavior.accessControlExposeHeaders ? { items: behavior.accessControlExposeHeaders } : undefined,
67 accessControlMaxAgeSec: behavior.accessControlMaxAge ? behavior.accessControlMaxAge.toSeconds() : undefined,
68 originOverride: behavior.originOverride,
69 };
70 }
71 _renderCustomHeadersConfig(behavior) {
72 return {
73 items: behavior.customHeaders,
74 };
75 }
76 _renderSecurityHeadersConfig(behavior) {
77 return {
78 contentSecurityPolicy: behavior.contentSecurityPolicy,
79 contentTypeOptions: behavior.contentTypeOptions,
80 frameOptions: behavior.frameOptions,
81 referrerPolicy: behavior.referrerPolicy,
82 strictTransportSecurity: behavior.strictTransportSecurity ? {
83 ...behavior.strictTransportSecurity,
84 accessControlMaxAgeSec: behavior.strictTransportSecurity.accessControlMaxAge.toSeconds(),
85 } : undefined,
86 xssProtection: behavior.xssProtection,
87 };
88 }
89}
90exports.ResponseHeadersPolicy = ResponseHeadersPolicy;
91_a = JSII_RTTI_SYMBOL_1;
92ResponseHeadersPolicy[_a] = { fqn: "@aws-cdk/aws-cloudfront.ResponseHeadersPolicy", version: "1.157.0" };
93/** Use this managed policy to allow simple CORS requests from any origin. */
94ResponseHeadersPolicy.CORS_ALLOW_ALL_ORIGINS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('60669652-455b-4ae9-85a4-c4c02393f86c');
95/** Use this managed policy to allow CORS requests from any origin, including preflight requests. */
96ResponseHeadersPolicy.CORS_ALLOW_ALL_ORIGINS_WITH_PREFLIGHT = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('5cc3b908-e619-4b99-88e5-2cf7f45965bd');
97/** Use this managed policy to add a set of security headers to all responses that CloudFront sends to viewers. */
98ResponseHeadersPolicy.SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('67f7725c-6f97-4210-82d7-5512b31e9d03');
99/** Use this managed policy to allow simple CORS requests from any origin and add a set of security headers to all responses that CloudFront sends to viewers. */
100ResponseHeadersPolicy.CORS_ALLOW_ALL_ORIGINS_AND_SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('e61eb60c-9c35-4d20-a928-2b84e02af89c');
101/** Use this managed policy to allow CORS requests from any origin, including preflight requests, and add a set of security headers to all responses that CloudFront sends to viewers. */
102ResponseHeadersPolicy.CORS_ALLOW_ALL_ORIGINS_WITH_PREFLIGHT_AND_SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('eaab4381-ed33-4a86-88ca-d9558dc6cd63');
103/**
104 * Enum representing possible values of the X-Frame-Options HTTP response header.
105 */
106var HeadersFrameOption;
107(function (HeadersFrameOption) {
108 /**
109 * The page can only be displayed in a frame on the same origin as the page itself.
110 */
111 HeadersFrameOption["DENY"] = "DENY";
112 /**
113 * The page can only be displayed in a frame on the specified origin.
114 */
115 HeadersFrameOption["SAMEORIGIN"] = "SAMEORIGIN";
116})(HeadersFrameOption = exports.HeadersFrameOption || (exports.HeadersFrameOption = {}));
117/**
118 * Enum representing possible values of the Referrer-Policy HTTP response header.
119 */
120var HeadersReferrerPolicy;
121(function (HeadersReferrerPolicy) {
122 /**
123 * The referrer policy is not set.
124 */
125 HeadersReferrerPolicy["NO_REFERRER"] = "no-referrer";
126 /**
127 * The referrer policy is no-referrer-when-downgrade.
128 */
129 HeadersReferrerPolicy["NO_REFERRER_WHEN_DOWNGRADE"] = "no-referrer-when-downgrade";
130 /**
131 * The referrer policy is origin.
132 */
133 HeadersReferrerPolicy["ORIGIN"] = "origin";
134 /**
135 * The referrer policy is origin-when-cross-origin.
136 */
137 HeadersReferrerPolicy["ORIGIN_WHEN_CROSS_ORIGIN"] = "origin-when-cross-origin";
138 /**
139 * The referrer policy is same-origin.
140 */
141 HeadersReferrerPolicy["SAME_ORIGIN"] = "same-origin";
142 /**
143 * The referrer policy is strict-origin.
144 */
145 HeadersReferrerPolicy["STRICT_ORIGIN"] = "strict-origin";
146 /**
147 * The referrer policy is strict-origin-when-cross-origin.
148 */
149 HeadersReferrerPolicy["STRICT_ORIGIN_WHEN_CROSS_ORIGIN"] = "strict-origin-when-cross-origin";
150 /**
151 * The referrer policy is unsafe-url.
152 */
153 HeadersReferrerPolicy["UNSAFE_URL"] = "unsafe-url";
154})(HeadersReferrerPolicy = exports.HeadersReferrerPolicy || (exports.HeadersReferrerPolicy = {}));
155//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"response-headers-policy.js","sourceRoot":"","sources":["response-headers-policy.ts"],"names":[],"mappings":"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","sourcesContent":["import { Duration, Names, Resource } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { CfnResponseHeadersPolicy } from './cloudfront.generated';\n\n/**\n * Represents a response headers policy.\n */\nexport interface IResponseHeadersPolicy {\n  /**\n   * The ID of the response headers policy\n   * @attribute\n   **/\n  readonly responseHeadersPolicyId: string;\n}\n\n/**\n * Properties for creating a Response Headers Policy\n */\nexport interface ResponseHeadersPolicyProps {\n  /**\n   * A unique name to identify the response headers policy.\n   *\n   * @default - generated from the `id`\n   */\n  readonly responseHeadersPolicyName?: string;\n\n  /**\n   * A comment to describe the response headers policy.\n   *\n   * @default - no comment\n   */\n  readonly comment?: string;\n\n  /**\n   * A configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).\n   *\n   * @default - no cors behavior\n   */\n  readonly corsBehavior?: ResponseHeadersCorsBehavior;\n\n  /**\n   * A configuration for a set of custom HTTP response headers.\n   *\n   * @default - no custom headers behavior\n   */\n  readonly customHeadersBehavior?: ResponseCustomHeadersBehavior;\n\n  /**\n   * A configuration for a set of security-related HTTP response headers.\n   *\n   * @default - no security headers behavior\n   */\n  readonly securityHeadersBehavior?: ResponseSecurityHeadersBehavior;\n}\n\n/**\n * A Response Headers Policy configuration\n *\n * @resource AWS::CloudFront::ResponseHeadersPolicy\n */\nexport class ResponseHeadersPolicy extends Resource implements IResponseHeadersPolicy {\n\n  /** Use this managed policy to allow simple CORS requests from any origin. */\n  public static readonly CORS_ALLOW_ALL_ORIGINS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('60669652-455b-4ae9-85a4-c4c02393f86c');\n  /** Use this managed policy to allow CORS requests from any origin, including preflight requests. */\n  public static readonly CORS_ALLOW_ALL_ORIGINS_WITH_PREFLIGHT = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('5cc3b908-e619-4b99-88e5-2cf7f45965bd');\n  /** Use this managed policy to add a set of security headers to all responses that CloudFront sends to viewers. */\n  public static readonly SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('67f7725c-6f97-4210-82d7-5512b31e9d03');\n  /** Use this managed policy to allow simple CORS requests from any origin and add a set of security headers to all responses that CloudFront sends to viewers. */\n  public static readonly CORS_ALLOW_ALL_ORIGINS_AND_SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('e61eb60c-9c35-4d20-a928-2b84e02af89c');\n  /** Use this managed policy to allow CORS requests from any origin, including preflight requests, and add a set of security headers to all responses that CloudFront sends to viewers. */\n  public static readonly CORS_ALLOW_ALL_ORIGINS_WITH_PREFLIGHT_AND_SECURITY_HEADERS = ResponseHeadersPolicy.fromManagedResponseHeadersPolicy('eaab4381-ed33-4a86-88ca-d9558dc6cd63');\n\n  /**\n   * Import an existing Response Headers Policy from its ID.\n   */\n  public static fromResponseHeadersPolicyId(scope: Construct, id: string, responseHeadersPolicyId: string): IResponseHeadersPolicy {\n    class Import extends Resource implements IResponseHeadersPolicy {\n      public readonly responseHeadersPolicyId = responseHeadersPolicyId;\n    }\n    return new Import(scope, id);\n  }\n\n  private static fromManagedResponseHeadersPolicy(managedResponseHeadersPolicyId: string): IResponseHeadersPolicy {\n    return new class implements IResponseHeadersPolicy {\n      public readonly responseHeadersPolicyId = managedResponseHeadersPolicyId;\n    };\n  }\n\n  public readonly responseHeadersPolicyId: string;\n\n  constructor(scope: Construct, id: string, props: ResponseHeadersPolicyProps = {}) {\n    super(scope, id, {\n      physicalName: props.responseHeadersPolicyName,\n    });\n\n    const responseHeadersPolicyName = props.responseHeadersPolicyName ?? Names.uniqueId(this);\n\n    const resource = new CfnResponseHeadersPolicy(this, 'Resource', {\n      responseHeadersPolicyConfig: {\n        name: responseHeadersPolicyName,\n        comment: props.comment,\n        corsConfig: props.corsBehavior ? this._renderCorsConfig(props.corsBehavior) : undefined,\n        customHeadersConfig: props.customHeadersBehavior ? this._renderCustomHeadersConfig(props.customHeadersBehavior) : undefined,\n        securityHeadersConfig: props.securityHeadersBehavior ? this._renderSecurityHeadersConfig(props.securityHeadersBehavior) : undefined,\n      },\n    });\n\n    this.responseHeadersPolicyId = resource.ref;\n  }\n\n  private _renderCorsConfig(behavior: ResponseHeadersCorsBehavior): CfnResponseHeadersPolicy.CorsConfigProperty {\n    return {\n      accessControlAllowCredentials: behavior.accessControlAllowCredentials,\n      accessControlAllowHeaders: { items: behavior.accessControlAllowHeaders },\n      accessControlAllowMethods: { items: behavior.accessControlAllowMethods },\n      accessControlAllowOrigins: { items: behavior.accessControlAllowOrigins },\n      accessControlExposeHeaders: behavior.accessControlExposeHeaders ? { items: behavior.accessControlExposeHeaders } : undefined,\n      accessControlMaxAgeSec: behavior.accessControlMaxAge ? behavior.accessControlMaxAge.toSeconds() : undefined,\n      originOverride: behavior.originOverride,\n    };\n  }\n\n  private _renderCustomHeadersConfig(behavior: ResponseCustomHeadersBehavior): CfnResponseHeadersPolicy.CustomHeadersConfigProperty {\n    return {\n      items: behavior.customHeaders,\n    };\n  }\n\n  private _renderSecurityHeadersConfig(behavior: ResponseSecurityHeadersBehavior): CfnResponseHeadersPolicy.SecurityHeadersConfigProperty {\n    return {\n      contentSecurityPolicy: behavior.contentSecurityPolicy,\n      contentTypeOptions: behavior.contentTypeOptions,\n      frameOptions: behavior.frameOptions,\n      referrerPolicy: behavior.referrerPolicy,\n      strictTransportSecurity: behavior.strictTransportSecurity ? {\n        ...behavior.strictTransportSecurity,\n        accessControlMaxAgeSec: behavior.strictTransportSecurity.accessControlMaxAge.toSeconds(),\n      }: undefined,\n      xssProtection: behavior.xssProtection,\n    };\n  }\n}\n\n/**\n * Configuration for a set of HTTP response headers that are used for cross-origin resource sharing (CORS).\n * CloudFront adds these headers to HTTP responses that it sends for CORS requests that match a cache behavior\n * associated with this response headers policy.\n */\nexport interface ResponseHeadersCorsBehavior {\n  /**\n   * A Boolean that CloudFront uses as the value for the Access-Control-Allow-Credentials HTTP response header.\n   */\n  readonly accessControlAllowCredentials: boolean;\n\n  /**\n   * A list of HTTP header names that CloudFront includes as values for the Access-Control-Allow-Headers HTTP response header.\n   * You can specify `['*']` to allow all headers.\n   */\n  readonly accessControlAllowHeaders: string[];\n\n  /**\n   * A list of HTTP methods that CloudFront includes as values for the Access-Control-Allow-Methods HTTP response header.\n   */\n  readonly accessControlAllowMethods: string[];\n\n  /**\n   * A list of origins (domain names) that CloudFront can use as the value for the Access-Control-Allow-Origin HTTP response header.\n   * You can specify `['*']` to allow all origins.\n   */\n  readonly accessControlAllowOrigins: string[];\n\n  /**\n   * A list of HTTP headers that CloudFront includes as values for the Access-Control-Expose-Headers HTTP response header.\n   * You can specify `['*']` to expose all headers.\n   *\n   * @default - no headers exposed\n   */\n  readonly accessControlExposeHeaders?: string[];\n\n  /**\n   * A number that CloudFront uses as the value for the Access-Control-Max-Age HTTP response header.\n   *\n   * @default - no max age\n   */\n  readonly accessControlMaxAge?: Duration;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides HTTP response headers received from the origin with the ones specified in this response headers policy.\n   */\n  readonly originOverride: boolean;\n}\n\n/**\n * Configuration for a set of HTTP response headers that are sent for requests that match a cache behavior\n * that’s associated with this response headers policy.\n */\nexport interface ResponseCustomHeadersBehavior {\n  /**\n   * The list of HTTP response headers and their values.\n   */\n  readonly customHeaders: ResponseCustomHeader[];\n}\n\n/**\n * An HTTP response header name and its value.\n * CloudFront includes this header in HTTP responses that it sends for requests that match a cache behavior that’s associated with this response headers policy.\n */\nexport interface ResponseCustomHeader {\n  /**\n   * The HTTP response header name.\n   */\n  readonly header: string;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides a response header with the same name\n   * received from the origin with the header specified here.\n   */\n  readonly override: boolean;\n\n  /**\n   * The value for the HTTP response header.\n   */\n  readonly value: string;\n}\n\n/**\n * Configuration for a set of security-related HTTP response headers.\n * CloudFront adds these headers to HTTP responses that it sends for requests that match a cache behavior\n * associated with this response headers policy.\n */\nexport interface ResponseSecurityHeadersBehavior {\n  /**\n   * The policy directives and their values that CloudFront includes as values for the Content-Security-Policy HTTP response header.\n   *\n   * @default - no content security policy\n   */\n  readonly contentSecurityPolicy?: ResponseHeadersContentSecurityPolicy;\n\n  /**\n   * Determines whether CloudFront includes the X-Content-Type-Options HTTP response header with its value set to nosniff.\n   *\n   * @default - no content type options\n   */\n  readonly contentTypeOptions?: ResponseHeadersContentTypeOptions;\n\n  /**\n   * Determines whether CloudFront includes the X-Frame-Options HTTP response header and the header’s value.\n   *\n   * @default - no frame options\n   */\n  readonly frameOptions?: ResponseHeadersFrameOptions;\n\n  /**\n   * Determines whether CloudFront includes the Referrer-Policy HTTP response header and the header’s value.\n   *\n   * @default - no referrer policy\n   */\n  readonly referrerPolicy?: ResponseHeadersReferrerPolicy;\n\n  /**\n   * Determines whether CloudFront includes the Strict-Transport-Security HTTP response header and the header’s value.\n   *\n   * @default - no strict transport security\n   */\n  readonly strictTransportSecurity?: ResponseHeadersStrictTransportSecurity;\n\n  /**\n   * Determines whether CloudFront includes the X-XSS-Protection HTTP response header and the header’s value.\n   *\n   * @default - no xss protection\n   */\n  readonly xssProtection?: ResponseHeadersXSSProtection;\n}\n\n/**\n * The policy directives and their values that CloudFront includes as values for the Content-Security-Policy HTTP response header.\n */\nexport interface ResponseHeadersContentSecurityPolicy {\n  /**\n   * The policy directives and their values that CloudFront includes as values for the Content-Security-Policy HTTP response header.\n   */\n  readonly contentSecurityPolicy: string;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides the Content-Security-Policy HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n}\n\n/**\n * Determines whether CloudFront includes the X-Content-Type-Options HTTP response header with its value set to nosniff.\n */\nexport interface ResponseHeadersContentTypeOptions {\n  /**\n   * A Boolean that determines whether CloudFront overrides the X-Content-Type-Options HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n}\n\n/**\n * Determines whether CloudFront includes the X-Frame-Options HTTP response header and the header’s value.\n */\nexport interface ResponseHeadersFrameOptions {\n  /**\n   * The value of the X-Frame-Options HTTP response header.\n   */\n  readonly frameOption: HeadersFrameOption;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides the X-Frame-Options HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n}\n\n/**\n * Determines whether CloudFront includes the Referrer-Policy HTTP response header and the header’s value.\n */\nexport interface ResponseHeadersReferrerPolicy {\n  /**\n   * The value of the Referrer-Policy HTTP response header.\n   */\n  readonly referrerPolicy: HeadersReferrerPolicy;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides the Referrer-Policy HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n}\n\n/**\n * Determines whether CloudFront includes the Strict-Transport-Security HTTP response header and the header’s value.\n */\nexport interface ResponseHeadersStrictTransportSecurity {\n  /**\n   * A number that CloudFront uses as the value for the max-age directive in the Strict-Transport-Security HTTP response header.\n   */\n  readonly accessControlMaxAge: Duration;\n\n  /**\n   * A Boolean that determines whether CloudFront includes the includeSubDomains directive in the Strict-Transport-Security HTTP response header.\n   *\n   * @default false\n   */\n  readonly includeSubdomains?: boolean;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides the Strict-Transport-Security HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n\n  /**\n   * A Boolean that determines whether CloudFront includes the preload directive in the Strict-Transport-Security HTTP response header.\n   *\n   * @default false\n   */\n  readonly preload?: boolean;\n}\n\n/**\n * Determines whether CloudFront includes the X-XSS-Protection HTTP response header and the header’s value.\n */\nexport interface ResponseHeadersXSSProtection {\n  /**\n   * A Boolean that determines whether CloudFront includes the mode=block directive in the X-XSS-Protection header.\n   *\n   * @default false\n   */\n  readonly modeBlock?: boolean;\n\n  /**\n   * A Boolean that determines whether CloudFront overrides the X-XSS-Protection HTTP response header\n   * received from the origin with the one specified in this response headers policy.\n   */\n  readonly override: boolean;\n\n  /**\n   * A Boolean that determines the value of the X-XSS-Protection HTTP response header.\n   * When this setting is true, the value of the X-XSS-Protection header is 1.\n   * When this setting is false, the value of the X-XSS-Protection header is 0.\n   */\n  readonly protection: boolean;\n\n  /**\n   * A reporting URI, which CloudFront uses as the value of the report directive in the X-XSS-Protection header.\n   * You cannot specify a ReportUri when ModeBlock is true.\n   *\n   * @default - no report uri\n   */\n  readonly reportUri?: string;\n}\n\n/**\n * Enum representing possible values of the X-Frame-Options HTTP response header.\n */\nexport enum HeadersFrameOption {\n  /**\n   * The page can only be displayed in a frame on the same origin as the page itself.\n   */\n  DENY = 'DENY',\n\n  /**\n   * The page can only be displayed in a frame on the specified origin.\n   */\n  SAMEORIGIN = 'SAMEORIGIN',\n}\n\n/**\n * Enum representing possible values of the Referrer-Policy HTTP response header.\n */\nexport enum HeadersReferrerPolicy {\n  /**\n   * The referrer policy is not set.\n   */\n  NO_REFERRER = 'no-referrer',\n\n  /**\n   * The referrer policy is no-referrer-when-downgrade.\n   */\n  NO_REFERRER_WHEN_DOWNGRADE = 'no-referrer-when-downgrade',\n\n  /**\n   * The referrer policy is origin.\n   */\n  ORIGIN = 'origin',\n\n  /**\n   * The referrer policy is origin-when-cross-origin.\n   */\n  ORIGIN_WHEN_CROSS_ORIGIN = 'origin-when-cross-origin',\n\n  /**\n   * The referrer policy is same-origin.\n   */\n  SAME_ORIGIN = 'same-origin',\n\n  /**\n   * The referrer policy is strict-origin.\n   */\n  STRICT_ORIGIN = 'strict-origin',\n\n  /**\n   * The referrer policy is strict-origin-when-cross-origin.\n   */\n  STRICT_ORIGIN_WHEN_CROSS_ORIGIN = 'strict-origin-when-cross-origin',\n\n  /**\n   * The referrer policy is unsafe-url.\n   */\n  UNSAFE_URL = 'unsafe-url',\n}\n"]}
\No newline at end of file