@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.
Files changed (121) hide show
  1. package/.jsii +46476 -27231
  2. package/API.md +68443 -28286
  3. package/lib/azure-actiongroup/lib/action-group.js +1 -1
  4. package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
  5. package/lib/azure-aks/lib/aks-cluster.js +1 -1
  6. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
  7. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
  8. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
  9. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
  10. package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
  11. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
  12. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
  13. package/lib/azure-dnszone/lib/dns-zone.js +1 -1
  14. package/lib/azure-dnszone/lib/index.d.ts +1 -0
  15. package/lib/azure-dnszone/lib/index.js +2 -1
  16. package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
  17. package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
  18. package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
  19. package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
  20. package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
  21. package/lib/azure-dnszone/lib/records/index.js +38 -0
  22. package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
  23. package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
  24. package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
  25. package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
  26. package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
  27. package/lib/azure-loganalyticsworkspace/index.js +23 -0
  28. package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
  29. package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
  30. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
  31. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
  32. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
  33. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
  34. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
  35. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
  36. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
  37. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
  38. package/lib/azure-metricalert/lib/metric-alert.js +1 -1
  39. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  40. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  41. package/lib/azure-networkwatcher/index.d.ts +14 -0
  42. package/lib/azure-networkwatcher/index.js +31 -0
  43. package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
  44. package/lib/azure-networkwatcher/lib/index.js +22 -0
  45. package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
  46. package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
  47. package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
  48. package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
  49. package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
  50. package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
  51. package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
  52. package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
  53. package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
  54. package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
  55. package/lib/azure-policysetdefinition/index.d.ts +10 -0
  56. package/lib/azure-policysetdefinition/index.js +27 -0
  57. package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
  58. package/lib/azure-policysetdefinition/lib/index.js +22 -0
  59. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
  60. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
  61. package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
  62. package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
  63. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
  64. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
  65. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
  66. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
  67. package/lib/azure-privatednszone/lib/index.d.ts +1 -0
  68. package/lib/azure-privatednszone/lib/index.js +2 -1
  69. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
  70. package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
  71. package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
  72. package/lib/azure-privatednszone/lib/records/index.js +26 -0
  73. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
  74. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
  75. package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
  76. package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
  77. package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
  78. package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
  79. package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
  80. package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
  81. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
  82. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  83. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  84. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  85. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  86. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  87. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  88. package/lib/azure-subnet/lib/subnet.js +1 -1
  89. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  90. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  91. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
  92. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
  93. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
  94. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
  95. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
  96. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  97. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
  98. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
  99. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  100. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  101. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  102. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  103. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  104. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
  105. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  106. package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
  107. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  108. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  109. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  110. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  111. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  112. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  113. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  114. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  115. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  116. package/lib/index.d.ts +23 -0
  117. package/lib/index.js +25 -2
  118. package/lib/testing/index.js +2 -2
  119. package/lib/testing/lib/cleanup.js +1 -1
  120. package/lib/testing/lib/metadata.js +1 -1
  121. package/package.json +1 -1
@@ -0,0 +1,739 @@
1
+ "use strict";
2
+ var _a, _b, _c, _d, _e, _f, _g, _h;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.PrivateDnsTxtRecord = exports.PrivateDnsSrvRecord = exports.PrivateDnsSoaRecord = exports.PrivateDnsPtrRecord = exports.PrivateDnsMxRecord = exports.PrivateDnsCnameRecord = exports.PrivateDnsAaaaRecord = exports.PrivateDnsARecord = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Azure Private DNS Zone Record implementations using AzapiResource framework
8
+ *
9
+ * This file provides implementations for all Private DNS Zone record types:
10
+ * - PrivateDnsARecord (A records with IPv4 addresses)
11
+ * - PrivateDnsAaaaRecord (AAAA records with IPv6 addresses)
12
+ * - PrivateDnsCnameRecord (CNAME records)
13
+ * - PrivateDnsMxRecord (MX records with exchange and preference)
14
+ * - PrivateDnsPtrRecord (PTR records)
15
+ * - PrivateDnsSoaRecord (SOA records)
16
+ * - PrivateDnsSrvRecord (SRV records with priority, weight, port, target)
17
+ * - PrivateDnsTxtRecord (TXT records)
18
+ *
19
+ * API Version: 2024-06-01
20
+ */
21
+ const cdktf = require("cdktf");
22
+ const private_dns_record_schemas_1 = require("./private-dns-record-schemas");
23
+ const azapi_resource_1 = require("../../../core-azure/lib/azapi/azapi-resource");
24
+ /**
25
+ * Azure Private DNS A Record implementation
26
+ *
27
+ * A records map a hostname to one or more IPv4 addresses.
28
+ *
29
+ * @example
30
+ * // Create an A record with multiple IP addresses:
31
+ * const aRecord = new PrivateDnsARecord(this, "web-a-record", {
32
+ * name: "www",
33
+ * privateDnsZoneId: zone.id,
34
+ * ttl: 300,
35
+ * records: [
36
+ * { ipv4Address: "10.0.1.4" },
37
+ * { ipv4Address: "10.0.1.5" },
38
+ * ],
39
+ * });
40
+ *
41
+ * @stability stable
42
+ */
43
+ class PrivateDnsARecord extends azapi_resource_1.AzapiResource {
44
+ constructor(scope, id, props) {
45
+ super(scope, id, props);
46
+ this.props = props;
47
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
48
+ value: this.id,
49
+ description: "The ID of the A Record",
50
+ });
51
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
52
+ value: `\${${this.terraformResource.fqn}.name}`,
53
+ description: "The name of the A Record",
54
+ });
55
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
56
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
57
+ description: "The FQDN of the A Record",
58
+ });
59
+ this.idOutput.overrideLogicalId("id");
60
+ this.nameOutput.overrideLogicalId("name");
61
+ this.fqdnOutput.overrideLogicalId("fqdn");
62
+ }
63
+ resolveParentId(props) {
64
+ const typedProps = props;
65
+ return typedProps.privateDnsZoneId;
66
+ }
67
+ defaultVersion() {
68
+ return "2024-06-01";
69
+ }
70
+ resourceType() {
71
+ return private_dns_record_schemas_1.PRIVATE_DNS_A_RECORD_TYPE;
72
+ }
73
+ apiSchema() {
74
+ return this.resolveSchema();
75
+ }
76
+ requiresLocation() {
77
+ return false;
78
+ }
79
+ supportsTags() {
80
+ return false;
81
+ }
82
+ createResourceBody(props) {
83
+ const typedProps = props;
84
+ const body = {
85
+ properties: {
86
+ ttl: typedProps.ttl ?? 3600,
87
+ aRecords: typedProps.records.map((r) => ({
88
+ ipv4Address: r.ipv4Address,
89
+ })),
90
+ },
91
+ };
92
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
93
+ body.properties.metadata =
94
+ typedProps.metadata;
95
+ }
96
+ return body;
97
+ }
98
+ /**
99
+ * Get the FQDN of the record
100
+ */
101
+ get fqdn() {
102
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
103
+ }
104
+ }
105
+ exports.PrivateDnsARecord = PrivateDnsARecord;
106
+ _a = JSII_RTTI_SYMBOL_1;
107
+ PrivateDnsARecord[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsARecord", version: "1.9.0" };
108
+ (() => {
109
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_A_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_A_RECORD_VERSIONS);
110
+ })();
111
+ /**
112
+ * Azure Private DNS AAAA Record implementation
113
+ *
114
+ * AAAA records map a hostname to one or more IPv6 addresses.
115
+ *
116
+ * @example
117
+ * // Create an AAAA record:
118
+ * const aaaaRecord = new PrivateDnsAaaaRecord(this, "web-aaaa-record", {
119
+ * name: "www",
120
+ * privateDnsZoneId: zone.id,
121
+ * ttl: 300,
122
+ * records: [
123
+ * { ipv6Address: "2001:db8::1" },
124
+ * ],
125
+ * });
126
+ *
127
+ * @stability stable
128
+ */
129
+ class PrivateDnsAaaaRecord extends azapi_resource_1.AzapiResource {
130
+ constructor(scope, id, props) {
131
+ super(scope, id, props);
132
+ this.props = props;
133
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
134
+ value: this.id,
135
+ description: "The ID of the AAAA Record",
136
+ });
137
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
138
+ value: `\${${this.terraformResource.fqn}.name}`,
139
+ description: "The name of the AAAA Record",
140
+ });
141
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
142
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
143
+ description: "The FQDN of the AAAA Record",
144
+ });
145
+ this.idOutput.overrideLogicalId("id");
146
+ this.nameOutput.overrideLogicalId("name");
147
+ this.fqdnOutput.overrideLogicalId("fqdn");
148
+ }
149
+ resolveParentId(props) {
150
+ const typedProps = props;
151
+ return typedProps.privateDnsZoneId;
152
+ }
153
+ defaultVersion() {
154
+ return "2024-06-01";
155
+ }
156
+ resourceType() {
157
+ return private_dns_record_schemas_1.PRIVATE_DNS_AAAA_RECORD_TYPE;
158
+ }
159
+ apiSchema() {
160
+ return this.resolveSchema();
161
+ }
162
+ requiresLocation() {
163
+ return false;
164
+ }
165
+ supportsTags() {
166
+ return false;
167
+ }
168
+ createResourceBody(props) {
169
+ const typedProps = props;
170
+ const body = {
171
+ properties: {
172
+ ttl: typedProps.ttl ?? 3600,
173
+ aaaaRecords: typedProps.records.map((r) => ({
174
+ ipv6Address: r.ipv6Address,
175
+ })),
176
+ },
177
+ };
178
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
179
+ body.properties.metadata =
180
+ typedProps.metadata;
181
+ }
182
+ return body;
183
+ }
184
+ /**
185
+ * Get the FQDN of the record
186
+ */
187
+ get fqdn() {
188
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
189
+ }
190
+ }
191
+ exports.PrivateDnsAaaaRecord = PrivateDnsAaaaRecord;
192
+ _b = JSII_RTTI_SYMBOL_1;
193
+ PrivateDnsAaaaRecord[_b] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsAaaaRecord", version: "1.9.0" };
194
+ (() => {
195
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_AAAA_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_AAAA_RECORD_VERSIONS);
196
+ })();
197
+ /**
198
+ * Azure Private DNS CNAME Record implementation
199
+ *
200
+ * CNAME records create an alias from one hostname to another.
201
+ * Note: CNAME records cannot coexist with other record types at the same name.
202
+ *
203
+ * @example
204
+ * // Create a CNAME record:
205
+ * const cnameRecord = new PrivateDnsCnameRecord(this, "alias-record", {
206
+ * name: "app",
207
+ * privateDnsZoneId: zone.id,
208
+ * ttl: 3600,
209
+ * cname: "www.internal.example.com",
210
+ * });
211
+ *
212
+ * @stability stable
213
+ */
214
+ class PrivateDnsCnameRecord extends azapi_resource_1.AzapiResource {
215
+ constructor(scope, id, props) {
216
+ super(scope, id, props);
217
+ this.props = props;
218
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
219
+ value: this.id,
220
+ description: "The ID of the CNAME Record",
221
+ });
222
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
223
+ value: `\${${this.terraformResource.fqn}.name}`,
224
+ description: "The name of the CNAME Record",
225
+ });
226
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
227
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
228
+ description: "The FQDN of the CNAME Record",
229
+ });
230
+ this.idOutput.overrideLogicalId("id");
231
+ this.nameOutput.overrideLogicalId("name");
232
+ this.fqdnOutput.overrideLogicalId("fqdn");
233
+ }
234
+ resolveParentId(props) {
235
+ const typedProps = props;
236
+ return typedProps.privateDnsZoneId;
237
+ }
238
+ defaultVersion() {
239
+ return "2024-06-01";
240
+ }
241
+ resourceType() {
242
+ return private_dns_record_schemas_1.PRIVATE_DNS_CNAME_RECORD_TYPE;
243
+ }
244
+ apiSchema() {
245
+ return this.resolveSchema();
246
+ }
247
+ requiresLocation() {
248
+ return false;
249
+ }
250
+ supportsTags() {
251
+ return false;
252
+ }
253
+ createResourceBody(props) {
254
+ const typedProps = props;
255
+ const body = {
256
+ properties: {
257
+ ttl: typedProps.ttl ?? 3600,
258
+ cnameRecord: {
259
+ cname: typedProps.cname,
260
+ },
261
+ },
262
+ };
263
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
264
+ body.properties.metadata =
265
+ typedProps.metadata;
266
+ }
267
+ return body;
268
+ }
269
+ /**
270
+ * Get the FQDN of the record
271
+ */
272
+ get fqdn() {
273
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
274
+ }
275
+ }
276
+ exports.PrivateDnsCnameRecord = PrivateDnsCnameRecord;
277
+ _c = JSII_RTTI_SYMBOL_1;
278
+ PrivateDnsCnameRecord[_c] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsCnameRecord", version: "1.9.0" };
279
+ (() => {
280
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_CNAME_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_CNAME_RECORD_VERSIONS);
281
+ })();
282
+ /**
283
+ * Azure Private DNS MX Record implementation
284
+ *
285
+ * MX records specify mail exchange servers for a domain.
286
+ *
287
+ * @example
288
+ * // Create an MX record:
289
+ * const mxRecord = new PrivateDnsMxRecord(this, "mail-record", {
290
+ * name: "@",
291
+ * privateDnsZoneId: zone.id,
292
+ * ttl: 3600,
293
+ * records: [
294
+ * { preference: 10, exchange: "mail1.internal.example.com" },
295
+ * { preference: 20, exchange: "mail2.internal.example.com" },
296
+ * ],
297
+ * });
298
+ *
299
+ * @stability stable
300
+ */
301
+ class PrivateDnsMxRecord extends azapi_resource_1.AzapiResource {
302
+ constructor(scope, id, props) {
303
+ super(scope, id, props);
304
+ this.props = props;
305
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
306
+ value: this.id,
307
+ description: "The ID of the MX Record",
308
+ });
309
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
310
+ value: `\${${this.terraformResource.fqn}.name}`,
311
+ description: "The name of the MX Record",
312
+ });
313
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
314
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
315
+ description: "The FQDN of the MX Record",
316
+ });
317
+ this.idOutput.overrideLogicalId("id");
318
+ this.nameOutput.overrideLogicalId("name");
319
+ this.fqdnOutput.overrideLogicalId("fqdn");
320
+ }
321
+ resolveParentId(props) {
322
+ const typedProps = props;
323
+ return typedProps.privateDnsZoneId;
324
+ }
325
+ defaultVersion() {
326
+ return "2024-06-01";
327
+ }
328
+ resourceType() {
329
+ return private_dns_record_schemas_1.PRIVATE_DNS_MX_RECORD_TYPE;
330
+ }
331
+ apiSchema() {
332
+ return this.resolveSchema();
333
+ }
334
+ requiresLocation() {
335
+ return false;
336
+ }
337
+ supportsTags() {
338
+ return false;
339
+ }
340
+ createResourceBody(props) {
341
+ const typedProps = props;
342
+ const body = {
343
+ properties: {
344
+ ttl: typedProps.ttl ?? 3600,
345
+ mxRecords: typedProps.records.map((r) => ({
346
+ preference: r.preference,
347
+ exchange: r.exchange,
348
+ })),
349
+ },
350
+ };
351
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
352
+ body.properties.metadata =
353
+ typedProps.metadata;
354
+ }
355
+ return body;
356
+ }
357
+ /**
358
+ * Get the FQDN of the record
359
+ */
360
+ get fqdn() {
361
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
362
+ }
363
+ }
364
+ exports.PrivateDnsMxRecord = PrivateDnsMxRecord;
365
+ _d = JSII_RTTI_SYMBOL_1;
366
+ PrivateDnsMxRecord[_d] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsMxRecord", version: "1.9.0" };
367
+ (() => {
368
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_MX_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_MX_RECORD_VERSIONS);
369
+ })();
370
+ /**
371
+ * Azure Private DNS PTR Record implementation
372
+ *
373
+ * PTR records are used for reverse DNS lookups, mapping IP addresses to hostnames.
374
+ *
375
+ * @example
376
+ * // Create a PTR record:
377
+ * const ptrRecord = new PrivateDnsPtrRecord(this, "ptr-record", {
378
+ * name: "4.1.0.10.in-addr.arpa",
379
+ * privateDnsZoneId: reverseZone.id,
380
+ * ttl: 3600,
381
+ * records: [
382
+ * { ptrdname: "server1.internal.example.com" },
383
+ * ],
384
+ * });
385
+ *
386
+ * @stability stable
387
+ */
388
+ class PrivateDnsPtrRecord extends azapi_resource_1.AzapiResource {
389
+ constructor(scope, id, props) {
390
+ super(scope, id, props);
391
+ this.props = props;
392
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
393
+ value: this.id,
394
+ description: "The ID of the PTR Record",
395
+ });
396
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
397
+ value: `\${${this.terraformResource.fqn}.name}`,
398
+ description: "The name of the PTR Record",
399
+ });
400
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
401
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
402
+ description: "The FQDN of the PTR Record",
403
+ });
404
+ this.idOutput.overrideLogicalId("id");
405
+ this.nameOutput.overrideLogicalId("name");
406
+ this.fqdnOutput.overrideLogicalId("fqdn");
407
+ }
408
+ resolveParentId(props) {
409
+ const typedProps = props;
410
+ return typedProps.privateDnsZoneId;
411
+ }
412
+ defaultVersion() {
413
+ return "2024-06-01";
414
+ }
415
+ resourceType() {
416
+ return private_dns_record_schemas_1.PRIVATE_DNS_PTR_RECORD_TYPE;
417
+ }
418
+ apiSchema() {
419
+ return this.resolveSchema();
420
+ }
421
+ requiresLocation() {
422
+ return false;
423
+ }
424
+ supportsTags() {
425
+ return false;
426
+ }
427
+ createResourceBody(props) {
428
+ const typedProps = props;
429
+ const body = {
430
+ properties: {
431
+ ttl: typedProps.ttl ?? 3600,
432
+ ptrRecords: typedProps.records.map((r) => ({ ptrdname: r.ptrdname })),
433
+ },
434
+ };
435
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
436
+ body.properties.metadata =
437
+ typedProps.metadata;
438
+ }
439
+ return body;
440
+ }
441
+ /**
442
+ * Get the FQDN of the record
443
+ */
444
+ get fqdn() {
445
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
446
+ }
447
+ }
448
+ exports.PrivateDnsPtrRecord = PrivateDnsPtrRecord;
449
+ _e = JSII_RTTI_SYMBOL_1;
450
+ PrivateDnsPtrRecord[_e] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsPtrRecord", version: "1.9.0" };
451
+ (() => {
452
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_PTR_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_PTR_RECORD_VERSIONS);
453
+ })();
454
+ /**
455
+ * Azure Private DNS SOA Record implementation
456
+ *
457
+ * SOA records contain administrative information about a DNS zone.
458
+ * Note: Each zone automatically has an SOA record; this is typically used to update it.
459
+ *
460
+ * @example
461
+ * // Update the SOA record:
462
+ * const soaRecord = new PrivateDnsSoaRecord(this, "soa-record", {
463
+ * name: "@",
464
+ * privateDnsZoneId: zone.id,
465
+ * ttl: 3600,
466
+ * soaRecord: {
467
+ * email: "admin.example.com",
468
+ * refreshTime: 3600,
469
+ * retryTime: 300,
470
+ * expireTime: 2419200,
471
+ * minimumTtl: 300,
472
+ * },
473
+ * });
474
+ *
475
+ * @stability stable
476
+ */
477
+ class PrivateDnsSoaRecord extends azapi_resource_1.AzapiResource {
478
+ constructor(scope, id, props) {
479
+ super(scope, id, props);
480
+ this.props = props;
481
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
482
+ value: this.id,
483
+ description: "The ID of the SOA Record",
484
+ });
485
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
486
+ value: `\${${this.terraformResource.fqn}.name}`,
487
+ description: "The name of the SOA Record",
488
+ });
489
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
490
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
491
+ description: "The FQDN of the SOA Record",
492
+ });
493
+ this.idOutput.overrideLogicalId("id");
494
+ this.nameOutput.overrideLogicalId("name");
495
+ this.fqdnOutput.overrideLogicalId("fqdn");
496
+ }
497
+ resolveParentId(props) {
498
+ const typedProps = props;
499
+ return typedProps.privateDnsZoneId;
500
+ }
501
+ defaultVersion() {
502
+ return "2024-06-01";
503
+ }
504
+ resourceType() {
505
+ return private_dns_record_schemas_1.PRIVATE_DNS_SOA_RECORD_TYPE;
506
+ }
507
+ apiSchema() {
508
+ return this.resolveSchema();
509
+ }
510
+ requiresLocation() {
511
+ return false;
512
+ }
513
+ supportsTags() {
514
+ return false;
515
+ }
516
+ createResourceBody(props) {
517
+ const typedProps = props;
518
+ const soaRecord = {};
519
+ if (typedProps.soaRecord.host !== undefined) {
520
+ soaRecord.host = typedProps.soaRecord.host;
521
+ }
522
+ if (typedProps.soaRecord.email !== undefined) {
523
+ soaRecord.email = typedProps.soaRecord.email;
524
+ }
525
+ if (typedProps.soaRecord.serialNumber !== undefined) {
526
+ soaRecord.serialNumber = typedProps.soaRecord.serialNumber;
527
+ }
528
+ if (typedProps.soaRecord.refreshTime !== undefined) {
529
+ soaRecord.refreshTime = typedProps.soaRecord.refreshTime;
530
+ }
531
+ if (typedProps.soaRecord.retryTime !== undefined) {
532
+ soaRecord.retryTime = typedProps.soaRecord.retryTime;
533
+ }
534
+ if (typedProps.soaRecord.expireTime !== undefined) {
535
+ soaRecord.expireTime = typedProps.soaRecord.expireTime;
536
+ }
537
+ if (typedProps.soaRecord.minimumTtl !== undefined) {
538
+ soaRecord.minimumTtl = typedProps.soaRecord.minimumTtl;
539
+ }
540
+ const body = {
541
+ properties: {
542
+ ttl: typedProps.ttl ?? 3600,
543
+ soaRecord: soaRecord,
544
+ },
545
+ };
546
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
547
+ body.properties.metadata =
548
+ typedProps.metadata;
549
+ }
550
+ return body;
551
+ }
552
+ /**
553
+ * Get the FQDN of the record
554
+ */
555
+ get fqdn() {
556
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
557
+ }
558
+ }
559
+ exports.PrivateDnsSoaRecord = PrivateDnsSoaRecord;
560
+ _f = JSII_RTTI_SYMBOL_1;
561
+ PrivateDnsSoaRecord[_f] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSoaRecord", version: "1.9.0" };
562
+ (() => {
563
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_SOA_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_SOA_RECORD_VERSIONS);
564
+ })();
565
+ /**
566
+ * Azure Private DNS SRV Record implementation
567
+ *
568
+ * SRV records specify the location of services like SIP, XMPP, etc.
569
+ *
570
+ * @example
571
+ * // Create an SRV record for a SIP service:
572
+ * const srvRecord = new PrivateDnsSrvRecord(this, "sip-record", {
573
+ * name: "_sip._tcp",
574
+ * privateDnsZoneId: zone.id,
575
+ * ttl: 3600,
576
+ * records: [
577
+ * { priority: 10, weight: 60, port: 5060, target: "sipserver1.internal.example.com" },
578
+ * { priority: 10, weight: 40, port: 5060, target: "sipserver2.internal.example.com" },
579
+ * ],
580
+ * });
581
+ *
582
+ * @stability stable
583
+ */
584
+ class PrivateDnsSrvRecord extends azapi_resource_1.AzapiResource {
585
+ constructor(scope, id, props) {
586
+ super(scope, id, props);
587
+ this.props = props;
588
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
589
+ value: this.id,
590
+ description: "The ID of the SRV Record",
591
+ });
592
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
593
+ value: `\${${this.terraformResource.fqn}.name}`,
594
+ description: "The name of the SRV Record",
595
+ });
596
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
597
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
598
+ description: "The FQDN of the SRV Record",
599
+ });
600
+ this.idOutput.overrideLogicalId("id");
601
+ this.nameOutput.overrideLogicalId("name");
602
+ this.fqdnOutput.overrideLogicalId("fqdn");
603
+ }
604
+ resolveParentId(props) {
605
+ const typedProps = props;
606
+ return typedProps.privateDnsZoneId;
607
+ }
608
+ defaultVersion() {
609
+ return "2024-06-01";
610
+ }
611
+ resourceType() {
612
+ return private_dns_record_schemas_1.PRIVATE_DNS_SRV_RECORD_TYPE;
613
+ }
614
+ apiSchema() {
615
+ return this.resolveSchema();
616
+ }
617
+ requiresLocation() {
618
+ return false;
619
+ }
620
+ supportsTags() {
621
+ return false;
622
+ }
623
+ createResourceBody(props) {
624
+ const typedProps = props;
625
+ const body = {
626
+ properties: {
627
+ ttl: typedProps.ttl ?? 3600,
628
+ srvRecords: typedProps.records.map((r) => ({
629
+ priority: r.priority,
630
+ weight: r.weight,
631
+ port: r.port,
632
+ target: r.target,
633
+ })),
634
+ },
635
+ };
636
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
637
+ body.properties.metadata =
638
+ typedProps.metadata;
639
+ }
640
+ return body;
641
+ }
642
+ /**
643
+ * Get the FQDN of the record
644
+ */
645
+ get fqdn() {
646
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
647
+ }
648
+ }
649
+ exports.PrivateDnsSrvRecord = PrivateDnsSrvRecord;
650
+ _g = JSII_RTTI_SYMBOL_1;
651
+ PrivateDnsSrvRecord[_g] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSrvRecord", version: "1.9.0" };
652
+ (() => {
653
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_SRV_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_SRV_RECORD_VERSIONS);
654
+ })();
655
+ /**
656
+ * Azure Private DNS TXT Record implementation
657
+ *
658
+ * TXT records store arbitrary text data, commonly used for SPF, DKIM, etc.
659
+ *
660
+ * @example
661
+ * // Create a TXT record for SPF:
662
+ * const txtRecord = new PrivateDnsTxtRecord(this, "spf-record", {
663
+ * name: "@",
664
+ * privateDnsZoneId: zone.id,
665
+ * ttl: 3600,
666
+ * records: [
667
+ * { value: ["v=spf1 include:spf.protection.outlook.com -all"] },
668
+ * ],
669
+ * });
670
+ *
671
+ * @stability stable
672
+ */
673
+ class PrivateDnsTxtRecord extends azapi_resource_1.AzapiResource {
674
+ constructor(scope, id, props) {
675
+ super(scope, id, props);
676
+ this.props = props;
677
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
678
+ value: this.id,
679
+ description: "The ID of the TXT Record",
680
+ });
681
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
682
+ value: `\${${this.terraformResource.fqn}.name}`,
683
+ description: "The name of the TXT Record",
684
+ });
685
+ this.fqdnOutput = new cdktf.TerraformOutput(this, "fqdn", {
686
+ value: `\${${this.terraformResource.fqn}.output.properties.fqdn}`,
687
+ description: "The FQDN of the TXT Record",
688
+ });
689
+ this.idOutput.overrideLogicalId("id");
690
+ this.nameOutput.overrideLogicalId("name");
691
+ this.fqdnOutput.overrideLogicalId("fqdn");
692
+ }
693
+ resolveParentId(props) {
694
+ const typedProps = props;
695
+ return typedProps.privateDnsZoneId;
696
+ }
697
+ defaultVersion() {
698
+ return "2024-06-01";
699
+ }
700
+ resourceType() {
701
+ return private_dns_record_schemas_1.PRIVATE_DNS_TXT_RECORD_TYPE;
702
+ }
703
+ apiSchema() {
704
+ return this.resolveSchema();
705
+ }
706
+ requiresLocation() {
707
+ return false;
708
+ }
709
+ supportsTags() {
710
+ return false;
711
+ }
712
+ createResourceBody(props) {
713
+ const typedProps = props;
714
+ const body = {
715
+ properties: {
716
+ ttl: typedProps.ttl ?? 3600,
717
+ txtRecords: typedProps.records.map((r) => ({ value: r.value })),
718
+ },
719
+ };
720
+ if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {
721
+ body.properties.metadata =
722
+ typedProps.metadata;
723
+ }
724
+ return body;
725
+ }
726
+ /**
727
+ * Get the FQDN of the record
728
+ */
729
+ get fqdn() {
730
+ return `\${${this.terraformResource.fqn}.output.properties.fqdn}`;
731
+ }
732
+ }
733
+ exports.PrivateDnsTxtRecord = PrivateDnsTxtRecord;
734
+ _h = JSII_RTTI_SYMBOL_1;
735
+ PrivateDnsTxtRecord[_h] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsTxtRecord", version: "1.9.0" };
736
+ (() => {
737
+ azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_TXT_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_TXT_RECORD_VERSIONS);
738
+ })();
739
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"private-dns-records.js","sourceRoot":"","sources":["../../../../src/azure-privatednszone/lib/records/private-dns-records.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Private DNS Zone Record implementations using AzapiResource framework\n *\n * This file provides implementations for all Private DNS Zone record types:\n * - PrivateDnsARecord (A records with IPv4 addresses)\n * - PrivateDnsAaaaRecord (AAAA records with IPv6 addresses)\n * - PrivateDnsCnameRecord (CNAME records)\n * - PrivateDnsMxRecord (MX records with exchange and preference)\n * - PrivateDnsPtrRecord (PTR records)\n * - PrivateDnsSoaRecord (SOA records)\n * - PrivateDnsSrvRecord (SRV records with priority, weight, port, target)\n * - PrivateDnsTxtRecord (TXT records)\n *\n * API Version: 2024-06-01\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_PRIVATE_DNS_A_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_AAAA_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_CNAME_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_MX_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_PTR_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_SOA_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_SRV_RECORD_VERSIONS,\n  ALL_PRIVATE_DNS_TXT_RECORD_VERSIONS,\n  PRIVATE_DNS_A_RECORD_TYPE,\n  PRIVATE_DNS_AAAA_RECORD_TYPE,\n  PRIVATE_DNS_CNAME_RECORD_TYPE,\n  PRIVATE_DNS_MX_RECORD_TYPE,\n  PRIVATE_DNS_PTR_RECORD_TYPE,\n  PRIVATE_DNS_SOA_RECORD_TYPE,\n  PRIVATE_DNS_SRV_RECORD_TYPE,\n  PRIVATE_DNS_TXT_RECORD_TYPE,\n} from \"./private-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 Private 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 PrivateDnsRecordBaseProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the parent Private DNS Zone\n   * @example zone.id or \"/subscriptions/.../providers/Microsoft.Network/privateDnsZones/example.com\"\n   */\n  readonly privateDnsZoneId: 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 ARecordEntry {\n  /**\n   * The IPv4 address of this A record\n   * @example \"10.0.1.4\"\n   */\n  readonly ipv4Address: string;\n}\n\n/**\n * Properties for Private DNS A Record\n */\nexport interface PrivateDnsARecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of A records with IPv4 addresses\n   */\n  readonly records: ARecordEntry[];\n}\n\n/**\n * Azure Private DNS A Record implementation\n *\n * A records map a hostname to one or more IPv4 addresses.\n *\n * @example\n * // Create an A record with multiple IP addresses:\n * const aRecord = new PrivateDnsARecord(this, \"web-a-record\", {\n *   name: \"www\",\n *   privateDnsZoneId: zone.id,\n *   ttl: 300,\n *   records: [\n *     { ipv4Address: \"10.0.1.4\" },\n *     { ipv4Address: \"10.0.1.5\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsARecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_A_RECORD_TYPE,\n      ALL_PRIVATE_DNS_A_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsARecordProps;\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: PrivateDnsARecordProps) {\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 PrivateDnsARecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsARecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        aRecords: typedProps.records.map((r) => ({\n          ipv4Address: r.ipv4Address,\n        })),\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 AaaaRecordEntry {\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 Private DNS AAAA Record\n */\nexport interface PrivateDnsAaaaRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of AAAA records with IPv6 addresses\n   */\n  readonly records: AaaaRecordEntry[];\n}\n\n/**\n * Azure Private DNS AAAA Record implementation\n *\n * AAAA records map a hostname to one or more IPv6 addresses.\n *\n * @example\n * // Create an AAAA record:\n * const aaaaRecord = new PrivateDnsAaaaRecord(this, \"web-aaaa-record\", {\n *   name: \"www\",\n *   privateDnsZoneId: zone.id,\n *   ttl: 300,\n *   records: [\n *     { ipv6Address: \"2001:db8::1\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsAaaaRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_AAAA_RECORD_TYPE,\n      ALL_PRIVATE_DNS_AAAA_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsAaaaRecordProps;\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: PrivateDnsAaaaRecordProps) {\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 PrivateDnsAaaaRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsAaaaRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        aaaaRecords: typedProps.records.map((r) => ({\n          ipv6Address: r.ipv6Address,\n        })),\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 Private DNS CNAME Record\n */\nexport interface PrivateDnsCnameRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * The canonical name for this CNAME record\n   * @example \"www.contoso.com\"\n   */\n  readonly cname: string;\n}\n\n/**\n * Azure Private DNS CNAME Record implementation\n *\n * CNAME records create an alias from one hostname to another.\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 PrivateDnsCnameRecord(this, \"alias-record\", {\n *   name: \"app\",\n *   privateDnsZoneId: zone.id,\n *   ttl: 3600,\n *   cname: \"www.internal.example.com\",\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsCnameRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_CNAME_RECORD_TYPE,\n      ALL_PRIVATE_DNS_CNAME_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsCnameRecordProps;\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: PrivateDnsCnameRecordProps) {\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 PrivateDnsCnameRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsCnameRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        cnameRecord: {\n          cname: typedProps.cname,\n        },\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 MxRecordEntry {\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 Private DNS MX Record\n */\nexport interface PrivateDnsMxRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of MX records with exchange and preference\n   */\n  readonly records: MxRecordEntry[];\n}\n\n/**\n * Azure Private 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 PrivateDnsMxRecord(this, \"mail-record\", {\n *   name: \"@\",\n *   privateDnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { preference: 10, exchange: \"mail1.internal.example.com\" },\n *     { preference: 20, exchange: \"mail2.internal.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsMxRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_MX_RECORD_TYPE,\n      ALL_PRIVATE_DNS_MX_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsMxRecordProps;\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: PrivateDnsMxRecordProps) {\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 PrivateDnsMxRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsMxRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        mxRecords: typedProps.records.map((r) => ({\n          preference: r.preference,\n          exchange: r.exchange,\n        })),\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 PtrRecordEntry {\n  /**\n   * The PTR target domain name\n   * @example \"server1.internal.example.com\"\n   */\n  readonly ptrdname: string;\n}\n\n/**\n * Properties for Private DNS PTR Record\n */\nexport interface PrivateDnsPtrRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of PTR records with ptrdname values\n   */\n  readonly records: PtrRecordEntry[];\n}\n\n/**\n * Azure Private 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 PrivateDnsPtrRecord(this, \"ptr-record\", {\n *   name: \"4.1.0.10.in-addr.arpa\",\n *   privateDnsZoneId: reverseZone.id,\n *   ttl: 3600,\n *   records: [\n *     { ptrdname: \"server1.internal.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsPtrRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_PTR_RECORD_TYPE,\n      ALL_PRIVATE_DNS_PTR_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsPtrRecordProps;\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: PrivateDnsPtrRecordProps) {\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 PrivateDnsPtrRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsPtrRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        ptrRecords: typedProps.records.map((r) => ({ ptrdname: r.ptrdname })),\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 SoaRecordConfig {\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 Private DNS SOA Record\n */\nexport interface PrivateDnsSoaRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * SOA record configuration\n   */\n  readonly soaRecord: SoaRecordConfig;\n}\n\n/**\n * Azure Private 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 PrivateDnsSoaRecord(this, \"soa-record\", {\n *   name: \"@\",\n *   privateDnsZoneId: 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 PrivateDnsSoaRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_SOA_RECORD_TYPE,\n      ALL_PRIVATE_DNS_SOA_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsSoaRecordProps;\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: PrivateDnsSoaRecordProps) {\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 PrivateDnsSoaRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsSoaRecordProps;\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 body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        soaRecord: soaRecord,\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 SrvRecordEntry {\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.internal.example.com\"\n   */\n  readonly target: string;\n}\n\n/**\n * Properties for Private DNS SRV Record\n */\nexport interface PrivateDnsSrvRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of SRV records with priority, weight, port, and target\n   */\n  readonly records: SrvRecordEntry[];\n}\n\n/**\n * Azure Private 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 PrivateDnsSrvRecord(this, \"sip-record\", {\n *   name: \"_sip._tcp\",\n *   privateDnsZoneId: zone.id,\n *   ttl: 3600,\n *   records: [\n *     { priority: 10, weight: 60, port: 5060, target: \"sipserver1.internal.example.com\" },\n *     { priority: 10, weight: 40, port: 5060, target: \"sipserver2.internal.example.com\" },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PrivateDnsSrvRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_SRV_RECORD_TYPE,\n      ALL_PRIVATE_DNS_SRV_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsSrvRecordProps;\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: PrivateDnsSrvRecordProps) {\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 PrivateDnsSrvRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsSrvRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\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\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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 TxtRecordEntry {\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 Private DNS TXT Record\n */\nexport interface PrivateDnsTxtRecordProps extends PrivateDnsRecordBaseProps {\n  /**\n   * Array of TXT records with string values\n   */\n  readonly records: TxtRecordEntry[];\n}\n\n/**\n * Azure Private DNS TXT Record implementation\n *\n * TXT records store arbitrary text data, commonly used for SPF, DKIM, etc.\n *\n * @example\n * // Create a TXT record for SPF:\n * const txtRecord = new PrivateDnsTxtRecord(this, \"spf-record\", {\n *   name: \"@\",\n *   privateDnsZoneId: 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 PrivateDnsTxtRecord extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      PRIVATE_DNS_TXT_RECORD_TYPE,\n      ALL_PRIVATE_DNS_TXT_RECORD_VERSIONS,\n    );\n  }\n\n  public readonly props: PrivateDnsTxtRecordProps;\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: PrivateDnsTxtRecordProps) {\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 PrivateDnsTxtRecordProps;\n    return typedProps.privateDnsZoneId;\n  }\n\n  protected defaultVersion(): string {\n    return \"2024-06-01\";\n  }\n\n  protected resourceType(): string {\n    return PRIVATE_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 PrivateDnsTxtRecordProps;\n    const body: { [key: string]: object } = {\n      properties: {\n        ttl: typedProps.ttl ?? 3600,\n        txtRecords: typedProps.records.map((r) => ({ value: r.value })),\n      },\n    };\n\n    if (typedProps.metadata && Object.keys(typedProps.metadata).length > 0) {\n      (body.properties as { [key: string]: unknown }).metadata =\n        typedProps.metadata;\n    }\n\n    return body;\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"]}