1 | ;
|
2 | var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
3 | Object.defineProperty(exports, "__esModule", { value: true });
|
4 | exports.CrossAccountZoneDelegationRecord = exports.ZoneDelegationRecord = exports.DsRecord = exports.NsRecord = exports.MxRecord = exports.CaaAmazonRecord = exports.CaaRecord = exports.CaaTag = exports.SrvRecord = exports.TxtRecord = exports.CnameRecord = exports.AaaaRecord = exports.ARecord = exports.AddressRecordTarget = exports.RecordSet = exports.RecordTarget = exports.RecordType = void 0;
|
5 | const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
|
6 | const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
7 | const path = require("path");
|
8 | const iam = require("@aws-cdk/aws-iam");
|
9 | const core_1 = require("@aws-cdk/core");
|
10 | const route53_generated_1 = require("./route53.generated");
|
11 | const util_1 = require("./util");
|
12 | const CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE = 'Custom::CrossAccountZoneDelegation';
|
13 | // v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.
|
14 | // eslint-disable-next-line
|
15 | const core_2 = require("@aws-cdk/core");
|
16 | /**
|
17 | * The record type.
|
18 | */
|
19 | var RecordType;
|
20 | (function (RecordType) {
|
21 | /**
|
22 | * route traffic to a resource, such as a web server, using an IPv4 address in dotted decimal
|
23 | * notation
|
24 | *
|
25 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#AFormat
|
26 | */
|
27 | RecordType["A"] = "A";
|
28 | /**
|
29 | * route traffic to a resource, such as a web server, using an IPv6 address in colon-separated
|
30 | * hexadecimal format
|
31 | *
|
32 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#AAAAFormat
|
33 | */
|
34 | RecordType["AAAA"] = "AAAA";
|
35 | /**
|
36 | * A CAA record specifies which certificate authorities (CAs) are allowed to issue certificates
|
37 | * for a domain or subdomain
|
38 | *
|
39 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#CAAFormat
|
40 | */
|
41 | RecordType["CAA"] = "CAA";
|
42 | /**
|
43 | * A CNAME record maps DNS queries for the name of the current record, such as acme.example.com,
|
44 | * to another domain (example.com or example.net) or subdomain (acme.example.com or zenith.example.org).
|
45 | *
|
46 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#CNAMEFormat
|
47 | */
|
48 | RecordType["CNAME"] = "CNAME";
|
49 | /**
|
50 | * A delegation signer (DS) record refers a zone key for a delegated subdomain zone.
|
51 | *
|
52 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#DSFormat
|
53 | */
|
54 | RecordType["DS"] = "DS";
|
55 | /**
|
56 | * An MX record specifies the names of your mail servers and, if you have two or more mail servers,
|
57 | * the priority order.
|
58 | *
|
59 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#MXFormat
|
60 | */
|
61 | RecordType["MX"] = "MX";
|
62 | /**
|
63 | * A Name Authority Pointer (NAPTR) is a type of record that is used by Dynamic Delegation Discovery
|
64 | * System (DDDS) applications to convert one value to another or to replace one value with another.
|
65 | * For example, one common use is to convert phone numbers into SIP URIs.
|
66 | *
|
67 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#NAPTRFormat
|
68 | */
|
69 | RecordType["NAPTR"] = "NAPTR";
|
70 | /**
|
71 | * An NS record identifies the name servers for the hosted zone
|
72 | *
|
73 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#NSFormat
|
74 | */
|
75 | RecordType["NS"] = "NS";
|
76 | /**
|
77 | * A PTR record maps an IP address to the corresponding domain name.
|
78 | *
|
79 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#PTRFormat
|
80 | */
|
81 | RecordType["PTR"] = "PTR";
|
82 | /**
|
83 | * A start of authority (SOA) record provides information about a domain and the corresponding Amazon
|
84 | * Route 53 hosted zone
|
85 | *
|
86 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SOAFormat
|
87 | */
|
88 | RecordType["SOA"] = "SOA";
|
89 | /**
|
90 | * SPF records were formerly used to verify the identity of the sender of email messages.
|
91 | * Instead of an SPF record, we recommend that you create a TXT record that contains the applicable value.
|
92 | *
|
93 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SPFFormat
|
94 | */
|
95 | RecordType["SPF"] = "SPF";
|
96 | /**
|
97 | * An SRV record Value element consists of four space-separated values. The first three values are
|
98 | * decimal numbers representing priority, weight, and port. The fourth value is a domain name.
|
99 | *
|
100 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SRVFormat
|
101 | */
|
102 | RecordType["SRV"] = "SRV";
|
103 | /**
|
104 | * A TXT record contains one or more strings that are enclosed in double quotation marks (").
|
105 | *
|
106 | * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#TXTFormat
|
107 | */
|
108 | RecordType["TXT"] = "TXT";
|
109 | })(RecordType = exports.RecordType || (exports.RecordType = {}));
|
110 | /**
|
111 | * Type union for a record that accepts multiple types of target.
|
112 | */
|
113 | class RecordTarget {
|
114 | /**
|
115 | *
|
116 | * @param values correspond with the chosen record type (e.g. for 'A' Type, specify one or more IP addresses)
|
117 | * @param aliasTarget alias for targets such as CloudFront distribution to route traffic to
|
118 | */
|
119 | constructor(values, aliasTarget) {
|
120 | this.values = values;
|
121 | this.aliasTarget = aliasTarget;
|
122 | try {
|
123 | jsiiDeprecationWarnings._aws_cdk_aws_route53_IAliasRecordTarget(aliasTarget);
|
124 | }
|
125 | catch (error) {
|
126 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
127 | Error.captureStackTrace(error, RecordTarget);
|
128 | }
|
129 | throw error;
|
130 | }
|
131 | }
|
132 | /**
|
133 | * Use string values as target.
|
134 | */
|
135 | static fromValues(...values) {
|
136 | return new RecordTarget(values);
|
137 | }
|
138 | /**
|
139 | * Use an alias as target.
|
140 | */
|
141 | static fromAlias(aliasTarget) {
|
142 | try {
|
143 | jsiiDeprecationWarnings._aws_cdk_aws_route53_IAliasRecordTarget(aliasTarget);
|
144 | }
|
145 | catch (error) {
|
146 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
147 | Error.captureStackTrace(error, this.fromAlias);
|
148 | }
|
149 | throw error;
|
150 | }
|
151 | return new RecordTarget(undefined, aliasTarget);
|
152 | }
|
153 | /**
|
154 | * Use ip addresses as target.
|
155 | */
|
156 | static fromIpAddresses(...ipAddresses) {
|
157 | return RecordTarget.fromValues(...ipAddresses);
|
158 | }
|
159 | }
|
160 | exports.RecordTarget = RecordTarget;
|
161 | _a = JSII_RTTI_SYMBOL_1;
|
162 | RecordTarget[_a] = { fqn: "@aws-cdk/aws-route53.RecordTarget", version: "1.204.0" };
|
163 | /**
|
164 | * A record set.
|
165 | */
|
166 | class RecordSet extends core_1.Resource {
|
167 | constructor(scope, id, props) {
|
168 | super(scope, id);
|
169 | try {
|
170 | jsiiDeprecationWarnings._aws_cdk_aws_route53_RecordSetProps(props);
|
171 | }
|
172 | catch (error) {
|
173 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
174 | Error.captureStackTrace(error, RecordSet);
|
175 | }
|
176 | throw error;
|
177 | }
|
178 | const ttl = props.target.aliasTarget ? undefined : ((props.ttl && props.ttl.toSeconds()) ?? 1800).toString();
|
179 | const recordSet = new route53_generated_1.CfnRecordSet(this, 'Resource', {
|
180 | hostedZoneId: props.zone.hostedZoneId,
|
181 | name: util_1.determineFullyQualifiedDomainName(props.recordName || props.zone.zoneName, props.zone),
|
182 | type: props.recordType,
|
183 | resourceRecords: props.target.values,
|
184 | aliasTarget: props.target.aliasTarget && props.target.aliasTarget.bind(this, props.zone),
|
185 | ttl,
|
186 | comment: props.comment,
|
187 | });
|
188 | this.domainName = recordSet.ref;
|
189 | }
|
190 | }
|
191 | exports.RecordSet = RecordSet;
|
192 | _b = JSII_RTTI_SYMBOL_1;
|
193 | RecordSet[_b] = { fqn: "@aws-cdk/aws-route53.RecordSet", version: "1.204.0" };
|
194 | /**
|
195 | * Target for a DNS A Record
|
196 | *
|
197 | * @deprecated Use RecordTarget
|
198 | */
|
199 | class AddressRecordTarget extends RecordTarget {
|
200 | }
|
201 | exports.AddressRecordTarget = AddressRecordTarget;
|
202 | _c = JSII_RTTI_SYMBOL_1;
|
203 | AddressRecordTarget[_c] = { fqn: "@aws-cdk/aws-route53.AddressRecordTarget", version: "1.204.0" };
|
204 | /**
|
205 | * A DNS A record
|
206 | *
|
207 | * @resource AWS::Route53::RecordSet
|
208 | */
|
209 | class ARecord extends RecordSet {
|
210 | constructor(scope, id, props) {
|
211 | super(scope, id, {
|
212 | ...props,
|
213 | recordType: RecordType.A,
|
214 | target: props.target,
|
215 | });
|
216 | try {
|
217 | jsiiDeprecationWarnings._aws_cdk_aws_route53_ARecordProps(props);
|
218 | }
|
219 | catch (error) {
|
220 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
221 | Error.captureStackTrace(error, ARecord);
|
222 | }
|
223 | throw error;
|
224 | }
|
225 | }
|
226 | }
|
227 | exports.ARecord = ARecord;
|
228 | _d = JSII_RTTI_SYMBOL_1;
|
229 | ARecord[_d] = { fqn: "@aws-cdk/aws-route53.ARecord", version: "1.204.0" };
|
230 | /**
|
231 | * A DNS AAAA record
|
232 | *
|
233 | * @resource AWS::Route53::RecordSet
|
234 | */
|
235 | class AaaaRecord extends RecordSet {
|
236 | constructor(scope, id, props) {
|
237 | super(scope, id, {
|
238 | ...props,
|
239 | recordType: RecordType.AAAA,
|
240 | target: props.target,
|
241 | });
|
242 | try {
|
243 | jsiiDeprecationWarnings._aws_cdk_aws_route53_AaaaRecordProps(props);
|
244 | }
|
245 | catch (error) {
|
246 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
247 | Error.captureStackTrace(error, AaaaRecord);
|
248 | }
|
249 | throw error;
|
250 | }
|
251 | }
|
252 | }
|
253 | exports.AaaaRecord = AaaaRecord;
|
254 | _e = JSII_RTTI_SYMBOL_1;
|
255 | AaaaRecord[_e] = { fqn: "@aws-cdk/aws-route53.AaaaRecord", version: "1.204.0" };
|
256 | /**
|
257 | * A DNS CNAME record
|
258 | *
|
259 | * @resource AWS::Route53::RecordSet
|
260 | */
|
261 | class CnameRecord extends RecordSet {
|
262 | constructor(scope, id, props) {
|
263 | super(scope, id, {
|
264 | ...props,
|
265 | recordType: RecordType.CNAME,
|
266 | target: RecordTarget.fromValues(props.domainName),
|
267 | });
|
268 | try {
|
269 | jsiiDeprecationWarnings._aws_cdk_aws_route53_CnameRecordProps(props);
|
270 | }
|
271 | catch (error) {
|
272 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
273 | Error.captureStackTrace(error, CnameRecord);
|
274 | }
|
275 | throw error;
|
276 | }
|
277 | }
|
278 | }
|
279 | exports.CnameRecord = CnameRecord;
|
280 | _f = JSII_RTTI_SYMBOL_1;
|
281 | CnameRecord[_f] = { fqn: "@aws-cdk/aws-route53.CnameRecord", version: "1.204.0" };
|
282 | /**
|
283 | * A DNS TXT record
|
284 | *
|
285 | * @resource AWS::Route53::RecordSet
|
286 | */
|
287 | class TxtRecord extends RecordSet {
|
288 | constructor(scope, id, props) {
|
289 | super(scope, id, {
|
290 | ...props,
|
291 | recordType: RecordType.TXT,
|
292 | target: RecordTarget.fromValues(...props.values.map(v => formatTxt(v))),
|
293 | });
|
294 | try {
|
295 | jsiiDeprecationWarnings._aws_cdk_aws_route53_TxtRecordProps(props);
|
296 | }
|
297 | catch (error) {
|
298 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
299 | Error.captureStackTrace(error, TxtRecord);
|
300 | }
|
301 | throw error;
|
302 | }
|
303 | }
|
304 | }
|
305 | exports.TxtRecord = TxtRecord;
|
306 | _g = JSII_RTTI_SYMBOL_1;
|
307 | TxtRecord[_g] = { fqn: "@aws-cdk/aws-route53.TxtRecord", version: "1.204.0" };
|
308 | /**
|
309 | * Formats a text value for use in a TXT record
|
310 | *
|
311 | * Use `JSON.stringify` to correctly escape and enclose in double quotes ("").
|
312 | *
|
313 | * DNS TXT records can contain up to 255 characters in a single string. TXT
|
314 | * record strings over 255 characters must be split into multiple text strings
|
315 | * within the same record.
|
316 | *
|
317 | * @see https://aws.amazon.com/premiumsupport/knowledge-center/route53-resolve-dkim-text-record-error/
|
318 | */
|
319 | function formatTxt(string) {
|
320 | const result = [];
|
321 | let idx = 0;
|
322 | while (idx < string.length) {
|
323 | result.push(string.slice(idx, idx += 255)); // chunks of 255 characters long
|
324 | }
|
325 | return result.map(r => JSON.stringify(r)).join('');
|
326 | }
|
327 | /**
|
328 | * A DNS SRV record
|
329 | *
|
330 | * @resource AWS::Route53::RecordSet
|
331 | */
|
332 | class SrvRecord extends RecordSet {
|
333 | constructor(scope, id, props) {
|
334 | super(scope, id, {
|
335 | ...props,
|
336 | recordType: RecordType.SRV,
|
337 | target: RecordTarget.fromValues(...props.values.map(v => `${v.priority} ${v.weight} ${v.port} ${v.hostName}`)),
|
338 | });
|
339 | try {
|
340 | jsiiDeprecationWarnings._aws_cdk_aws_route53_SrvRecordProps(props);
|
341 | }
|
342 | catch (error) {
|
343 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
344 | Error.captureStackTrace(error, SrvRecord);
|
345 | }
|
346 | throw error;
|
347 | }
|
348 | }
|
349 | }
|
350 | exports.SrvRecord = SrvRecord;
|
351 | _h = JSII_RTTI_SYMBOL_1;
|
352 | SrvRecord[_h] = { fqn: "@aws-cdk/aws-route53.SrvRecord", version: "1.204.0" };
|
353 | /**
|
354 | * The CAA tag.
|
355 | */
|
356 | var CaaTag;
|
357 | (function (CaaTag) {
|
358 | /**
|
359 | * Explicity authorizes a single certificate authority to issue a
|
360 | * certificate (any type) for the hostname.
|
361 | */
|
362 | CaaTag["ISSUE"] = "issue";
|
363 | /**
|
364 | * Explicity authorizes a single certificate authority to issue a
|
365 | * wildcard certificate (and only wildcard) for the hostname.
|
366 | */
|
367 | CaaTag["ISSUEWILD"] = "issuewild";
|
368 | /**
|
369 | * Specifies a URL to which a certificate authority may report policy
|
370 | * violations.
|
371 | */
|
372 | CaaTag["IODEF"] = "iodef";
|
373 | })(CaaTag = exports.CaaTag || (exports.CaaTag = {}));
|
374 | /**
|
375 | * A DNS CAA record
|
376 | *
|
377 | * @resource AWS::Route53::RecordSet
|
378 | */
|
379 | class CaaRecord extends RecordSet {
|
380 | constructor(scope, id, props) {
|
381 | super(scope, id, {
|
382 | ...props,
|
383 | recordType: RecordType.CAA,
|
384 | target: RecordTarget.fromValues(...props.values.map(v => `${v.flag} ${v.tag} "${v.value}"`)),
|
385 | });
|
386 | try {
|
387 | jsiiDeprecationWarnings._aws_cdk_aws_route53_CaaRecordProps(props);
|
388 | }
|
389 | catch (error) {
|
390 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
391 | Error.captureStackTrace(error, CaaRecord);
|
392 | }
|
393 | throw error;
|
394 | }
|
395 | }
|
396 | }
|
397 | exports.CaaRecord = CaaRecord;
|
398 | _j = JSII_RTTI_SYMBOL_1;
|
399 | CaaRecord[_j] = { fqn: "@aws-cdk/aws-route53.CaaRecord", version: "1.204.0" };
|
400 | /**
|
401 | * A DNS Amazon CAA record.
|
402 | *
|
403 | * A CAA record to restrict certificate authorities allowed
|
404 | * to issue certificates for a domain to Amazon only.
|
405 | *
|
406 | * @resource AWS::Route53::RecordSet
|
407 | */
|
408 | class CaaAmazonRecord extends CaaRecord {
|
409 | constructor(scope, id, props) {
|
410 | super(scope, id, {
|
411 | ...props,
|
412 | values: [
|
413 | {
|
414 | flag: 0,
|
415 | tag: CaaTag.ISSUE,
|
416 | value: 'amazon.com',
|
417 | },
|
418 | ],
|
419 | });
|
420 | try {
|
421 | jsiiDeprecationWarnings._aws_cdk_aws_route53_CaaAmazonRecordProps(props);
|
422 | }
|
423 | catch (error) {
|
424 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
425 | Error.captureStackTrace(error, CaaAmazonRecord);
|
426 | }
|
427 | throw error;
|
428 | }
|
429 | }
|
430 | }
|
431 | exports.CaaAmazonRecord = CaaAmazonRecord;
|
432 | _k = JSII_RTTI_SYMBOL_1;
|
433 | CaaAmazonRecord[_k] = { fqn: "@aws-cdk/aws-route53.CaaAmazonRecord", version: "1.204.0" };
|
434 | /**
|
435 | * A DNS MX record
|
436 | *
|
437 | * @resource AWS::Route53::RecordSet
|
438 | */
|
439 | class MxRecord extends RecordSet {
|
440 | constructor(scope, id, props) {
|
441 | super(scope, id, {
|
442 | ...props,
|
443 | recordType: RecordType.MX,
|
444 | target: RecordTarget.fromValues(...props.values.map(v => `${v.priority} ${v.hostName}`)),
|
445 | });
|
446 | try {
|
447 | jsiiDeprecationWarnings._aws_cdk_aws_route53_MxRecordProps(props);
|
448 | }
|
449 | catch (error) {
|
450 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
451 | Error.captureStackTrace(error, MxRecord);
|
452 | }
|
453 | throw error;
|
454 | }
|
455 | }
|
456 | }
|
457 | exports.MxRecord = MxRecord;
|
458 | _l = JSII_RTTI_SYMBOL_1;
|
459 | MxRecord[_l] = { fqn: "@aws-cdk/aws-route53.MxRecord", version: "1.204.0" };
|
460 | /**
|
461 | * A DNS NS record
|
462 | *
|
463 | * @resource AWS::Route53::RecordSet
|
464 | */
|
465 | class NsRecord extends RecordSet {
|
466 | constructor(scope, id, props) {
|
467 | super(scope, id, {
|
468 | ...props,
|
469 | recordType: RecordType.NS,
|
470 | target: RecordTarget.fromValues(...props.values),
|
471 | });
|
472 | try {
|
473 | jsiiDeprecationWarnings._aws_cdk_aws_route53_NsRecordProps(props);
|
474 | }
|
475 | catch (error) {
|
476 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
477 | Error.captureStackTrace(error, NsRecord);
|
478 | }
|
479 | throw error;
|
480 | }
|
481 | }
|
482 | }
|
483 | exports.NsRecord = NsRecord;
|
484 | _m = JSII_RTTI_SYMBOL_1;
|
485 | NsRecord[_m] = { fqn: "@aws-cdk/aws-route53.NsRecord", version: "1.204.0" };
|
486 | /**
|
487 | * A DNS DS record
|
488 | *
|
489 | * @resource AWS::Route53::RecordSet
|
490 | */
|
491 | class DsRecord extends RecordSet {
|
492 | constructor(scope, id, props) {
|
493 | super(scope, id, {
|
494 | ...props,
|
495 | recordType: RecordType.DS,
|
496 | target: RecordTarget.fromValues(...props.values),
|
497 | });
|
498 | try {
|
499 | jsiiDeprecationWarnings._aws_cdk_aws_route53_DsRecordProps(props);
|
500 | }
|
501 | catch (error) {
|
502 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
503 | Error.captureStackTrace(error, DsRecord);
|
504 | }
|
505 | throw error;
|
506 | }
|
507 | }
|
508 | }
|
509 | exports.DsRecord = DsRecord;
|
510 | _o = JSII_RTTI_SYMBOL_1;
|
511 | DsRecord[_o] = { fqn: "@aws-cdk/aws-route53.DsRecord", version: "1.204.0" };
|
512 | /**
|
513 | * A record to delegate further lookups to a different set of name servers.
|
514 | */
|
515 | class ZoneDelegationRecord extends RecordSet {
|
516 | constructor(scope, id, props) {
|
517 | super(scope, id, {
|
518 | ...props,
|
519 | recordType: RecordType.NS,
|
520 | target: RecordTarget.fromValues(...core_1.Token.isUnresolved(props.nameServers)
|
521 | ? props.nameServers // Can't map a string-array token!
|
522 | : props.nameServers.map(ns => (core_1.Token.isUnresolved(ns) || ns.endsWith('.')) ? ns : `${ns}.`)),
|
523 | ttl: props.ttl || core_1.Duration.days(2),
|
524 | });
|
525 | try {
|
526 | jsiiDeprecationWarnings._aws_cdk_aws_route53_ZoneDelegationRecordProps(props);
|
527 | }
|
528 | catch (error) {
|
529 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
530 | Error.captureStackTrace(error, ZoneDelegationRecord);
|
531 | }
|
532 | throw error;
|
533 | }
|
534 | }
|
535 | }
|
536 | exports.ZoneDelegationRecord = ZoneDelegationRecord;
|
537 | _p = JSII_RTTI_SYMBOL_1;
|
538 | ZoneDelegationRecord[_p] = { fqn: "@aws-cdk/aws-route53.ZoneDelegationRecord", version: "1.204.0" };
|
539 | /**
|
540 | * A Cross Account Zone Delegation record
|
541 | */
|
542 | class CrossAccountZoneDelegationRecord extends core_2.Construct {
|
543 | constructor(scope, id, props) {
|
544 | super(scope, id);
|
545 | try {
|
546 | jsiiDeprecationWarnings._aws_cdk_aws_route53_CrossAccountZoneDelegationRecordProps(props);
|
547 | }
|
548 | catch (error) {
|
549 | if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
|
550 | Error.captureStackTrace(error, CrossAccountZoneDelegationRecord);
|
551 | }
|
552 | throw error;
|
553 | }
|
554 | if (!props.parentHostedZoneName && !props.parentHostedZoneId) {
|
555 | throw Error('At least one of parentHostedZoneName or parentHostedZoneId is required');
|
556 | }
|
557 | if (props.parentHostedZoneName && props.parentHostedZoneId) {
|
558 | throw Error('Only one of parentHostedZoneName and parentHostedZoneId is supported');
|
559 | }
|
560 | const provider = core_1.CustomResourceProvider.getOrCreateProvider(this, CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE, {
|
561 | codeDirectory: path.join(__dirname, 'cross-account-zone-delegation-handler'),
|
562 | runtime: core_1.CustomResourceProviderRuntime.NODEJS_14_X,
|
563 | });
|
564 | const role = iam.Role.fromRoleArn(this, 'cross-account-zone-delegation-handler-role', provider.roleArn);
|
565 | const addToPrinciplePolicyResult = role.addToPrincipalPolicy(new iam.PolicyStatement({
|
566 | effect: iam.Effect.ALLOW,
|
567 | actions: ['sts:AssumeRole'],
|
568 | resources: [props.delegationRole.roleArn],
|
569 | }));
|
570 | const customResource = new core_1.CustomResource(this, 'CrossAccountZoneDelegationCustomResource', {
|
571 | resourceType: CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE,
|
572 | serviceToken: provider.serviceToken,
|
573 | removalPolicy: props.removalPolicy,
|
574 | properties: {
|
575 | AssumeRoleArn: props.delegationRole.roleArn,
|
576 | ParentZoneName: props.parentHostedZoneName,
|
577 | ParentZoneId: props.parentHostedZoneId,
|
578 | DelegatedZoneName: props.delegatedZone.zoneName,
|
579 | DelegatedZoneNameServers: props.delegatedZone.hostedZoneNameServers,
|
580 | TTL: (props.ttl || core_1.Duration.days(2)).toSeconds(),
|
581 | },
|
582 | });
|
583 | if (addToPrinciplePolicyResult.policyDependable) {
|
584 | customResource.node.addDependency(addToPrinciplePolicyResult.policyDependable);
|
585 | }
|
586 | }
|
587 | }
|
588 | exports.CrossAccountZoneDelegationRecord = CrossAccountZoneDelegationRecord;
|
589 | _q = JSII_RTTI_SYMBOL_1;
|
590 | CrossAccountZoneDelegationRecord[_q] = { fqn: "@aws-cdk/aws-route53.CrossAccountZoneDelegationRecord", version: "1.204.0" };
|
591 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-set.js","sourceRoot":"","sources":["record-set.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as iam from '@aws-cdk/aws-iam';\nimport { CustomResource, CustomResourceProvider, CustomResourceProviderRuntime, Duration, IResource, RemovalPolicy, Resource, Token } from '@aws-cdk/core';\nimport { Construct } from 'constructs';\nimport { IAliasRecordTarget } from './alias-record-target';\nimport { IHostedZone } from './hosted-zone-ref';\nimport { CfnRecordSet } from './route53.generated';\nimport { determineFullyQualifiedDomainName } from './util';\n\nconst CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE = 'Custom::CrossAccountZoneDelegation';\n\n// v2 - keep this import as a separate section to reduce merge conflict when forward merging with the v2 branch.\n// eslint-disable-next-line\nimport { Construct as CoreConstruct } from '@aws-cdk/core';\n\n/**\n * A record set\n */\nexport interface IRecordSet extends IResource {\n  /**\n   * The domain name of the record\n   */\n  readonly domainName: string;\n}\n\n/**\n * The record type.\n */\nexport enum RecordType {\n  /**\n   * route traffic to a resource, such as a web server, using an IPv4 address in dotted decimal\n   * notation\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#AFormat\n   */\n  A = 'A',\n\n  /**\n   * route traffic to a resource, such as a web server, using an IPv6 address in colon-separated\n   * hexadecimal format\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#AAAAFormat\n   */\n  AAAA = 'AAAA',\n\n  /**\n   * A CAA record specifies which certificate authorities (CAs) are allowed to issue certificates\n   * for a domain or subdomain\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#CAAFormat\n   */\n  CAA = 'CAA',\n\n  /**\n   * A CNAME record maps DNS queries for the name of the current record, such as acme.example.com,\n   * to another domain (example.com or example.net) or subdomain (acme.example.com or zenith.example.org).\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#CNAMEFormat\n   */\n  CNAME = 'CNAME',\n\n  /**\n   * A delegation signer (DS) record refers a zone key for a delegated subdomain zone.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#DSFormat\n   */\n  DS = 'DS',\n\n  /**\n   * An MX record specifies the names of your mail servers and, if you have two or more mail servers,\n   * the priority order.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#MXFormat\n   */\n  MX = 'MX',\n\n  /**\n   * A Name Authority Pointer (NAPTR) is a type of record that is used by Dynamic Delegation Discovery\n   * System (DDDS) applications to convert one value to another or to replace one value with another.\n   * For example, one common use is to convert phone numbers into SIP URIs.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#NAPTRFormat\n   */\n  NAPTR = 'NAPTR',\n\n  /**\n   * An NS record identifies the name servers for the hosted zone\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#NSFormat\n   */\n  NS = 'NS',\n\n  /**\n   * A PTR record maps an IP address to the corresponding domain name.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#PTRFormat\n   */\n  PTR = 'PTR',\n\n  /**\n   * A start of authority (SOA) record provides information about a domain and the corresponding Amazon\n   * Route 53 hosted zone\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SOAFormat\n   */\n  SOA = 'SOA',\n\n  /**\n   * SPF records were formerly used to verify the identity of the sender of email messages.\n   * Instead of an SPF record, we recommend that you create a TXT record that contains the applicable value.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SPFFormat\n   */\n  SPF = 'SPF',\n\n  /**\n   * An SRV record Value element consists of four space-separated values. The first three values are\n   * decimal numbers representing priority, weight, and port. The fourth value is a domain name.\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#SRVFormat\n   */\n  SRV = 'SRV',\n\n  /**\n   * A TXT record contains one or more strings that are enclosed in double quotation marks (\").\n   *\n   * @see https://docs.aws.amazon.com/Route53/latest/DeveloperGuide/ResourceRecordTypes.html#TXTFormat\n   */\n  TXT = 'TXT'\n}\n\n/**\n * Options for a RecordSet.\n */\nexport interface RecordSetOptions {\n  /**\n   * The hosted zone in which to define the new record.\n   */\n  readonly zone: IHostedZone;\n\n  /**\n   * The domain name for this record.\n   *\n   * @default zone root\n   */\n  readonly recordName?: string;\n\n  /**\n   * The resource record cache time to live (TTL).\n   *\n   * @default Duration.minutes(30)\n   */\n  readonly ttl?: Duration;\n\n  /**\n   * A comment to add on the record.\n   *\n   * @default no comment\n   */\n  readonly comment?: string;\n}\n\n/**\n * Type union for a record that accepts multiple types of target.\n */\nexport class RecordTarget {\n  /**\n   * Use string values as target.\n   */\n  public static fromValues(...values: string[]) {\n    return new RecordTarget(values);\n  }\n\n  /**\n   * Use an alias as target.\n   */\n  public static fromAlias(aliasTarget: IAliasRecordTarget) {\n    return new RecordTarget(undefined, aliasTarget);\n  }\n\n  /**\n   * Use ip addresses as target.\n   */\n  public static fromIpAddresses(...ipAddresses: string[]) {\n    return RecordTarget.fromValues(...ipAddresses);\n  }\n\n  /**\n   *\n   * @param values correspond with the chosen record type (e.g. for 'A' Type, specify one or more IP addresses)\n   * @param aliasTarget alias for targets such as CloudFront distribution to route traffic to\n   */\n  protected constructor(public readonly values?: string[], public readonly aliasTarget?: IAliasRecordTarget) {\n  }\n}\n\n/**\n * Construction properties for a RecordSet.\n */\nexport interface RecordSetProps extends RecordSetOptions {\n  /**\n   * The record type.\n   */\n  readonly recordType: RecordType;\n\n  /**\n   * The target for this record, either `RecordTarget.fromValues()` or\n   * `RecordTarget.fromAlias()`.\n   */\n  readonly target: RecordTarget;\n}\n\n/**\n * A record set.\n */\nexport class RecordSet extends Resource implements IRecordSet {\n  public readonly domainName: string;\n\n  constructor(scope: Construct, id: string, props: RecordSetProps) {\n    super(scope, id);\n\n    const ttl = props.target.aliasTarget ? undefined : ((props.ttl && props.ttl.toSeconds()) ?? 1800).toString();\n\n    const recordSet = new CfnRecordSet(this, 'Resource', {\n      hostedZoneId: props.zone.hostedZoneId,\n      name: determineFullyQualifiedDomainName(props.recordName || props.zone.zoneName, props.zone),\n      type: props.recordType,\n      resourceRecords: props.target.values,\n      aliasTarget: props.target.aliasTarget && props.target.aliasTarget.bind(this, props.zone),\n      ttl,\n      comment: props.comment,\n    });\n\n    this.domainName = recordSet.ref;\n  }\n}\n\n/**\n * Target for a DNS A Record\n *\n * @deprecated Use RecordTarget\n */\nexport class AddressRecordTarget extends RecordTarget {\n}\n\n/**\n * Construction properties for a ARecord.\n */\nexport interface ARecordProps extends RecordSetOptions {\n  /**\n   * The target.\n   */\n  readonly target: RecordTarget;\n}\n\n/**\n * A DNS A record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class ARecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: ARecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.A,\n      target: props.target,\n    });\n  }\n}\n\n/**\n * Construction properties for a AaaaRecord.\n */\nexport interface AaaaRecordProps extends RecordSetOptions {\n  /**\n   * The target.\n   */\n  readonly target: RecordTarget;\n}\n\n/**\n * A DNS AAAA record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class AaaaRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: AaaaRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.AAAA,\n      target: props.target,\n    });\n  }\n}\n\n/**\n * Construction properties for a CnameRecord.\n */\nexport interface CnameRecordProps extends RecordSetOptions {\n  /**\n   * The domain name.\n   */\n  readonly domainName: string;\n}\n\n/**\n * A DNS CNAME record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class CnameRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: CnameRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.CNAME,\n      target: RecordTarget.fromValues(props.domainName),\n    });\n  }\n}\n\n/**\n * Construction properties for a TxtRecord.\n */\nexport interface TxtRecordProps extends RecordSetOptions {\n  /**\n   * The text values.\n   */\n  readonly values: string[];\n}\n\n/**\n * A DNS TXT record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class TxtRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: TxtRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.TXT,\n      target: RecordTarget.fromValues(...props.values.map(v => formatTxt(v))),\n    });\n  }\n}\n\n/**\n * Formats a text value for use in a TXT record\n *\n * Use `JSON.stringify` to correctly escape and enclose in double quotes (\"\").\n *\n * DNS TXT records can contain up to 255 characters in a single string. TXT\n * record strings over 255 characters must be split into multiple text strings\n * within the same record.\n *\n * @see https://aws.amazon.com/premiumsupport/knowledge-center/route53-resolve-dkim-text-record-error/\n */\nfunction formatTxt(string: string): string {\n  const result = [];\n  let idx = 0;\n  while (idx < string.length) {\n    result.push(string.slice(idx, idx += 255)); // chunks of 255 characters long\n  }\n  return result.map(r => JSON.stringify(r)).join('');\n}\n\n/**\n * Properties for a SRV record value.\n */\nexport interface SrvRecordValue {\n  /**\n   * The priority.\n   */\n  readonly priority: number;\n\n  /**\n   * The weight.\n   */\n  readonly weight: number;\n\n  /**\n   * The port.\n   */\n  readonly port: number;\n\n  /**\n   * The server host name.\n   */\n  readonly hostName: string;\n}\n/**\n * Construction properties for a SrvRecord.\n */\nexport interface SrvRecordProps extends RecordSetOptions {\n  /**\n   * The values.\n   */\n  readonly values: SrvRecordValue[];\n}\n\n/**\n * A DNS SRV record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class SrvRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: SrvRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.SRV,\n      target: RecordTarget.fromValues(...props.values.map(v => `${v.priority} ${v.weight} ${v.port} ${v.hostName}`)),\n    });\n  }\n}\n\n/**\n * The CAA tag.\n */\nexport enum CaaTag {\n  /**\n   * Explicity authorizes a single certificate authority to issue a\n   * certificate (any type) for the hostname.\n   */\n  ISSUE = 'issue',\n\n  /**\n   * Explicity authorizes a single certificate authority to issue a\n   * wildcard certificate (and only wildcard) for the hostname.\n   */\n  ISSUEWILD = 'issuewild',\n\n  /**\n   * Specifies a URL to which a certificate authority may report policy\n   * violations.\n   */\n  IODEF = 'iodef',\n}\n\n/**\n * Properties for a CAA record value.\n */\nexport interface CaaRecordValue {\n  /**\n   * The flag.\n   */\n  readonly flag: number;\n\n  /**\n   * The tag.\n   */\n  readonly tag: CaaTag;\n\n  /**\n   * The value associated with the tag.\n   */\n  readonly value: string;\n}\n\n/**\n * Construction properties for a CaaRecord.\n */\nexport interface CaaRecordProps extends RecordSetOptions {\n  /**\n   * The values.\n   */\n  readonly values: CaaRecordValue[];\n}\n\n/**\n * A DNS CAA record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class CaaRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: CaaRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.CAA,\n      target: RecordTarget.fromValues(...props.values.map(v => `${v.flag} ${v.tag} \"${v.value}\"`)),\n    });\n  }\n}\n\n/**\n * Construction properties for a CaaAmazonRecord.\n */\nexport interface CaaAmazonRecordProps extends RecordSetOptions {}\n\n/**\n * A DNS Amazon CAA record.\n *\n * A CAA record to restrict certificate authorities allowed\n * to issue certificates for a domain to Amazon only.\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class CaaAmazonRecord extends CaaRecord {\n  constructor(scope: Construct, id: string, props: CaaAmazonRecordProps) {\n    super(scope, id, {\n      ...props,\n      values: [\n        {\n          flag: 0,\n          tag: CaaTag.ISSUE,\n          value: 'amazon.com',\n        },\n      ],\n    });\n  }\n}\n\n/**\n * Properties for a MX record value.\n */\nexport interface MxRecordValue {\n  /**\n   * The priority.\n   */\n  readonly priority: number;\n\n  /**\n   * The mail server host name.\n   */\n  readonly hostName: string;\n}\n\n/**\n * Construction properties for a MxRecord.\n */\nexport interface MxRecordProps extends RecordSetOptions {\n  /**\n   * The values.\n   */\n  readonly values: MxRecordValue[];\n}\n\n/**\n * A DNS MX record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class MxRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: MxRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.MX,\n      target: RecordTarget.fromValues(...props.values.map(v => `${v.priority} ${v.hostName}`)),\n    });\n  }\n}\n\n/**\n * Construction properties for a NSRecord.\n */\nexport interface NsRecordProps extends RecordSetOptions {\n  /**\n   * The NS values.\n   */\n  readonly values: string[];\n}\n\n/**\n * A DNS NS record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class NsRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: NsRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.NS,\n      target: RecordTarget.fromValues(...props.values),\n    });\n  }\n}\n\n/**\n * Construction properties for a DSRecord.\n */\nexport interface DsRecordProps extends RecordSetOptions {\n  /**\n   * The DS values.\n   */\n  readonly values: string[];\n}\n\n/**\n * A DNS DS record\n *\n * @resource AWS::Route53::RecordSet\n */\nexport class DsRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: DsRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.DS,\n      target: RecordTarget.fromValues(...props.values),\n    });\n  }\n}\n\n/**\n * Construction properties for a ZoneDelegationRecord\n */\nexport interface ZoneDelegationRecordProps extends RecordSetOptions {\n  /**\n   * The name servers to report in the delegation records.\n   */\n  readonly nameServers: string[];\n}\n\n/**\n * A record to delegate further lookups to a different set of name servers.\n */\nexport class ZoneDelegationRecord extends RecordSet {\n  constructor(scope: Construct, id: string, props: ZoneDelegationRecordProps) {\n    super(scope, id, {\n      ...props,\n      recordType: RecordType.NS,\n      target: RecordTarget.fromValues(...Token.isUnresolved(props.nameServers)\n        ? props.nameServers // Can't map a string-array token!\n        : props.nameServers.map(ns => (Token.isUnresolved(ns) || ns.endsWith('.')) ? ns : `${ns}.`),\n      ),\n      ttl: props.ttl || Duration.days(2),\n    });\n  }\n}\n\n/**\n * Construction properties for a CrossAccountZoneDelegationRecord\n */\nexport interface CrossAccountZoneDelegationRecordProps {\n  /**\n   * The zone to be delegated\n   */\n  readonly delegatedZone: IHostedZone;\n\n  /**\n   * The hosted zone name in the parent account\n   *\n   * @default - no zone name\n   */\n  readonly parentHostedZoneName?: string;\n\n  /**\n   * The hosted zone id in the parent account\n   *\n   * @default - no zone id\n   */\n  readonly parentHostedZoneId?: string;\n\n  /**\n   * The delegation role in the parent account\n   */\n  readonly delegationRole: iam.IRole;\n\n  /**\n   * The resource record cache time to live (TTL).\n   *\n   * @default Duration.days(2)\n   */\n  readonly ttl?: Duration;\n\n  /**\n   * The removal policy to apply to the record set.\n   *\n   * @default RemovalPolicy.DESTROY\n   */\n  readonly removalPolicy?: RemovalPolicy;\n}\n\n/**\n * A Cross Account Zone Delegation record\n */\nexport class CrossAccountZoneDelegationRecord extends CoreConstruct {\n  constructor(scope: Construct, id: string, props: CrossAccountZoneDelegationRecordProps) {\n    super(scope, id);\n\n    if (!props.parentHostedZoneName && !props.parentHostedZoneId) {\n      throw Error('At least one of parentHostedZoneName or parentHostedZoneId is required');\n    }\n\n    if (props.parentHostedZoneName && props.parentHostedZoneId) {\n      throw Error('Only one of parentHostedZoneName and parentHostedZoneId is supported');\n    }\n\n    const provider = CustomResourceProvider.getOrCreateProvider(this, CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE, {\n      codeDirectory: path.join(__dirname, 'cross-account-zone-delegation-handler'),\n      runtime: CustomResourceProviderRuntime.NODEJS_14_X,\n    });\n\n    const role = iam.Role.fromRoleArn(this, 'cross-account-zone-delegation-handler-role', provider.roleArn);\n\n    const addToPrinciplePolicyResult = role.addToPrincipalPolicy(new iam.PolicyStatement({\n      effect: iam.Effect.ALLOW,\n      actions: ['sts:AssumeRole'],\n      resources: [props.delegationRole.roleArn],\n    }));\n\n    const customResource = new CustomResource(this, 'CrossAccountZoneDelegationCustomResource', {\n      resourceType: CROSS_ACCOUNT_ZONE_DELEGATION_RESOURCE_TYPE,\n      serviceToken: provider.serviceToken,\n      removalPolicy: props.removalPolicy,\n      properties: {\n        AssumeRoleArn: props.delegationRole.roleArn,\n        ParentZoneName: props.parentHostedZoneName,\n        ParentZoneId: props.parentHostedZoneId,\n        DelegatedZoneName: props.delegatedZone.zoneName,\n        DelegatedZoneNameServers: props.delegatedZone.hostedZoneNameServers!,\n        TTL: (props.ttl || Duration.days(2)).toSeconds(),\n      },\n    });\n\n    if (addToPrinciplePolicyResult.policyDependable) {\n      customResource.node.addDependency(addToPrinciplePolicyResult.policyDependable);\n    }\n  }\n}\n"]} |
\ | No newline at end of file |