UNPKG

57.1 kBJavaScriptView Raw
1"use strict";
2var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
3Object.defineProperty(exports, "__esModule", { value: true });
4exports.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;
5const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
6const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
7const path = require("path");
8const iam = require("@aws-cdk/aws-iam");
9const core_1 = require("@aws-cdk/core");
10const route53_generated_1 = require("./route53.generated");
11const util_1 = require("./util");
12const 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
15const core_2 = require("@aws-cdk/core");
16/**
17 * The record type.
18 */
19var 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 */
113class 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}
160exports.RecordTarget = RecordTarget;
161_a = JSII_RTTI_SYMBOL_1;
162RecordTarget[_a] = { fqn: "@aws-cdk/aws-route53.RecordTarget", version: "1.204.0" };
163/**
164 * A record set.
165 */
166class 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}
191exports.RecordSet = RecordSet;
192_b = JSII_RTTI_SYMBOL_1;
193RecordSet[_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 */
199class AddressRecordTarget extends RecordTarget {
200}
201exports.AddressRecordTarget = AddressRecordTarget;
202_c = JSII_RTTI_SYMBOL_1;
203AddressRecordTarget[_c] = { fqn: "@aws-cdk/aws-route53.AddressRecordTarget", version: "1.204.0" };
204/**
205 * A DNS A record
206 *
207 * @resource AWS::Route53::RecordSet
208 */
209class 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}
227exports.ARecord = ARecord;
228_d = JSII_RTTI_SYMBOL_1;
229ARecord[_d] = { fqn: "@aws-cdk/aws-route53.ARecord", version: "1.204.0" };
230/**
231 * A DNS AAAA record
232 *
233 * @resource AWS::Route53::RecordSet
234 */
235class 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}
253exports.AaaaRecord = AaaaRecord;
254_e = JSII_RTTI_SYMBOL_1;
255AaaaRecord[_e] = { fqn: "@aws-cdk/aws-route53.AaaaRecord", version: "1.204.0" };
256/**
257 * A DNS CNAME record
258 *
259 * @resource AWS::Route53::RecordSet
260 */
261class 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}
279exports.CnameRecord = CnameRecord;
280_f = JSII_RTTI_SYMBOL_1;
281CnameRecord[_f] = { fqn: "@aws-cdk/aws-route53.CnameRecord", version: "1.204.0" };
282/**
283 * A DNS TXT record
284 *
285 * @resource AWS::Route53::RecordSet
286 */
287class 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}
305exports.TxtRecord = TxtRecord;
306_g = JSII_RTTI_SYMBOL_1;
307TxtRecord[_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 */
319function 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 */
332class 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}
350exports.SrvRecord = SrvRecord;
351_h = JSII_RTTI_SYMBOL_1;
352SrvRecord[_h] = { fqn: "@aws-cdk/aws-route53.SrvRecord", version: "1.204.0" };
353/**
354 * The CAA tag.
355 */
356var 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 */
379class 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}
397exports.CaaRecord = CaaRecord;
398_j = JSII_RTTI_SYMBOL_1;
399CaaRecord[_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 */
408class 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}
431exports.CaaAmazonRecord = CaaAmazonRecord;
432_k = JSII_RTTI_SYMBOL_1;
433CaaAmazonRecord[_k] = { fqn: "@aws-cdk/aws-route53.CaaAmazonRecord", version: "1.204.0" };
434/**
435 * A DNS MX record
436 *
437 * @resource AWS::Route53::RecordSet
438 */
439class 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}
457exports.MxRecord = MxRecord;
458_l = JSII_RTTI_SYMBOL_1;
459MxRecord[_l] = { fqn: "@aws-cdk/aws-route53.MxRecord", version: "1.204.0" };
460/**
461 * A DNS NS record
462 *
463 * @resource AWS::Route53::RecordSet
464 */
465class 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}
483exports.NsRecord = NsRecord;
484_m = JSII_RTTI_SYMBOL_1;
485NsRecord[_m] = { fqn: "@aws-cdk/aws-route53.NsRecord", version: "1.204.0" };
486/**
487 * A DNS DS record
488 *
489 * @resource AWS::Route53::RecordSet
490 */
491class 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}
509exports.DsRecord = DsRecord;
510_o = JSII_RTTI_SYMBOL_1;
511DsRecord[_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 */
515class 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}
536exports.ZoneDelegationRecord = ZoneDelegationRecord;
537_p = JSII_RTTI_SYMBOL_1;
538ZoneDelegationRecord[_p] = { fqn: "@aws-cdk/aws-route53.ZoneDelegationRecord", version: "1.204.0" };
539/**
540 * A Cross Account Zone Delegation record
541 */
542class 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}
588exports.CrossAccountZoneDelegationRecord = CrossAccountZoneDelegationRecord;
589_q = JSII_RTTI_SYMBOL_1;
590CrossAccountZoneDelegationRecord[_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