@microsoft/terraform-cdk-constructs 1.7.1 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +46476 -27231
- package/API.md +68443 -28286
- package/lib/azure-actiongroup/lib/action-group.js +1 -1
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
- package/lib/azure-aks/lib/aks-cluster.js +1 -1
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
- package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
- package/lib/azure-dnszone/lib/dns-zone.js +1 -1
- package/lib/azure-dnszone/lib/index.d.ts +1 -0
- package/lib/azure-dnszone/lib/index.js +2 -1
- package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
- package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
- package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
- package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
- package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
- package/lib/azure-dnszone/lib/records/index.js +38 -0
- package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
- package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
- package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
- package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
- package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
- package/lib/azure-loganalyticsworkspace/index.js +23 -0
- package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
- package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-networkinterface/lib/network-interface.js +1 -1
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
- package/lib/azure-networkwatcher/index.d.ts +14 -0
- package/lib/azure-networkwatcher/index.js +31 -0
- package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
- package/lib/azure-networkwatcher/lib/index.js +22 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
- package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
- package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-policysetdefinition/index.d.ts +10 -0
- package/lib/azure-policysetdefinition/index.js +27 -0
- package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
- package/lib/azure-policysetdefinition/lib/index.js +22 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
- package/lib/azure-privatednszone/lib/index.d.ts +1 -0
- package/lib/azure-privatednszone/lib/index.js +2 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
- package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
- package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
- package/lib/azure-privatednszone/lib/records/index.js +26 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
- package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
- package/lib/azure-roledefinition/lib/role-definition.js +1 -1
- package/lib/azure-storageaccount/lib/storage-account.js +1 -1
- package/lib/azure-subnet/lib/subnet.js +1 -1
- package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
- package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
- package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
- package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
- package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
- package/lib/index.d.ts +23 -0
- package/lib/index.js +25 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.js +1 -1
- package/lib/testing/lib/metadata.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,924 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.DnsTxtRecord = exports.DnsSrvRecord = exports.DnsSoaRecord = exports.DnsPtrRecord = exports.DnsNsRecord = exports.DnsMxRecord = exports.DnsCnameRecord = exports.DnsCaaRecord = exports.DnsAaaaRecord = exports.DnsARecord = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Azure Public DNS Zone Record implementations using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This file provides implementations for all Public DNS Zone record types:
|
|
10
|
+
* - DnsARecord (A records with IPv4 addresses)
|
|
11
|
+
* - DnsAaaaRecord (AAAA records with IPv6 addresses)
|
|
12
|
+
* - DnsCaaRecord (CAA records for Certificate Authority Authorization) - PUBLIC ONLY
|
|
13
|
+
* - DnsCnameRecord (CNAME records)
|
|
14
|
+
* - DnsMxRecord (MX records with exchange and preference)
|
|
15
|
+
* - DnsNsRecord (NS records for Name Servers) - PUBLIC ONLY
|
|
16
|
+
* - DnsPtrRecord (PTR records)
|
|
17
|
+
* - DnsSoaRecord (SOA records)
|
|
18
|
+
* - DnsSrvRecord (SRV records with priority, weight, port, target)
|
|
19
|
+
* - DnsTxtRecord (TXT records)
|
|
20
|
+
*
|
|
21
|
+
* API Version: 2018-05-01
|
|
22
|
+
*
|
|
23
|
+
* Key differences from Private DNS:
|
|
24
|
+
* - Property casing: Public DNS uses PascalCase (ARecords, TTL vs aRecords, ttl)
|
|
25
|
+
* - CAA records: Only available in public DNS
|
|
26
|
+
* - NS records: Only available in public DNS
|
|
27
|
+
* - targetResource: Public DNS A, AAAA, and CNAME records support alias records
|
|
28
|
+
*/
|
|
29
|
+
const cdktf = require("cdktf");
|
|
30
|
+
const dns_record_schemas_1 = require("./dns-record-schemas");
|
|
31
|
+
const azapi_resource_1 = require("../../../core-azure/lib/azapi/azapi-resource");
|
|
32
|
+
/**
|
|
33
|
+
* Azure Public DNS A Record implementation
|
|
34
|
+
*
|
|
35
|
+
* A records map a hostname to one or more IPv4 addresses.
|
|
36
|
+
* Supports alias records via targetResourceId for pointing to Azure resources.
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* // Create an A record with IP addresses:
|
|
40
|
+
* const aRecord = new DnsARecord(this, "web-a-record", {
|
|
41
|
+
* name: "www",
|
|
42
|
+
* dnsZoneId: zone.id,
|
|
43
|
+
* ttl: 300,
|
|
44
|
+
* records: [
|
|
45
|
+
* { ipv4Address: "20.30.40.50" },
|
|
46
|
+
* ],
|
|
47
|
+
* });
|
|
48
|
+
*
|
|
49
|
+
* @example
|
|
50
|
+
* // Create an alias A record pointing to an Azure resource:
|
|
51
|
+
* const aliasRecord = new DnsARecord(this, "alias-a-record", {
|
|
52
|
+
* name: "www",
|
|
53
|
+
* dnsZoneId: zone.id,
|
|
54
|
+
* ttl: 300,
|
|
55
|
+
* targetResourceId: publicIp.id,
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* @stability stable
|
|
59
|
+
*/
|
|
60
|
+
class DnsARecord extends azapi_resource_1.AzapiResource {
|
|
61
|
+
constructor(scope, id, props) {
|
|
62
|
+
super(scope, id, props);
|
|
63
|
+
this.props = props;
|
|
64
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
65
|
+
value: this.id,
|
|
66
|
+
description: "The ID of the A Record",
|
|
67
|
+
});
|
|
68
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
69
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
70
|
+
description: "The name of the A Record",
|
|
71
|
+
});
|
|
72
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
73
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
74
|
+
description: "The FQDN of the A Record",
|
|
75
|
+
});
|
|
76
|
+
this.idOutput.overrideLogicalId("id");
|
|
77
|
+
this.nameOutput.overrideLogicalId("name");
|
|
78
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
79
|
+
}
|
|
80
|
+
resolveParentId(props) {
|
|
81
|
+
const typedProps = props;
|
|
82
|
+
return typedProps.dnsZoneId;
|
|
83
|
+
}
|
|
84
|
+
defaultVersion() {
|
|
85
|
+
return "2018-05-01";
|
|
86
|
+
}
|
|
87
|
+
resourceType() {
|
|
88
|
+
return dns_record_schemas_1.DNS_A_RECORD_TYPE;
|
|
89
|
+
}
|
|
90
|
+
apiSchema() {
|
|
91
|
+
return this.resolveSchema();
|
|
92
|
+
}
|
|
93
|
+
requiresLocation() {
|
|
94
|
+
return false;
|
|
95
|
+
}
|
|
96
|
+
supportsTags() {
|
|
97
|
+
return false;
|
|
98
|
+
}
|
|
99
|
+
createResourceBody(props) {
|
|
100
|
+
const typedProps = props;
|
|
101
|
+
const properties = {
|
|
102
|
+
TTL: typedProps.ttl ?? 3600,
|
|
103
|
+
};
|
|
104
|
+
if (typedProps.records && typedProps.records.length > 0) {
|
|
105
|
+
properties.ARecords = typedProps.records.map((r) => ({
|
|
106
|
+
ipv4Address: r.ipv4Address,
|
|
107
|
+
}));
|
|
108
|
+
}
|
|
109
|
+
if (typedProps.targetResourceId) {
|
|
110
|
+
properties.targetResource = { id: typedProps.targetResourceId };
|
|
111
|
+
}
|
|
112
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
113
|
+
properties.metadata = typedProps.metadata;
|
|
114
|
+
}
|
|
115
|
+
return { properties };
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Get the FQDN of the record
|
|
119
|
+
*/
|
|
120
|
+
get fqdn() {
|
|
121
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
exports.DnsARecord = DnsARecord;
|
|
125
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
126
|
+
DnsARecord[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsARecord", version: "1.9.0" };
|
|
127
|
+
(() => {
|
|
128
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_A_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_A_RECORD_VERSIONS);
|
|
129
|
+
})();
|
|
130
|
+
/**
|
|
131
|
+
* Azure Public DNS AAAA Record implementation
|
|
132
|
+
*
|
|
133
|
+
* AAAA records map a hostname to one or more IPv6 addresses.
|
|
134
|
+
* Supports alias records via targetResourceId for pointing to Azure resources.
|
|
135
|
+
*
|
|
136
|
+
* @example
|
|
137
|
+
* // Create an AAAA record:
|
|
138
|
+
* const aaaaRecord = new DnsAaaaRecord(this, "web-aaaa-record", {
|
|
139
|
+
* name: "www",
|
|
140
|
+
* dnsZoneId: zone.id,
|
|
141
|
+
* ttl: 300,
|
|
142
|
+
* records: [
|
|
143
|
+
* { ipv6Address: "2001:db8::1" },
|
|
144
|
+
* ],
|
|
145
|
+
* });
|
|
146
|
+
*
|
|
147
|
+
* @stability stable
|
|
148
|
+
*/
|
|
149
|
+
class DnsAaaaRecord extends azapi_resource_1.AzapiResource {
|
|
150
|
+
constructor(scope, id, props) {
|
|
151
|
+
super(scope, id, props);
|
|
152
|
+
this.props = props;
|
|
153
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
154
|
+
value: this.id,
|
|
155
|
+
description: "The ID of the AAAA Record",
|
|
156
|
+
});
|
|
157
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
158
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
159
|
+
description: "The name of the AAAA Record",
|
|
160
|
+
});
|
|
161
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
162
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
163
|
+
description: "The FQDN of the AAAA Record",
|
|
164
|
+
});
|
|
165
|
+
this.idOutput.overrideLogicalId("id");
|
|
166
|
+
this.nameOutput.overrideLogicalId("name");
|
|
167
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
168
|
+
}
|
|
169
|
+
resolveParentId(props) {
|
|
170
|
+
const typedProps = props;
|
|
171
|
+
return typedProps.dnsZoneId;
|
|
172
|
+
}
|
|
173
|
+
defaultVersion() {
|
|
174
|
+
return "2018-05-01";
|
|
175
|
+
}
|
|
176
|
+
resourceType() {
|
|
177
|
+
return dns_record_schemas_1.DNS_AAAA_RECORD_TYPE;
|
|
178
|
+
}
|
|
179
|
+
apiSchema() {
|
|
180
|
+
return this.resolveSchema();
|
|
181
|
+
}
|
|
182
|
+
requiresLocation() {
|
|
183
|
+
return false;
|
|
184
|
+
}
|
|
185
|
+
supportsTags() {
|
|
186
|
+
return false;
|
|
187
|
+
}
|
|
188
|
+
createResourceBody(props) {
|
|
189
|
+
const typedProps = props;
|
|
190
|
+
const properties = {
|
|
191
|
+
TTL: typedProps.ttl ?? 3600,
|
|
192
|
+
};
|
|
193
|
+
if (typedProps.records && typedProps.records.length > 0) {
|
|
194
|
+
properties.AAAARecords = typedProps.records.map((r) => ({
|
|
195
|
+
ipv6Address: r.ipv6Address,
|
|
196
|
+
}));
|
|
197
|
+
}
|
|
198
|
+
if (typedProps.targetResourceId) {
|
|
199
|
+
properties.targetResource = { id: typedProps.targetResourceId };
|
|
200
|
+
}
|
|
201
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
202
|
+
properties.metadata = typedProps.metadata;
|
|
203
|
+
}
|
|
204
|
+
return { properties };
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Get the FQDN of the record
|
|
208
|
+
*/
|
|
209
|
+
get fqdn() {
|
|
210
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
exports.DnsAaaaRecord = DnsAaaaRecord;
|
|
214
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
215
|
+
DnsAaaaRecord[_b] = { fqn: "@microsoft/terraform-cdk-constructs.DnsAaaaRecord", version: "1.9.0" };
|
|
216
|
+
(() => {
|
|
217
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_AAAA_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_AAAA_RECORD_VERSIONS);
|
|
218
|
+
})();
|
|
219
|
+
/**
|
|
220
|
+
* Azure Public DNS CAA Record implementation
|
|
221
|
+
*
|
|
222
|
+
* CAA records specify which Certificate Authorities are authorized to issue
|
|
223
|
+
* certificates for a domain. This record type is only available in Public DNS Zones.
|
|
224
|
+
*
|
|
225
|
+
* @example
|
|
226
|
+
* // Create a CAA record to authorize Let's Encrypt:
|
|
227
|
+
* const caaRecord = new DnsCaaRecord(this, "caa-record", {
|
|
228
|
+
* name: "@",
|
|
229
|
+
* dnsZoneId: zone.id,
|
|
230
|
+
* ttl: 3600,
|
|
231
|
+
* records: [
|
|
232
|
+
* { flags: 0, tag: "issue", value: "letsencrypt.org" },
|
|
233
|
+
* { flags: 0, tag: "issuewild", value: ";" }, // Disallow wildcard certs
|
|
234
|
+
* { flags: 0, tag: "iodef", value: "mailto:security@example.com" },
|
|
235
|
+
* ],
|
|
236
|
+
* });
|
|
237
|
+
*
|
|
238
|
+
* @stability stable
|
|
239
|
+
*/
|
|
240
|
+
class DnsCaaRecord extends azapi_resource_1.AzapiResource {
|
|
241
|
+
constructor(scope, id, props) {
|
|
242
|
+
super(scope, id, props);
|
|
243
|
+
this.props = props;
|
|
244
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
245
|
+
value: this.id,
|
|
246
|
+
description: "The ID of the CAA Record",
|
|
247
|
+
});
|
|
248
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
249
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
250
|
+
description: "The name of the CAA Record",
|
|
251
|
+
});
|
|
252
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
253
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
254
|
+
description: "The FQDN of the CAA Record",
|
|
255
|
+
});
|
|
256
|
+
this.idOutput.overrideLogicalId("id");
|
|
257
|
+
this.nameOutput.overrideLogicalId("name");
|
|
258
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
259
|
+
}
|
|
260
|
+
resolveParentId(props) {
|
|
261
|
+
const typedProps = props;
|
|
262
|
+
return typedProps.dnsZoneId;
|
|
263
|
+
}
|
|
264
|
+
defaultVersion() {
|
|
265
|
+
return "2018-05-01";
|
|
266
|
+
}
|
|
267
|
+
resourceType() {
|
|
268
|
+
return dns_record_schemas_1.DNS_CAA_RECORD_TYPE;
|
|
269
|
+
}
|
|
270
|
+
apiSchema() {
|
|
271
|
+
return this.resolveSchema();
|
|
272
|
+
}
|
|
273
|
+
requiresLocation() {
|
|
274
|
+
return false;
|
|
275
|
+
}
|
|
276
|
+
supportsTags() {
|
|
277
|
+
return false;
|
|
278
|
+
}
|
|
279
|
+
createResourceBody(props) {
|
|
280
|
+
const typedProps = props;
|
|
281
|
+
const properties = {
|
|
282
|
+
TTL: typedProps.ttl ?? 3600,
|
|
283
|
+
caaRecords: typedProps.records.map((r) => ({
|
|
284
|
+
flags: r.flags,
|
|
285
|
+
tag: r.tag,
|
|
286
|
+
value: r.value,
|
|
287
|
+
})),
|
|
288
|
+
};
|
|
289
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
290
|
+
properties.metadata = typedProps.metadata;
|
|
291
|
+
}
|
|
292
|
+
return { properties };
|
|
293
|
+
}
|
|
294
|
+
/**
|
|
295
|
+
* Get the FQDN of the record
|
|
296
|
+
*/
|
|
297
|
+
get fqdn() {
|
|
298
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
exports.DnsCaaRecord = DnsCaaRecord;
|
|
302
|
+
_c = JSII_RTTI_SYMBOL_1;
|
|
303
|
+
DnsCaaRecord[_c] = { fqn: "@microsoft/terraform-cdk-constructs.DnsCaaRecord", version: "1.9.0" };
|
|
304
|
+
(() => {
|
|
305
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_CAA_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_CAA_RECORD_VERSIONS);
|
|
306
|
+
})();
|
|
307
|
+
/**
|
|
308
|
+
* Azure Public DNS CNAME Record implementation
|
|
309
|
+
*
|
|
310
|
+
* CNAME records create an alias from one hostname to another.
|
|
311
|
+
* Supports alias records via targetResourceId for pointing to Azure resources.
|
|
312
|
+
* Note: CNAME records cannot coexist with other record types at the same name.
|
|
313
|
+
*
|
|
314
|
+
* @example
|
|
315
|
+
* // Create a CNAME record:
|
|
316
|
+
* const cnameRecord = new DnsCnameRecord(this, "alias-record", {
|
|
317
|
+
* name: "app",
|
|
318
|
+
* dnsZoneId: zone.id,
|
|
319
|
+
* ttl: 3600,
|
|
320
|
+
* cname: "www.example.com",
|
|
321
|
+
* });
|
|
322
|
+
*
|
|
323
|
+
* @stability stable
|
|
324
|
+
*/
|
|
325
|
+
class DnsCnameRecord extends azapi_resource_1.AzapiResource {
|
|
326
|
+
constructor(scope, id, props) {
|
|
327
|
+
super(scope, id, props);
|
|
328
|
+
this.props = props;
|
|
329
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
330
|
+
value: this.id,
|
|
331
|
+
description: "The ID of the CNAME Record",
|
|
332
|
+
});
|
|
333
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
334
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
335
|
+
description: "The name of the CNAME Record",
|
|
336
|
+
});
|
|
337
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
338
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
339
|
+
description: "The FQDN of the CNAME Record",
|
|
340
|
+
});
|
|
341
|
+
this.idOutput.overrideLogicalId("id");
|
|
342
|
+
this.nameOutput.overrideLogicalId("name");
|
|
343
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
344
|
+
}
|
|
345
|
+
resolveParentId(props) {
|
|
346
|
+
const typedProps = props;
|
|
347
|
+
return typedProps.dnsZoneId;
|
|
348
|
+
}
|
|
349
|
+
defaultVersion() {
|
|
350
|
+
return "2018-05-01";
|
|
351
|
+
}
|
|
352
|
+
resourceType() {
|
|
353
|
+
return dns_record_schemas_1.DNS_CNAME_RECORD_TYPE;
|
|
354
|
+
}
|
|
355
|
+
apiSchema() {
|
|
356
|
+
return this.resolveSchema();
|
|
357
|
+
}
|
|
358
|
+
requiresLocation() {
|
|
359
|
+
return false;
|
|
360
|
+
}
|
|
361
|
+
supportsTags() {
|
|
362
|
+
return false;
|
|
363
|
+
}
|
|
364
|
+
createResourceBody(props) {
|
|
365
|
+
const typedProps = props;
|
|
366
|
+
const properties = {
|
|
367
|
+
TTL: typedProps.ttl ?? 3600,
|
|
368
|
+
};
|
|
369
|
+
if (typedProps.cname) {
|
|
370
|
+
properties.CNAMERecord = { cname: typedProps.cname };
|
|
371
|
+
}
|
|
372
|
+
if (typedProps.targetResourceId) {
|
|
373
|
+
properties.targetResource = { id: typedProps.targetResourceId };
|
|
374
|
+
}
|
|
375
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
376
|
+
properties.metadata = typedProps.metadata;
|
|
377
|
+
}
|
|
378
|
+
return { properties };
|
|
379
|
+
}
|
|
380
|
+
/**
|
|
381
|
+
* Get the FQDN of the record
|
|
382
|
+
*/
|
|
383
|
+
get fqdn() {
|
|
384
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
385
|
+
}
|
|
386
|
+
}
|
|
387
|
+
exports.DnsCnameRecord = DnsCnameRecord;
|
|
388
|
+
_d = JSII_RTTI_SYMBOL_1;
|
|
389
|
+
DnsCnameRecord[_d] = { fqn: "@microsoft/terraform-cdk-constructs.DnsCnameRecord", version: "1.9.0" };
|
|
390
|
+
(() => {
|
|
391
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_CNAME_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_CNAME_RECORD_VERSIONS);
|
|
392
|
+
})();
|
|
393
|
+
/**
|
|
394
|
+
* Azure Public DNS MX Record implementation
|
|
395
|
+
*
|
|
396
|
+
* MX records specify mail exchange servers for a domain.
|
|
397
|
+
*
|
|
398
|
+
* @example
|
|
399
|
+
* // Create an MX record:
|
|
400
|
+
* const mxRecord = new DnsMxRecord(this, "mail-record", {
|
|
401
|
+
* name: "@",
|
|
402
|
+
* dnsZoneId: zone.id,
|
|
403
|
+
* ttl: 3600,
|
|
404
|
+
* records: [
|
|
405
|
+
* { preference: 10, exchange: "mail1.example.com" },
|
|
406
|
+
* { preference: 20, exchange: "mail2.example.com" },
|
|
407
|
+
* ],
|
|
408
|
+
* });
|
|
409
|
+
*
|
|
410
|
+
* @stability stable
|
|
411
|
+
*/
|
|
412
|
+
class DnsMxRecord extends azapi_resource_1.AzapiResource {
|
|
413
|
+
constructor(scope, id, props) {
|
|
414
|
+
super(scope, id, props);
|
|
415
|
+
this.props = props;
|
|
416
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
417
|
+
value: this.id,
|
|
418
|
+
description: "The ID of the MX Record",
|
|
419
|
+
});
|
|
420
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
421
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
422
|
+
description: "The name of the MX Record",
|
|
423
|
+
});
|
|
424
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
425
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
426
|
+
description: "The FQDN of the MX Record",
|
|
427
|
+
});
|
|
428
|
+
this.idOutput.overrideLogicalId("id");
|
|
429
|
+
this.nameOutput.overrideLogicalId("name");
|
|
430
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
431
|
+
}
|
|
432
|
+
resolveParentId(props) {
|
|
433
|
+
const typedProps = props;
|
|
434
|
+
return typedProps.dnsZoneId;
|
|
435
|
+
}
|
|
436
|
+
defaultVersion() {
|
|
437
|
+
return "2018-05-01";
|
|
438
|
+
}
|
|
439
|
+
resourceType() {
|
|
440
|
+
return dns_record_schemas_1.DNS_MX_RECORD_TYPE;
|
|
441
|
+
}
|
|
442
|
+
apiSchema() {
|
|
443
|
+
return this.resolveSchema();
|
|
444
|
+
}
|
|
445
|
+
requiresLocation() {
|
|
446
|
+
return false;
|
|
447
|
+
}
|
|
448
|
+
supportsTags() {
|
|
449
|
+
return false;
|
|
450
|
+
}
|
|
451
|
+
createResourceBody(props) {
|
|
452
|
+
const typedProps = props;
|
|
453
|
+
const properties = {
|
|
454
|
+
TTL: typedProps.ttl ?? 3600,
|
|
455
|
+
MXRecords: typedProps.records.map((r) => ({
|
|
456
|
+
preference: r.preference,
|
|
457
|
+
exchange: r.exchange,
|
|
458
|
+
})),
|
|
459
|
+
};
|
|
460
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
461
|
+
properties.metadata = typedProps.metadata;
|
|
462
|
+
}
|
|
463
|
+
return { properties };
|
|
464
|
+
}
|
|
465
|
+
/**
|
|
466
|
+
* Get the FQDN of the record
|
|
467
|
+
*/
|
|
468
|
+
get fqdn() {
|
|
469
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
470
|
+
}
|
|
471
|
+
}
|
|
472
|
+
exports.DnsMxRecord = DnsMxRecord;
|
|
473
|
+
_e = JSII_RTTI_SYMBOL_1;
|
|
474
|
+
DnsMxRecord[_e] = { fqn: "@microsoft/terraform-cdk-constructs.DnsMxRecord", version: "1.9.0" };
|
|
475
|
+
(() => {
|
|
476
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_MX_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_MX_RECORD_VERSIONS);
|
|
477
|
+
})();
|
|
478
|
+
/**
|
|
479
|
+
* Azure Public DNS NS Record implementation
|
|
480
|
+
*
|
|
481
|
+
* NS records specify the authoritative name servers for a domain or subdomain.
|
|
482
|
+
* This record type is only available in Public DNS Zones.
|
|
483
|
+
*
|
|
484
|
+
* @example
|
|
485
|
+
* // Create an NS record for a subdomain delegation:
|
|
486
|
+
* const nsRecord = new DnsNsRecord(this, "ns-record", {
|
|
487
|
+
* name: "subdomain",
|
|
488
|
+
* dnsZoneId: zone.id,
|
|
489
|
+
* ttl: 3600,
|
|
490
|
+
* records: [
|
|
491
|
+
* { nsdname: "ns1.subdomain.example.com" },
|
|
492
|
+
* { nsdname: "ns2.subdomain.example.com" },
|
|
493
|
+
* ],
|
|
494
|
+
* });
|
|
495
|
+
*
|
|
496
|
+
* @stability stable
|
|
497
|
+
*/
|
|
498
|
+
class DnsNsRecord extends azapi_resource_1.AzapiResource {
|
|
499
|
+
constructor(scope, id, props) {
|
|
500
|
+
super(scope, id, props);
|
|
501
|
+
this.props = props;
|
|
502
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
503
|
+
value: this.id,
|
|
504
|
+
description: "The ID of the NS Record",
|
|
505
|
+
});
|
|
506
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
507
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
508
|
+
description: "The name of the NS Record",
|
|
509
|
+
});
|
|
510
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
511
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
512
|
+
description: "The FQDN of the NS Record",
|
|
513
|
+
});
|
|
514
|
+
this.idOutput.overrideLogicalId("id");
|
|
515
|
+
this.nameOutput.overrideLogicalId("name");
|
|
516
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
517
|
+
}
|
|
518
|
+
resolveParentId(props) {
|
|
519
|
+
const typedProps = props;
|
|
520
|
+
return typedProps.dnsZoneId;
|
|
521
|
+
}
|
|
522
|
+
defaultVersion() {
|
|
523
|
+
return "2018-05-01";
|
|
524
|
+
}
|
|
525
|
+
resourceType() {
|
|
526
|
+
return dns_record_schemas_1.DNS_NS_RECORD_TYPE;
|
|
527
|
+
}
|
|
528
|
+
apiSchema() {
|
|
529
|
+
return this.resolveSchema();
|
|
530
|
+
}
|
|
531
|
+
requiresLocation() {
|
|
532
|
+
return false;
|
|
533
|
+
}
|
|
534
|
+
supportsTags() {
|
|
535
|
+
return false;
|
|
536
|
+
}
|
|
537
|
+
createResourceBody(props) {
|
|
538
|
+
const typedProps = props;
|
|
539
|
+
const properties = {
|
|
540
|
+
TTL: typedProps.ttl ?? 3600,
|
|
541
|
+
NSRecords: typedProps.records.map((r) => ({
|
|
542
|
+
nsdname: r.nsdname,
|
|
543
|
+
})),
|
|
544
|
+
};
|
|
545
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
546
|
+
properties.metadata = typedProps.metadata;
|
|
547
|
+
}
|
|
548
|
+
return { properties };
|
|
549
|
+
}
|
|
550
|
+
/**
|
|
551
|
+
* Get the FQDN of the record
|
|
552
|
+
*/
|
|
553
|
+
get fqdn() {
|
|
554
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
exports.DnsNsRecord = DnsNsRecord;
|
|
558
|
+
_f = JSII_RTTI_SYMBOL_1;
|
|
559
|
+
DnsNsRecord[_f] = { fqn: "@microsoft/terraform-cdk-constructs.DnsNsRecord", version: "1.9.0" };
|
|
560
|
+
(() => {
|
|
561
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_NS_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_NS_RECORD_VERSIONS);
|
|
562
|
+
})();
|
|
563
|
+
/**
|
|
564
|
+
* Azure Public DNS PTR Record implementation
|
|
565
|
+
*
|
|
566
|
+
* PTR records are used for reverse DNS lookups, mapping IP addresses to hostnames.
|
|
567
|
+
*
|
|
568
|
+
* @example
|
|
569
|
+
* // Create a PTR record:
|
|
570
|
+
* const ptrRecord = new DnsPtrRecord(this, "ptr-record", {
|
|
571
|
+
* name: "50",
|
|
572
|
+
* dnsZoneId: reverseZone.id,
|
|
573
|
+
* ttl: 3600,
|
|
574
|
+
* records: [
|
|
575
|
+
* { ptrdname: "server1.example.com" },
|
|
576
|
+
* ],
|
|
577
|
+
* });
|
|
578
|
+
*
|
|
579
|
+
* @stability stable
|
|
580
|
+
*/
|
|
581
|
+
class DnsPtrRecord extends azapi_resource_1.AzapiResource {
|
|
582
|
+
constructor(scope, id, props) {
|
|
583
|
+
super(scope, id, props);
|
|
584
|
+
this.props = props;
|
|
585
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
586
|
+
value: this.id,
|
|
587
|
+
description: "The ID of the PTR Record",
|
|
588
|
+
});
|
|
589
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
590
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
591
|
+
description: "The name of the PTR Record",
|
|
592
|
+
});
|
|
593
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
594
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
595
|
+
description: "The FQDN of the PTR Record",
|
|
596
|
+
});
|
|
597
|
+
this.idOutput.overrideLogicalId("id");
|
|
598
|
+
this.nameOutput.overrideLogicalId("name");
|
|
599
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
600
|
+
}
|
|
601
|
+
resolveParentId(props) {
|
|
602
|
+
const typedProps = props;
|
|
603
|
+
return typedProps.dnsZoneId;
|
|
604
|
+
}
|
|
605
|
+
defaultVersion() {
|
|
606
|
+
return "2018-05-01";
|
|
607
|
+
}
|
|
608
|
+
resourceType() {
|
|
609
|
+
return dns_record_schemas_1.DNS_PTR_RECORD_TYPE;
|
|
610
|
+
}
|
|
611
|
+
apiSchema() {
|
|
612
|
+
return this.resolveSchema();
|
|
613
|
+
}
|
|
614
|
+
requiresLocation() {
|
|
615
|
+
return false;
|
|
616
|
+
}
|
|
617
|
+
supportsTags() {
|
|
618
|
+
return false;
|
|
619
|
+
}
|
|
620
|
+
createResourceBody(props) {
|
|
621
|
+
const typedProps = props;
|
|
622
|
+
const properties = {
|
|
623
|
+
TTL: typedProps.ttl ?? 3600,
|
|
624
|
+
PTRRecords: typedProps.records.map((r) => ({
|
|
625
|
+
ptrdname: r.ptrdname,
|
|
626
|
+
})),
|
|
627
|
+
};
|
|
628
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
629
|
+
properties.metadata = typedProps.metadata;
|
|
630
|
+
}
|
|
631
|
+
return { properties };
|
|
632
|
+
}
|
|
633
|
+
/**
|
|
634
|
+
* Get the FQDN of the record
|
|
635
|
+
*/
|
|
636
|
+
get fqdn() {
|
|
637
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
638
|
+
}
|
|
639
|
+
}
|
|
640
|
+
exports.DnsPtrRecord = DnsPtrRecord;
|
|
641
|
+
_g = JSII_RTTI_SYMBOL_1;
|
|
642
|
+
DnsPtrRecord[_g] = { fqn: "@microsoft/terraform-cdk-constructs.DnsPtrRecord", version: "1.9.0" };
|
|
643
|
+
(() => {
|
|
644
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_PTR_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_PTR_RECORD_VERSIONS);
|
|
645
|
+
})();
|
|
646
|
+
/**
|
|
647
|
+
* Azure Public DNS SOA Record implementation
|
|
648
|
+
*
|
|
649
|
+
* SOA records contain administrative information about a DNS zone.
|
|
650
|
+
* Note: Each zone automatically has an SOA record; this is typically used to update it.
|
|
651
|
+
*
|
|
652
|
+
* @example
|
|
653
|
+
* // Update the SOA record:
|
|
654
|
+
* const soaRecord = new DnsSoaRecord(this, "soa-record", {
|
|
655
|
+
* name: "@",
|
|
656
|
+
* dnsZoneId: zone.id,
|
|
657
|
+
* ttl: 3600,
|
|
658
|
+
* soaRecord: {
|
|
659
|
+
* email: "admin.example.com",
|
|
660
|
+
* refreshTime: 3600,
|
|
661
|
+
* retryTime: 300,
|
|
662
|
+
* expireTime: 2419200,
|
|
663
|
+
* minimumTTL: 300,
|
|
664
|
+
* },
|
|
665
|
+
* });
|
|
666
|
+
*
|
|
667
|
+
* @stability stable
|
|
668
|
+
*/
|
|
669
|
+
class DnsSoaRecord extends azapi_resource_1.AzapiResource {
|
|
670
|
+
constructor(scope, id, props) {
|
|
671
|
+
super(scope, id, props);
|
|
672
|
+
this.props = props;
|
|
673
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
674
|
+
value: this.id,
|
|
675
|
+
description: "The ID of the SOA Record",
|
|
676
|
+
});
|
|
677
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
678
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
679
|
+
description: "The name of the SOA Record",
|
|
680
|
+
});
|
|
681
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
682
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
683
|
+
description: "The FQDN of the SOA Record",
|
|
684
|
+
});
|
|
685
|
+
this.idOutput.overrideLogicalId("id");
|
|
686
|
+
this.nameOutput.overrideLogicalId("name");
|
|
687
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
688
|
+
}
|
|
689
|
+
resolveParentId(props) {
|
|
690
|
+
const typedProps = props;
|
|
691
|
+
return typedProps.dnsZoneId;
|
|
692
|
+
}
|
|
693
|
+
defaultVersion() {
|
|
694
|
+
return "2018-05-01";
|
|
695
|
+
}
|
|
696
|
+
resourceType() {
|
|
697
|
+
return dns_record_schemas_1.DNS_SOA_RECORD_TYPE;
|
|
698
|
+
}
|
|
699
|
+
apiSchema() {
|
|
700
|
+
return this.resolveSchema();
|
|
701
|
+
}
|
|
702
|
+
requiresLocation() {
|
|
703
|
+
return false;
|
|
704
|
+
}
|
|
705
|
+
supportsTags() {
|
|
706
|
+
return false;
|
|
707
|
+
}
|
|
708
|
+
createResourceBody(props) {
|
|
709
|
+
const typedProps = props;
|
|
710
|
+
const soaRecord = {};
|
|
711
|
+
if (typedProps.soaRecord.host !== undefined) {
|
|
712
|
+
soaRecord.host = typedProps.soaRecord.host;
|
|
713
|
+
}
|
|
714
|
+
if (typedProps.soaRecord.email !== undefined) {
|
|
715
|
+
soaRecord.email = typedProps.soaRecord.email;
|
|
716
|
+
}
|
|
717
|
+
if (typedProps.soaRecord.serialNumber !== undefined) {
|
|
718
|
+
soaRecord.serialNumber = typedProps.soaRecord.serialNumber;
|
|
719
|
+
}
|
|
720
|
+
if (typedProps.soaRecord.refreshTime !== undefined) {
|
|
721
|
+
soaRecord.refreshTime = typedProps.soaRecord.refreshTime;
|
|
722
|
+
}
|
|
723
|
+
if (typedProps.soaRecord.retryTime !== undefined) {
|
|
724
|
+
soaRecord.retryTime = typedProps.soaRecord.retryTime;
|
|
725
|
+
}
|
|
726
|
+
if (typedProps.soaRecord.expireTime !== undefined) {
|
|
727
|
+
soaRecord.expireTime = typedProps.soaRecord.expireTime;
|
|
728
|
+
}
|
|
729
|
+
if (typedProps.soaRecord.minimumTTL !== undefined) {
|
|
730
|
+
soaRecord.minimumTTL = typedProps.soaRecord.minimumTTL;
|
|
731
|
+
}
|
|
732
|
+
const properties = {
|
|
733
|
+
TTL: typedProps.ttl ?? 3600,
|
|
734
|
+
SOARecord: soaRecord,
|
|
735
|
+
};
|
|
736
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
737
|
+
properties.metadata = typedProps.metadata;
|
|
738
|
+
}
|
|
739
|
+
return { properties };
|
|
740
|
+
}
|
|
741
|
+
/**
|
|
742
|
+
* Get the FQDN of the record
|
|
743
|
+
*/
|
|
744
|
+
get fqdn() {
|
|
745
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
746
|
+
}
|
|
747
|
+
}
|
|
748
|
+
exports.DnsSoaRecord = DnsSoaRecord;
|
|
749
|
+
_h = JSII_RTTI_SYMBOL_1;
|
|
750
|
+
DnsSoaRecord[_h] = { fqn: "@microsoft/terraform-cdk-constructs.DnsSoaRecord", version: "1.9.0" };
|
|
751
|
+
(() => {
|
|
752
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_SOA_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_SOA_RECORD_VERSIONS);
|
|
753
|
+
})();
|
|
754
|
+
/**
|
|
755
|
+
* Azure Public DNS SRV Record implementation
|
|
756
|
+
*
|
|
757
|
+
* SRV records specify the location of services like SIP, XMPP, etc.
|
|
758
|
+
*
|
|
759
|
+
* @example
|
|
760
|
+
* // Create an SRV record for a SIP service:
|
|
761
|
+
* const srvRecord = new DnsSrvRecord(this, "sip-record", {
|
|
762
|
+
* name: "_sip._tcp",
|
|
763
|
+
* dnsZoneId: zone.id,
|
|
764
|
+
* ttl: 3600,
|
|
765
|
+
* records: [
|
|
766
|
+
* { priority: 10, weight: 60, port: 5060, target: "sipserver1.example.com" },
|
|
767
|
+
* { priority: 10, weight: 40, port: 5060, target: "sipserver2.example.com" },
|
|
768
|
+
* ],
|
|
769
|
+
* });
|
|
770
|
+
*
|
|
771
|
+
* @stability stable
|
|
772
|
+
*/
|
|
773
|
+
class DnsSrvRecord extends azapi_resource_1.AzapiResource {
|
|
774
|
+
constructor(scope, id, props) {
|
|
775
|
+
super(scope, id, props);
|
|
776
|
+
this.props = props;
|
|
777
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
778
|
+
value: this.id,
|
|
779
|
+
description: "The ID of the SRV Record",
|
|
780
|
+
});
|
|
781
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
782
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
783
|
+
description: "The name of the SRV Record",
|
|
784
|
+
});
|
|
785
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
786
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
787
|
+
description: "The FQDN of the SRV Record",
|
|
788
|
+
});
|
|
789
|
+
this.idOutput.overrideLogicalId("id");
|
|
790
|
+
this.nameOutput.overrideLogicalId("name");
|
|
791
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
792
|
+
}
|
|
793
|
+
resolveParentId(props) {
|
|
794
|
+
const typedProps = props;
|
|
795
|
+
return typedProps.dnsZoneId;
|
|
796
|
+
}
|
|
797
|
+
defaultVersion() {
|
|
798
|
+
return "2018-05-01";
|
|
799
|
+
}
|
|
800
|
+
resourceType() {
|
|
801
|
+
return dns_record_schemas_1.DNS_SRV_RECORD_TYPE;
|
|
802
|
+
}
|
|
803
|
+
apiSchema() {
|
|
804
|
+
return this.resolveSchema();
|
|
805
|
+
}
|
|
806
|
+
requiresLocation() {
|
|
807
|
+
return false;
|
|
808
|
+
}
|
|
809
|
+
supportsTags() {
|
|
810
|
+
return false;
|
|
811
|
+
}
|
|
812
|
+
createResourceBody(props) {
|
|
813
|
+
const typedProps = props;
|
|
814
|
+
const properties = {
|
|
815
|
+
TTL: typedProps.ttl ?? 3600,
|
|
816
|
+
SRVRecords: typedProps.records.map((r) => ({
|
|
817
|
+
priority: r.priority,
|
|
818
|
+
weight: r.weight,
|
|
819
|
+
port: r.port,
|
|
820
|
+
target: r.target,
|
|
821
|
+
})),
|
|
822
|
+
};
|
|
823
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
824
|
+
properties.metadata = typedProps.metadata;
|
|
825
|
+
}
|
|
826
|
+
return { properties };
|
|
827
|
+
}
|
|
828
|
+
/**
|
|
829
|
+
* Get the FQDN of the record
|
|
830
|
+
*/
|
|
831
|
+
get fqdn() {
|
|
832
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
833
|
+
}
|
|
834
|
+
}
|
|
835
|
+
exports.DnsSrvRecord = DnsSrvRecord;
|
|
836
|
+
_j = JSII_RTTI_SYMBOL_1;
|
|
837
|
+
DnsSrvRecord[_j] = { fqn: "@microsoft/terraform-cdk-constructs.DnsSrvRecord", version: "1.9.0" };
|
|
838
|
+
(() => {
|
|
839
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_SRV_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_SRV_RECORD_VERSIONS);
|
|
840
|
+
})();
|
|
841
|
+
/**
|
|
842
|
+
* Azure Public DNS TXT Record implementation
|
|
843
|
+
*
|
|
844
|
+
* TXT records store arbitrary text data, commonly used for SPF, DKIM, domain verification, etc.
|
|
845
|
+
*
|
|
846
|
+
* @example
|
|
847
|
+
* // Create a TXT record for SPF:
|
|
848
|
+
* const txtRecord = new DnsTxtRecord(this, "spf-record", {
|
|
849
|
+
* name: "@",
|
|
850
|
+
* dnsZoneId: zone.id,
|
|
851
|
+
* ttl: 3600,
|
|
852
|
+
* records: [
|
|
853
|
+
* { value: ["v=spf1 include:spf.protection.outlook.com -all"] },
|
|
854
|
+
* ],
|
|
855
|
+
* });
|
|
856
|
+
*
|
|
857
|
+
* @stability stable
|
|
858
|
+
*/
|
|
859
|
+
class DnsTxtRecord extends azapi_resource_1.AzapiResource {
|
|
860
|
+
constructor(scope, id, props) {
|
|
861
|
+
super(scope, id, props);
|
|
862
|
+
this.props = props;
|
|
863
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
864
|
+
value: this.id,
|
|
865
|
+
description: "The ID of the TXT Record",
|
|
866
|
+
});
|
|
867
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
868
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
869
|
+
description: "The name of the TXT Record",
|
|
870
|
+
});
|
|
871
|
+
this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
|
|
872
|
+
value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
|
|
873
|
+
description: "The FQDN of the TXT Record",
|
|
874
|
+
});
|
|
875
|
+
this.idOutput.overrideLogicalId("id");
|
|
876
|
+
this.nameOutput.overrideLogicalId("name");
|
|
877
|
+
this.fqdnOutput.overrideLogicalId("fqdn");
|
|
878
|
+
}
|
|
879
|
+
resolveParentId(props) {
|
|
880
|
+
const typedProps = props;
|
|
881
|
+
return typedProps.dnsZoneId;
|
|
882
|
+
}
|
|
883
|
+
defaultVersion() {
|
|
884
|
+
return "2018-05-01";
|
|
885
|
+
}
|
|
886
|
+
resourceType() {
|
|
887
|
+
return dns_record_schemas_1.DNS_TXT_RECORD_TYPE;
|
|
888
|
+
}
|
|
889
|
+
apiSchema() {
|
|
890
|
+
return this.resolveSchema();
|
|
891
|
+
}
|
|
892
|
+
requiresLocation() {
|
|
893
|
+
return false;
|
|
894
|
+
}
|
|
895
|
+
supportsTags() {
|
|
896
|
+
return false;
|
|
897
|
+
}
|
|
898
|
+
createResourceBody(props) {
|
|
899
|
+
const typedProps = props;
|
|
900
|
+
const properties = {
|
|
901
|
+
TTL: typedProps.ttl ?? 3600,
|
|
902
|
+
TXTRecords: typedProps.records.map((r) => ({
|
|
903
|
+
value: r.value,
|
|
904
|
+
})),
|
|
905
|
+
};
|
|
906
|
+
if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
|
|
907
|
+
properties.metadata = typedProps.metadata;
|
|
908
|
+
}
|
|
909
|
+
return { properties };
|
|
910
|
+
}
|
|
911
|
+
/**
|
|
912
|
+
* Get the FQDN of the record
|
|
913
|
+
*/
|
|
914
|
+
get fqdn() {
|
|
915
|
+
return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
|
|
916
|
+
}
|
|
917
|
+
}
|
|
918
|
+
exports.DnsTxtRecord = DnsTxtRecord;
|
|
919
|
+
_k = JSII_RTTI_SYMBOL_1;
|
|
920
|
+
DnsTxtRecord[_k] = { fqn: "@microsoft/terraform-cdk-constructs.DnsTxtRecord", version: "1.9.0" };
|
|
921
|
+
(() => {
|
|
922
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_record_schemas_1.DNS_TXT_RECORD_TYPE, dns_record_schemas_1.ALL_DNS_TXT_RECORD_VERSIONS);
|
|
923
|
+
})();
|
|
924
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-records.js","sourceRoot":"","sources":["../../../../src/azure-dnszone/lib/records/dns-records.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Public DNS Zone Record implementations using AzapiResource framework\n *\n * This file provides implementations for all Public DNS Zone record types:\n * - DnsARecord (A records with IPv4 addresses)\n * - DnsAaaaRecord (AAAA records with IPv6 addresses)\n * - DnsCaaRecord (CAA records for Certificate Authority Authorization) - PUBLIC ONLY\n * - DnsCnameRecord (CNAME records)\n * - DnsMxRecord (MX records with exchange and preference)\n * - DnsNsRecord (NS records for Name Servers) - PUBLIC ONLY\n * - DnsPtrRecord (PTR records)\n * - DnsSoaRecord (SOA records)\n * - DnsSrvRecord (SRV records with priority, weight, port, target)\n * - DnsTxtRecord (TXT records)\n *\n * API Version: 2018-05-01\n *\n * Key differences from Private DNS:\n * - Property casing: Public DNS uses PascalCase (ARecords, TTL vs aRecords, ttl)\n * - CAA records: Only available in public DNS\n * - NS records: Only available in public DNS\n * - targetResource: Public DNS A, AAAA, and CNAME records support alias records\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_DNS_A_RECORD_VERSIONS,\n  ALL_DNS_AAAA_RECORD_VERSIONS,\n  ALL_DNS_CAA_RECORD_VERSIONS,\n  ALL_DNS_CNAME_RECORD_VERSIONS,\n  ALL_DNS_MX_RECORD_VERSIONS,\n  ALL_DNS_NS_RECORD_VERSIONS,\n  ALL_DNS_PTR_RECORD_VERSIONS,\n  ALL_DNS_SOA_RECORD_VERSIONS,\n  ALL_DNS_SRV_RECORD_VERSIONS,\n  ALL_DNS_TXT_RECORD_VERSIONS,\n  DNS_A_RECORD_TYPE,\n  DNS_AAAA_RECORD_TYPE,\n  DNS_CAA_RECORD_TYPE,\n  DNS_CNAME_RECORD_TYPE,\n  DNS_MX_RECORD_TYPE,\n  DNS_NS_RECORD_TYPE,\n  DNS_PTR_RECORD_TYPE,\n  DNS_SOA_RECORD_TYPE,\n  DNS_SRV_RECORD_TYPE,\n  DNS_TXT_RECORD_TYPE,\n} from \"./dns-record-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON INTERFACES\n// =============================================================================\n\n/**\n * Base properties shared by all Public DNS record types\n *\n * Note: The `name` property is inherited from AzapiResourceProps.\n * For DNS records, use @ for apex records or provide a relative name like \"www\" or \"mail\".\n */\nexport interface DnsRecordBaseProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the parent DNS Zone\n   * @example zone.id or \"/subscriptions/.../providers/Microsoft.Network/dnsZones/example.com\"\n   */\n  readonly dnsZoneId: string;\n\n  /**\n   * Time to Live in seconds\n   * @default 3600\n   */\n  readonly ttl?: number;\n\n  /**\n   * Metadata key-value pairs for the record set\n   */\n  readonly metadata?: { [key: string]: string };\n}\n\n// =============================================================================\n// A RECORD\n// =============================================================================\n\n/**\n * Entry for an A record with IPv4 address\n */\nexport interface DnsARecordEntry {\n  /**\n   * The IPv4 address of this A record\n   * @example \"20.30.40.50\"\n   */\n  readonly ipv4Address: string;\n}\n\n/**\n * Properties for Public DNS A Record\n */\nexport interface DnsARecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of A records with IPv4 addresses\n   * Either records or targetResourceId must be specified\n   */\n  readonly records?: DnsARecordEntry[];\n\n  /**\n   * Reference to an Azure resource from where the IP content is taken (alias record)\n   * Either records or targetResourceId must be specified\n   * @example publicIp.id\n   */\n  readonly targetResourceId?: string;\n}\n\n/**\n * Azure Public DNS A Record implementation\n *\n * A records map a hostname to one or more IPv4 addresses.\n * Supports alias records via targetResourceId for pointing to Azure resources.\n *\n * @example\n * // Create an A record with IP addresses:\n * const aRecord = new DnsARecord(this, \"web-a-record\", {\n *   name: \"www\",\n *   dnsZoneId: zone.id,\n *   ttl: 300,\n *   records: [\n *     { ipv4Address: \"20.30.40.50\" },\n *   ],\n * });\n *\n * @example\n * // Create an alias A record pointing to an Azure resource:\n * const aliasRecord = new DnsARecord(this, \"alias-a-record\", {\n *   name: \"www\",\n *   dnsZoneId: zone.id,\n *   ttl: 300,\n *   targetResourceId: publicIp.id,\n * });\n *\n * @stability stable\n */\nexport class DnsARecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(DNS_A_RECORD_TYPE, ALL_DNS_A_RECORD_VERSIONS);\n  }\n\n  public readonly props: DnsARecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsARecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the A Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the A Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the A Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsARecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_A_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsARecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n    };\n\n    if (typedProps.records && typedProps.records.length > 0) {\n      properties.ARecords = typedProps.records.map((r) => ({\n        ipv4Address: r.ipv4Address,\n      }));\n    }\n\n    if (typedProps.targetResourceId) {\n      properties.targetResource = { id: typedProps.targetResourceId };\n    }\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// AAAA RECORD\n// =============================================================================\n\n/**\n * Entry for an AAAA record with IPv6 address\n */\nexport interface DnsAaaaRecordEntry {\n  /**\n   * The IPv6 address of this AAAA record\n   * @example \"2001:db8::1\"\n   */\n  readonly ipv6Address: string;\n}\n\n/**\n * Properties for Public DNS AAAA Record\n */\nexport interface DnsAaaaRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of AAAA records with IPv6 addresses\n   * Either records or targetResourceId must be specified\n   */\n  readonly records?: DnsAaaaRecordEntry[];\n\n  /**\n   * Reference to an Azure resource from where the IP content is taken (alias record)\n   * Either records or targetResourceId must be specified\n   */\n  readonly targetResourceId?: string;\n}\n\n/**\n * Azure Public DNS AAAA Record implementation\n *\n * AAAA records map a hostname to one or more IPv6 addresses.\n * Supports alias records via targetResourceId for pointing to Azure resources.\n *\n * @example\n * // Create an AAAA record:\n * const aaaaRecord = new DnsAaaaRecord(this, \"web-aaaa-record\", {\n *   name: \"www\",\n *   dnsZoneId: zone.id,\n *   ttl: 300,\n *   records: [\n *     { ipv6Address: \"2001:db8::1\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsAaaaRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_AAAA_RECORD_TYPE,\n      ALL_DNS_AAAA_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsAaaaRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsAaaaRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the AAAA Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the AAAA Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the AAAA Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsAaaaRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_AAAA_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsAaaaRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n    };\n\n    if (typedProps.records && typedProps.records.length > 0) {\n      properties.AAAARecords = typedProps.records.map((r) => ({\n        ipv6Address: r.ipv6Address,\n      }));\n    }\n\n    if (typedProps.targetResourceId) {\n      properties.targetResource = { id: typedProps.targetResourceId };\n    }\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// CAA RECORD (PUBLIC DNS ONLY)\n// =============================================================================\n\n/**\n * Entry for a CAA record (Certificate Authority Authorization)\n */\nexport interface DnsCaaRecordEntry {\n  /**\n   * Flags for this CAA record (0-255)\n   * 0 = non-critical, 128 = critical\n   * @example 0\n   */\n  readonly flags: number;\n\n  /**\n   * The property tag for this CAA record\n   * Common values: \"issue\", \"issuewild\", \"iodef\"\n   * @example \"issue\"\n   */\n  readonly tag: string;\n\n  /**\n   * The value associated with the tag\n   * @example \"letsencrypt.org\"\n   */\n  readonly value: string;\n}\n\n/**\n * Properties for Public DNS CAA Record\n */\nexport interface DnsCaaRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of CAA records with flags, tag, and value\n   */\n  readonly records: DnsCaaRecordEntry[];\n}\n\n/**\n * Azure Public DNS CAA Record implementation\n *\n * CAA records specify which Certificate Authorities are authorized to issue\n * certificates for a domain. This record type is only available in Public DNS Zones.\n *\n * @example\n * // Create a CAA record to authorize Let's Encrypt:\n * const caaRecord = new DnsCaaRecord(this, \"caa-record\", {\n *   name: \"@\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { flags: 0, tag: \"issue\", value: \"letsencrypt.org\" },\n *     { flags: 0, tag: \"issuewild\", value: \";\" }, // Disallow wildcard certs\n *     { flags: 0, tag: \"iodef\", value: \"mailto:security@example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsCaaRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_CAA_RECORD_TYPE,\n      ALL_DNS_CAA_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsCaaRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsCaaRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the CAA Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the CAA Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the CAA Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsCaaRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_CAA_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsCaaRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      caaRecords: typedProps.records.map((r) => ({\n        flags: r.flags,\n        tag: r.tag,\n        value: r.value,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// CNAME RECORD\n// =============================================================================\n\n/**\n * Properties for Public DNS CNAME Record\n */\nexport interface DnsCnameRecordProps extends DnsRecordBaseProps {\n  /**\n   * The canonical name for this CNAME record\n   * Either cname or targetResourceId must be specified\n   * @example \"www.contoso.com\"\n   */\n  readonly cname?: string;\n\n  /**\n   * Reference to an Azure resource from where the DNS content is taken (alias record)\n   * Either cname or targetResourceId must be specified\n   */\n  readonly targetResourceId?: string;\n}\n\n/**\n * Azure Public DNS CNAME Record implementation\n *\n * CNAME records create an alias from one hostname to another.\n * Supports alias records via targetResourceId for pointing to Azure resources.\n * Note: CNAME records cannot coexist with other record types at the same name.\n *\n * @example\n * // Create a CNAME record:\n * const cnameRecord = new DnsCnameRecord(this, \"alias-record\", {\n *   name: \"app\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   cname: \"www.example.com\",\n * });\n *\n * @stability stable\n */\nexport class DnsCnameRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_CNAME_RECORD_TYPE,\n      ALL_DNS_CNAME_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsCnameRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsCnameRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the CNAME Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the CNAME Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the CNAME Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsCnameRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_CNAME_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsCnameRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n    };\n\n    if (typedProps.cname) {\n      properties.CNAMERecord = { cname: typedProps.cname };\n    }\n\n    if (typedProps.targetResourceId) {\n      properties.targetResource = { id: typedProps.targetResourceId };\n    }\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// MX RECORD\n// =============================================================================\n\n/**\n * Entry for an MX record\n */\nexport interface DnsMxRecordEntry {\n  /**\n   * The preference value for this MX record (lower values have higher priority)\n   * @example 10\n   */\n  readonly preference: number;\n\n  /**\n   * The mail exchange server hostname\n   * @example \"mail1.example.com\"\n   */\n  readonly exchange: string;\n}\n\n/**\n * Properties for Public DNS MX Record\n */\nexport interface DnsMxRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of MX records with exchange and preference\n   */\n  readonly records: DnsMxRecordEntry[];\n}\n\n/**\n * Azure Public DNS MX Record implementation\n *\n * MX records specify mail exchange servers for a domain.\n *\n * @example\n * // Create an MX record:\n * const mxRecord = new DnsMxRecord(this, \"mail-record\", {\n *   name: \"@\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { preference: 10, exchange: \"mail1.example.com\" },\n *     { preference: 20, exchange: \"mail2.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsMxRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_MX_RECORD_TYPE,\n      ALL_DNS_MX_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsMxRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsMxRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the MX Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the MX Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the MX Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsMxRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_MX_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsMxRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      MXRecords: typedProps.records.map((r) => ({\n        preference: r.preference,\n        exchange: r.exchange,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// NS RECORD (PUBLIC DNS ONLY)\n// =============================================================================\n\n/**\n * Entry for an NS record\n */\nexport interface DnsNsRecordEntry {\n  /**\n   * The name server domain name\n   * @example \"ns1.example.com\"\n   */\n  readonly nsdname: string;\n}\n\n/**\n * Properties for Public DNS NS Record\n */\nexport interface DnsNsRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of NS records with nsdname values\n   */\n  readonly records: DnsNsRecordEntry[];\n}\n\n/**\n * Azure Public DNS NS Record implementation\n *\n * NS records specify the authoritative name servers for a domain or subdomain.\n * This record type is only available in Public DNS Zones.\n *\n * @example\n * // Create an NS record for a subdomain delegation:\n * const nsRecord = new DnsNsRecord(this, \"ns-record\", {\n *   name: \"subdomain\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { nsdname: \"ns1.subdomain.example.com\" },\n *     { nsdname: \"ns2.subdomain.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsNsRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_NS_RECORD_TYPE,\n      ALL_DNS_NS_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsNsRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsNsRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the NS Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the NS Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the NS Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsNsRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_NS_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsNsRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      NSRecords: typedProps.records.map((r) => ({\n        nsdname: r.nsdname,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// PTR RECORD\n// =============================================================================\n\n/**\n * Entry for a PTR record\n */\nexport interface DnsPtrRecordEntry {\n  /**\n   * The PTR target domain name\n   * @example \"server1.example.com\"\n   */\n  readonly ptrdname: string;\n}\n\n/**\n * Properties for Public DNS PTR Record\n */\nexport interface DnsPtrRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of PTR records with ptrdname values\n   */\n  readonly records: DnsPtrRecordEntry[];\n}\n\n/**\n * Azure Public DNS PTR Record implementation\n *\n * PTR records are used for reverse DNS lookups, mapping IP addresses to hostnames.\n *\n * @example\n * // Create a PTR record:\n * const ptrRecord = new DnsPtrRecord(this, \"ptr-record\", {\n *   name: \"50\",\n *   dnsZoneId: reverseZone.id,\n *   ttl: 3600,\n *   records: [\n *     { ptrdname: \"server1.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsPtrRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_PTR_RECORD_TYPE,\n      ALL_DNS_PTR_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsPtrRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsPtrRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the PTR Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the PTR Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the PTR Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsPtrRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_PTR_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsPtrRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      PTRRecords: typedProps.records.map((r) => ({\n        ptrdname: r.ptrdname,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// SOA RECORD\n// =============================================================================\n\n/**\n * SOA record configuration\n */\nexport interface DnsSoaRecordConfig {\n  /**\n   * The domain name of the authoritative name server\n   */\n  readonly host?: string;\n\n  /**\n   * The email contact for this zone (with @ replaced by .)\n   * @example \"admin.example.com\" (for admin@example.com)\n   */\n  readonly email?: string;\n\n  /**\n   * The serial number for this zone\n   */\n  readonly serialNumber?: number;\n\n  /**\n   * The refresh time in seconds\n   */\n  readonly refreshTime?: number;\n\n  /**\n   * The retry time in seconds\n   */\n  readonly retryTime?: number;\n\n  /**\n   * The expire time in seconds\n   */\n  readonly expireTime?: number;\n\n  /**\n   * The minimum TTL in seconds\n   */\n  readonly minimumTTL?: number;\n}\n\n/**\n * Properties for Public DNS SOA Record\n */\nexport interface DnsSoaRecordProps extends DnsRecordBaseProps {\n  /**\n   * SOA record configuration\n   */\n  readonly soaRecord: DnsSoaRecordConfig;\n}\n\n/**\n * Azure Public DNS SOA Record implementation\n *\n * SOA records contain administrative information about a DNS zone.\n * Note: Each zone automatically has an SOA record; this is typically used to update it.\n *\n * @example\n * // Update the SOA record:\n * const soaRecord = new DnsSoaRecord(this, \"soa-record\", {\n *   name: \"@\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   soaRecord: {\n *     email: \"admin.example.com\",\n *     refreshTime: 3600,\n *     retryTime: 300,\n *     expireTime: 2419200,\n *     minimumTTL: 300,\n *   },\n * });\n *\n * @stability stable\n */\nexport class DnsSoaRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_SOA_RECORD_TYPE,\n      ALL_DNS_SOA_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsSoaRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsSoaRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the SOA Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the SOA Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the SOA Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsSoaRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_SOA_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsSoaRecordProps;\n    const soaRecord: { [key: string]: unknown } = {};\n\n    if (typedProps.soaRecord.host !== undefined) {\n      soaRecord.host = typedProps.soaRecord.host;\n    }\n    if (typedProps.soaRecord.email !== undefined) {\n      soaRecord.email = typedProps.soaRecord.email;\n    }\n    if (typedProps.soaRecord.serialNumber !== undefined) {\n      soaRecord.serialNumber = typedProps.soaRecord.serialNumber;\n    }\n    if (typedProps.soaRecord.refreshTime !== undefined) {\n      soaRecord.refreshTime = typedProps.soaRecord.refreshTime;\n    }\n    if (typedProps.soaRecord.retryTime !== undefined) {\n      soaRecord.retryTime = typedProps.soaRecord.retryTime;\n    }\n    if (typedProps.soaRecord.expireTime !== undefined) {\n      soaRecord.expireTime = typedProps.soaRecord.expireTime;\n    }\n    if (typedProps.soaRecord.minimumTTL !== undefined) {\n      soaRecord.minimumTTL = typedProps.soaRecord.minimumTTL;\n    }\n\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      SOARecord: soaRecord,\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// SRV RECORD\n// =============================================================================\n\n/**\n * Entry for an SRV record\n */\nexport interface DnsSrvRecordEntry {\n  /**\n   * The priority of this SRV record (lower values have higher priority)\n   */\n  readonly priority: number;\n\n  /**\n   * The weight of this SRV record (used for load balancing among records with same priority)\n   */\n  readonly weight: number;\n\n  /**\n   * The port number for the service\n   */\n  readonly port: number;\n\n  /**\n   * The target hostname providing the service\n   * @example \"sipserver.example.com\"\n   */\n  readonly target: string;\n}\n\n/**\n * Properties for Public DNS SRV Record\n */\nexport interface DnsSrvRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of SRV records with priority, weight, port, and target\n   */\n  readonly records: DnsSrvRecordEntry[];\n}\n\n/**\n * Azure Public DNS SRV Record implementation\n *\n * SRV records specify the location of services like SIP, XMPP, etc.\n *\n * @example\n * // Create an SRV record for a SIP service:\n * const srvRecord = new DnsSrvRecord(this, \"sip-record\", {\n *   name: \"_sip._tcp\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { priority: 10, weight: 60, port: 5060, target: \"sipserver1.example.com\" },\n *     { priority: 10, weight: 40, port: 5060, target: \"sipserver2.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsSrvRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_SRV_RECORD_TYPE,\n      ALL_DNS_SRV_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsSrvRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsSrvRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the SRV Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the SRV Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the SRV Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsSrvRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_SRV_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsSrvRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      SRVRecords: typedProps.records.map((r) => ({\n        priority: r.priority,\n        weight: r.weight,\n        port: r.port,\n        target: r.target,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n\n// =============================================================================\n// TXT RECORD\n// =============================================================================\n\n/**\n * Entry for a TXT record\n */\nexport interface DnsTxtRecordEntry {\n  /**\n   * The text value of this TXT record (array of strings, each up to 255 chars)\n   * Long values are automatically split into multiple strings\n   * @example [\"v=spf1 include:spf.protection.outlook.com -all\"]\n   */\n  readonly value: string[];\n}\n\n/**\n * Properties for Public DNS TXT Record\n */\nexport interface DnsTxtRecordProps extends DnsRecordBaseProps {\n  /**\n   * Array of TXT records with string values\n   */\n  readonly records: DnsTxtRecordEntry[];\n}\n\n/**\n * Azure Public DNS TXT Record implementation\n *\n * TXT records store arbitrary text data, commonly used for SPF, DKIM, domain verification, etc.\n *\n * @example\n * // Create a TXT record for SPF:\n * const txtRecord = new DnsTxtRecord(this, \"spf-record\", {\n *   name: \"@\",\n *   dnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { value: [\"v=spf1 include:spf.protection.outlook.com -all\"] },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class DnsTxtRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_TXT_RECORD_TYPE,\n      ALL_DNS_TXT_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsTxtRecordProps;\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly fqdnOutput: cdktf.TerraformOutput;\n\n  constructor(scope: Construct, id: string, props: DnsTxtRecordProps) {\n    super(scope, id, props);\n    this.props = props;\n\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the TXT Record\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the TXT Record\",\n    });\n\n    this.fqdnOutput = new cdktf.TerraformOutput(this, \"fqdn\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.fqdn}`,\n      description: \"The FQDN of the TXT Record\",\n    });\n\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.fqdnOutput.overrideLogicalId(\"fqdn\");\n  }\n\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsTxtRecordProps;\n    return typedProps.dnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  protected resourceType(): string {\n    return DNS_TXT_RECORD_TYPE;\n  }\n\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsTxtRecordProps;\n    const properties: { [key: string]: unknown } = {\n      TTL: typedProps.ttl ?? 3600,\n      TXTRecords: typedProps.records.map((r) => ({\n        value: r.value,\n      })),\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      properties.metadata = typedProps.metadata;\n    }\n\n    return { properties };\n  }\n\n  /**\n   * Get the FQDN of the record\n   */\n  public get fqdn(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.fqdn}`;\n  }\n}\n"]}
|