@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.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 +54846 -26661
- package/API.md +72091 -23784
- package/lib/azure-actiongroup/index.d.ts +0 -10
- package/lib/azure-actiongroup/index.js +1 -11
- package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
- package/lib/azure-actiongroup/lib/action-group.js +6 -32
- package/lib/azure-actiongroup/lib/index.d.ts +1 -4
- package/lib/azure-actiongroup/lib/index.js +2 -5
- package/lib/azure-activitylogalert/index.d.ts +0 -10
- package/lib/azure-activitylogalert/index.js +1 -11
- package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
- package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
- package/lib/azure-activitylogalert/lib/index.js +2 -5
- package/lib/azure-aks/index.d.ts +0 -8
- package/lib/azure-aks/index.js +1 -11
- package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
- package/lib/azure-aks/lib/aks-cluster.js +13 -36
- package/lib/azure-aks/lib/index.d.ts +1 -10
- package/lib/azure-aks/lib/index.js +2 -21
- package/lib/azure-diagnosticsettings/index.d.ts +0 -6
- package/lib/azure-diagnosticsettings/index.js +1 -7
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
- package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
- package/lib/azure-diagnosticsettings/lib/index.js +2 -8
- package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
- package/lib/azure-dnsforwardingruleset/index.js +18 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
- package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
- package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
- package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
- package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
- package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
- package/lib/azure-dnsresolver/index.d.ts +1 -0
- package/lib/azure-dnsresolver/index.js +18 -0
- package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
- package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
- package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
- package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
- package/lib/azure-dnsresolver/lib/index.js +23 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
- package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
- package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
- package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
- package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
- package/lib/azure-dnszone/index.d.ts +1 -0
- package/lib/azure-dnszone/index.js +18 -0
- package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
- package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
- package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
- package/lib/azure-dnszone/lib/dns-zone.js +228 -0
- package/lib/azure-dnszone/lib/index.d.ts +2 -0
- package/lib/azure-dnszone/lib/index.js +19 -0
- package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
- package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
- package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
- package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
- package/lib/azure-metricalert/index.d.ts +0 -10
- package/lib/azure-metricalert/index.js +1 -11
- package/lib/azure-metricalert/lib/index.d.ts +1 -4
- package/lib/azure-metricalert/lib/index.js +2 -5
- package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
- package/lib/azure-metricalert/lib/metric-alert.js +6 -32
- package/lib/azure-networkinterface/index.d.ts +0 -3
- package/lib/azure-networkinterface/index.js +1 -4
- package/lib/azure-networkinterface/lib/index.d.ts +1 -5
- package/lib/azure-networkinterface/lib/index.js +2 -5
- package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
- package/lib/azure-networkinterface/lib/network-interface.js +14 -29
- package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
- package/lib/azure-networksecuritygroup/index.d.ts +0 -5
- package/lib/azure-networksecuritygroup/index.js +1 -6
- package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
- package/lib/azure-networksecuritygroup/lib/index.js +17 -14
- package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
- package/lib/azure-policyassignment/index.d.ts +1 -0
- package/lib/azure-policyassignment/index.js +18 -0
- package/lib/azure-policyassignment/lib/index.d.ts +2 -0
- package/lib/azure-policyassignment/lib/index.js +19 -0
- package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
- package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
- package/lib/azure-policyassignment/lib/policy-assignment.d.ts +342 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +228 -0
- package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
- package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
- package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
- package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
- package/lib/azure-policydefinition/index.d.ts +1 -0
- package/lib/azure-policydefinition/index.js +18 -0
- package/lib/azure-policydefinition/lib/index.d.ts +2 -0
- package/lib/azure-policydefinition/lib/index.js +19 -0
- package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
- package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
- package/lib/azure-policydefinition/lib/policy-definition.d.ts +260 -0
- package/lib/azure-policydefinition/lib/policy-definition.js +199 -0
- package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
- package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
- package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
- package/lib/azure-policydefinition/test/policy-definition.spec.js +596 -0
- package/lib/azure-privatednszone/index.d.ts +1 -0
- package/lib/azure-privatednszone/index.js +18 -0
- package/lib/azure-privatednszone/lib/index.d.ts +2 -0
- package/lib/azure-privatednszone/lib/index.js +19 -0
- package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
- package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
- package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
- package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
- package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
- package/lib/azure-privatednszonelink/index.d.ts +1 -0
- package/lib/azure-privatednszonelink/index.js +18 -0
- package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
- package/lib/azure-privatednszonelink/lib/index.js +19 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
- package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
- package/lib/azure-publicipaddress/index.d.ts +0 -5
- package/lib/azure-publicipaddress/index.js +1 -6
- package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
- package/lib/azure-publicipaddress/lib/index.js +17 -17
- package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
- package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
- package/lib/azure-resourcegroup/index.d.ts +0 -37
- package/lib/azure-resourcegroup/index.js +1 -39
- package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
- package/lib/azure-resourcegroup/lib/index.js +2 -43
- package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
- package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
- package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
- package/lib/azure-roleassignment/index.d.ts +1 -0
- package/lib/azure-roleassignment/index.js +18 -0
- package/lib/azure-roleassignment/lib/index.d.ts +2 -0
- package/lib/azure-roleassignment/lib/index.js +19 -0
- package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
- package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
- package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
- package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
- package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
- package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
- package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
- package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
- package/lib/azure-roledefinition/index.d.ts +1 -0
- package/lib/azure-roledefinition/index.js +18 -0
- package/lib/azure-roledefinition/lib/index.d.ts +2 -0
- package/lib/azure-roledefinition/lib/index.js +19 -0
- package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
- package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
- package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
- package/lib/azure-roledefinition/lib/role-definition.js +192 -0
- package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
- package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
- package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
- package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
- package/lib/azure-storageaccount/index.d.ts +0 -19
- package/lib/azure-storageaccount/index.js +1 -20
- package/lib/azure-storageaccount/lib/index.d.ts +1 -7
- package/lib/azure-storageaccount/lib/index.js +2 -8
- package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
- package/lib/azure-storageaccount/lib/storage-account.js +15 -29
- package/lib/azure-subnet/index.d.ts +0 -3
- package/lib/azure-subnet/index.js +1 -4
- package/lib/azure-subnet/lib/index.d.ts +1 -4
- package/lib/azure-subnet/lib/index.js +2 -5
- package/lib/azure-subnet/lib/subnet.d.ts +3 -14
- package/lib/azure-subnet/lib/subnet.js +28 -47
- package/lib/azure-subnet/test/subnet.integ.js +19 -7
- package/lib/azure-subnet/test/subnet.spec.js +1 -2
- package/lib/azure-virtualmachine/index.d.ts +0 -6
- package/lib/azure-virtualmachine/index.js +1 -7
- package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
- package/lib/azure-virtualmachine/lib/index.js +2 -21
- package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
- package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
- package/lib/azure-virtualnetwork/index.d.ts +0 -9
- package/lib/azure-virtualnetwork/index.js +1 -11
- package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
- package/lib/azure-virtualnetwork/lib/index.js +17 -20
- package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
- package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
- package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
- package/lib/azure-virtualnetworkmanager/index.js +18 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
- package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
- package/lib/azure-vmss/index.d.ts +0 -5
- package/lib/azure-vmss/index.js +1 -6
- package/lib/azure-vmss/lib/index.d.ts +0 -7
- package/lib/azure-vmss/lib/index.js +1 -21
- package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
- package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
- package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
- package/lib/core-azure/lib/azapi/azapi-resource.d.ts +178 -26
- package/lib/core-azure/lib/azapi/azapi-resource.js +328 -90
- package/lib/core-azure/lib/azapi/azapi-resource.spec.js +2 -2
- 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 +5 -3
- 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/resource-schema-validator.d.ts +118 -0
- package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
- package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
- package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
- package/lib/core-azure/lib/index.d.ts +2 -2
- package/lib/core-azure/lib/index.js +5 -5
- 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 +19 -0
- package/lib/index.js +21 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.d.ts +1 -0
- package/lib/testing/lib/cleanup.js +19 -12
- package/lib/testing/lib/metadata.js +19 -16
- package/package.json +1 -1
- package/scripts/cleanup-test-resources.ts +22 -4
- package/scripts/generate-index.js +25 -8
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* API schemas for Azure DNS Zone across all supported versions
|
|
4
|
+
*
|
|
5
|
+
* This file defines the complete API schemas for Microsoft.Network/dnsZones
|
|
6
|
+
* across all supported API versions. The schemas are used by the VersionedAzapiResource
|
|
7
|
+
* framework for validation, transformation, and version management.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.DNS_ZONE_TYPE = exports.ALL_DNS_ZONE_VERSIONS = exports.DNS_ZONE_VERSION_2018_05_01 = exports.DNS_ZONE_SCHEMA_2018_05_01 = void 0;
|
|
11
|
+
const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
|
|
12
|
+
// =============================================================================
|
|
13
|
+
// COMMON PROPERTY DEFINITIONS
|
|
14
|
+
// =============================================================================
|
|
15
|
+
/**
|
|
16
|
+
* Common property definitions shared across all DNS Zone versions
|
|
17
|
+
*/
|
|
18
|
+
const COMMON_PROPERTIES = {
|
|
19
|
+
location: {
|
|
20
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
21
|
+
required: true,
|
|
22
|
+
defaultValue: "global",
|
|
23
|
+
description: "The Azure region where the DNS Zone will be created. DNS Zones are global resources, so this is typically 'global'",
|
|
24
|
+
validation: [
|
|
25
|
+
{
|
|
26
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
27
|
+
message: "Location is required for DNS Zones",
|
|
28
|
+
},
|
|
29
|
+
],
|
|
30
|
+
},
|
|
31
|
+
tags: {
|
|
32
|
+
dataType: version_interfaces_1.PropertyType.OBJECT,
|
|
33
|
+
required: false,
|
|
34
|
+
defaultValue: {},
|
|
35
|
+
description: "A dictionary of tags to apply to the DNS Zone for organizational, billing, or other purposes",
|
|
36
|
+
validation: [
|
|
37
|
+
{
|
|
38
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
39
|
+
value: version_interfaces_1.PropertyType.OBJECT,
|
|
40
|
+
message: "Tags must be an object with string key-value pairs",
|
|
41
|
+
},
|
|
42
|
+
],
|
|
43
|
+
},
|
|
44
|
+
name: {
|
|
45
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
46
|
+
required: true,
|
|
47
|
+
description: "The name of the DNS Zone (without a terminating dot). Must be a valid domain name",
|
|
48
|
+
validation: [
|
|
49
|
+
{
|
|
50
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
51
|
+
message: "DNS Zone name is required",
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
55
|
+
value: "^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)*$",
|
|
56
|
+
message: "DNS Zone name must be a valid domain name without terminating dot",
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
|
|
60
|
+
value: { minLength: 1, maxLength: 253 },
|
|
61
|
+
message: "DNS Zone name must be between 1 and 253 characters",
|
|
62
|
+
},
|
|
63
|
+
],
|
|
64
|
+
},
|
|
65
|
+
zoneType: {
|
|
66
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
67
|
+
required: false,
|
|
68
|
+
defaultValue: "Public",
|
|
69
|
+
description: "The type of this DNS zone (Public or Private). Public zones are Internet-accessible",
|
|
70
|
+
validation: [
|
|
71
|
+
{
|
|
72
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
73
|
+
value: "^(Public|Private)$",
|
|
74
|
+
message: "Zone type must be either 'Public' or 'Private'",
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
registrationVirtualNetworks: {
|
|
79
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
80
|
+
required: false,
|
|
81
|
+
description: "A list of references to virtual networks that register hostnames in this DNS zone. Only valid when zoneType is Private",
|
|
82
|
+
validation: [
|
|
83
|
+
{
|
|
84
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
85
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
86
|
+
message: "RegistrationVirtualNetworks must be an array of virtual network references",
|
|
87
|
+
},
|
|
88
|
+
],
|
|
89
|
+
},
|
|
90
|
+
resolutionVirtualNetworks: {
|
|
91
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
92
|
+
required: false,
|
|
93
|
+
description: "A list of references to virtual networks that resolve records in this DNS zone. Only valid when zoneType is Private",
|
|
94
|
+
validation: [
|
|
95
|
+
{
|
|
96
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
97
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
98
|
+
message: "ResolutionVirtualNetworks must be an array of virtual network references",
|
|
99
|
+
},
|
|
100
|
+
],
|
|
101
|
+
},
|
|
102
|
+
ignoreChanges: {
|
|
103
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
104
|
+
required: false,
|
|
105
|
+
description: "Array of property names to ignore during updates",
|
|
106
|
+
validation: [
|
|
107
|
+
{
|
|
108
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
109
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
110
|
+
message: "IgnoreChanges must be an array of strings",
|
|
111
|
+
},
|
|
112
|
+
],
|
|
113
|
+
},
|
|
114
|
+
};
|
|
115
|
+
// =============================================================================
|
|
116
|
+
// VERSION-SPECIFIC SCHEMAS
|
|
117
|
+
// =============================================================================
|
|
118
|
+
/**
|
|
119
|
+
* API Schema for DNS Zone version 2018-05-01
|
|
120
|
+
*/
|
|
121
|
+
exports.DNS_ZONE_SCHEMA_2018_05_01 = {
|
|
122
|
+
resourceType: "Microsoft.Network/dnsZones",
|
|
123
|
+
version: "2018-05-01",
|
|
124
|
+
properties: {
|
|
125
|
+
...COMMON_PROPERTIES,
|
|
126
|
+
},
|
|
127
|
+
required: ["location", "name"],
|
|
128
|
+
optional: [
|
|
129
|
+
"tags",
|
|
130
|
+
"zoneType",
|
|
131
|
+
"registrationVirtualNetworks",
|
|
132
|
+
"resolutionVirtualNetworks",
|
|
133
|
+
"ignoreChanges",
|
|
134
|
+
],
|
|
135
|
+
deprecated: [],
|
|
136
|
+
transformationRules: {},
|
|
137
|
+
validationRules: [
|
|
138
|
+
{
|
|
139
|
+
property: "location",
|
|
140
|
+
rules: [
|
|
141
|
+
{
|
|
142
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
143
|
+
message: "Location is required for DNS Zones",
|
|
144
|
+
},
|
|
145
|
+
],
|
|
146
|
+
},
|
|
147
|
+
{
|
|
148
|
+
property: "name",
|
|
149
|
+
rules: [
|
|
150
|
+
{
|
|
151
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
152
|
+
message: "Name is required for DNS Zones",
|
|
153
|
+
},
|
|
154
|
+
],
|
|
155
|
+
},
|
|
156
|
+
],
|
|
157
|
+
};
|
|
158
|
+
// =============================================================================
|
|
159
|
+
// VERSION CONFIGURATIONS
|
|
160
|
+
// =============================================================================
|
|
161
|
+
/**
|
|
162
|
+
* Version configuration for DNS Zone 2018-05-01
|
|
163
|
+
*/
|
|
164
|
+
exports.DNS_ZONE_VERSION_2018_05_01 = {
|
|
165
|
+
version: "2018-05-01",
|
|
166
|
+
schema: exports.DNS_ZONE_SCHEMA_2018_05_01,
|
|
167
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
168
|
+
releaseDate: "2018-05-01",
|
|
169
|
+
deprecationDate: undefined,
|
|
170
|
+
sunsetDate: undefined,
|
|
171
|
+
breakingChanges: [],
|
|
172
|
+
migrationGuide: "/docs/dns-zone/migration-2018-05-01",
|
|
173
|
+
changeLog: [
|
|
174
|
+
{
|
|
175
|
+
changeType: "added",
|
|
176
|
+
description: "Stable release of DNS Zone API with support for public and private DNS zones",
|
|
177
|
+
breaking: false,
|
|
178
|
+
},
|
|
179
|
+
],
|
|
180
|
+
};
|
|
181
|
+
/**
|
|
182
|
+
* All supported DNS Zone versions for registration
|
|
183
|
+
*/
|
|
184
|
+
exports.ALL_DNS_ZONE_VERSIONS = [
|
|
185
|
+
exports.DNS_ZONE_VERSION_2018_05_01,
|
|
186
|
+
];
|
|
187
|
+
/**
|
|
188
|
+
* Resource type constant
|
|
189
|
+
*/
|
|
190
|
+
exports.DNS_ZONE_TYPE = "Microsoft.Network/dnsZones";
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-zone-schemas.js","sourceRoot":"","sources":["../../../src/azure-dnszone/lib/dns-zone-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure DNS Zone across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/dnsZones\n * across all supported API versions. The schemas are used by the VersionedAzapiResource\n * framework for validation, transformation, and version management.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all DNS Zone versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  location: {\n    dataType: PropertyType.STRING,\n    required: true,\n    defaultValue: \"global\",\n    description:\n      \"The Azure region where the DNS Zone will be created. DNS Zones are global resources, so this is typically 'global'\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Location is required for DNS Zones\",\n      },\n    ],\n  },\n  tags: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description:\n      \"A dictionary of tags to apply to the DNS Zone for organizational, billing, or other purposes\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Tags must be an object with string key-value pairs\",\n      },\n    ],\n  },\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The name of the DNS Zone (without a terminating dot). Must be a valid domain name\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"DNS Zone name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value:\n          \"^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\\\\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)*$\",\n        message:\n          \"DNS Zone name must be a valid domain name without terminating dot\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 253 },\n        message: \"DNS Zone name must be between 1 and 253 characters\",\n      },\n    ],\n  },\n  zoneType: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Public\",\n    description:\n      \"The type of this DNS zone (Public or Private). Public zones are Internet-accessible\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^(Public|Private)$\",\n        message: \"Zone type must be either 'Public' or 'Private'\",\n      },\n    ],\n  },\n  registrationVirtualNetworks: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"A list of references to virtual networks that register hostnames in this DNS zone. Only valid when zoneType is Private\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message:\n          \"RegistrationVirtualNetworks must be an array of virtual network references\",\n      },\n    ],\n  },\n  resolutionVirtualNetworks: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"A list of references to virtual networks that resolve records in this DNS zone. Only valid when zoneType is Private\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message:\n          \"ResolutionVirtualNetworks must be an array of virtual network references\",\n      },\n    ],\n  },\n  ignoreChanges: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description: \"Array of property names to ignore during updates\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"IgnoreChanges must be an array of strings\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for DNS Zone version 2018-05-01\n */\nexport const DNS_ZONE_SCHEMA_2018_05_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/dnsZones\",\n  version: \"2018-05-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"location\", \"name\"],\n  optional: [\n    \"tags\",\n    \"zoneType\",\n    \"registrationVirtualNetworks\",\n    \"resolutionVirtualNetworks\",\n    \"ignoreChanges\",\n  ],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"location\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Location is required for DNS Zones\",\n        },\n      ],\n    },\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for DNS Zones\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for DNS Zone 2018-05-01\n */\nexport const DNS_ZONE_VERSION_2018_05_01: VersionConfig = {\n  version: \"2018-05-01\",\n  schema: DNS_ZONE_SCHEMA_2018_05_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2018-05-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/dns-zone/migration-2018-05-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of DNS Zone API with support for public and private DNS zones\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported DNS Zone versions for registration\n */\nexport const ALL_DNS_ZONE_VERSIONS: VersionConfig[] = [\n  DNS_ZONE_VERSION_2018_05_01,\n];\n\n/**\n * Resource type constant\n */\nexport const DNS_ZONE_TYPE = \"Microsoft.Network/dnsZones\";\n"]}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Azure DNS Zone implementation using VersionedAzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a single, version-aware implementation that automatically handles
|
|
5
|
+
* version management, schema validation, and property transformation across all
|
|
6
|
+
* supported API versions.
|
|
7
|
+
*
|
|
8
|
+
* Supported API Versions:
|
|
9
|
+
* - 2018-05-01 (Active, Latest)
|
|
10
|
+
*
|
|
11
|
+
* Features:
|
|
12
|
+
* - Automatic latest version resolution when no version is specified
|
|
13
|
+
* - Explicit version pinning for stability requirements
|
|
14
|
+
* - Schema-driven validation and transformation
|
|
15
|
+
* - Full backward compatibility with existing interface
|
|
16
|
+
* - JSII compliance for multi-language support
|
|
17
|
+
* - Support for both Public and Private DNS zones
|
|
18
|
+
*/
|
|
19
|
+
import * as cdktf from "cdktf";
|
|
20
|
+
import { Construct } from "constructs";
|
|
21
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
22
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
23
|
+
/**
|
|
24
|
+
* Virtual network reference for private DNS zones
|
|
25
|
+
*/
|
|
26
|
+
export interface VirtualNetworkReference {
|
|
27
|
+
/**
|
|
28
|
+
* The resource ID of the virtual network
|
|
29
|
+
*/
|
|
30
|
+
readonly id: string;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Properties for the unified Azure DNS Zone
|
|
34
|
+
*
|
|
35
|
+
* Extends AzapiResourceProps with DNS Zone specific properties
|
|
36
|
+
*/
|
|
37
|
+
export interface DnsZoneProps extends AzapiResourceProps {
|
|
38
|
+
/**
|
|
39
|
+
* The type of this DNS zone (Public or Private)
|
|
40
|
+
* @default "Public"
|
|
41
|
+
*/
|
|
42
|
+
readonly zoneType?: "Public" | "Private";
|
|
43
|
+
/**
|
|
44
|
+
* A list of references to virtual networks that register hostnames in this DNS zone
|
|
45
|
+
* Only valid when zoneType is Private
|
|
46
|
+
*/
|
|
47
|
+
readonly registrationVirtualNetworks?: VirtualNetworkReference[];
|
|
48
|
+
/**
|
|
49
|
+
* A list of references to virtual networks that resolve records in this DNS zone
|
|
50
|
+
* Only valid when zoneType is Private
|
|
51
|
+
*/
|
|
52
|
+
readonly resolutionVirtualNetworks?: VirtualNetworkReference[];
|
|
53
|
+
/**
|
|
54
|
+
* The lifecycle rules to ignore changes
|
|
55
|
+
* @example ["tags"]
|
|
56
|
+
*/
|
|
57
|
+
readonly ignoreChanges?: string[];
|
|
58
|
+
/**
|
|
59
|
+
* Resource group ID where the DNS Zone will be created
|
|
60
|
+
*/
|
|
61
|
+
readonly resourceGroupId?: string;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* The resource body interface for Azure DNS Zone API calls
|
|
65
|
+
* This matches the Azure REST API schema
|
|
66
|
+
*/
|
|
67
|
+
export interface DnsZoneBody {
|
|
68
|
+
readonly location: string;
|
|
69
|
+
readonly tags?: {
|
|
70
|
+
[key: string]: string;
|
|
71
|
+
};
|
|
72
|
+
readonly properties?: {
|
|
73
|
+
[key: string]: any;
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Unified Azure DNS Zone implementation
|
|
78
|
+
*
|
|
79
|
+
* This class provides a single, version-aware implementation that replaces all
|
|
80
|
+
* version-specific DNS Zone classes. It automatically handles version
|
|
81
|
+
* resolution, schema validation, and property transformation while maintaining
|
|
82
|
+
* full backward compatibility.
|
|
83
|
+
*
|
|
84
|
+
* Azure DNS Zones are global resources used to host DNS records for a domain.
|
|
85
|
+
* They can be either Public (Internet-accessible) or Private (accessible only
|
|
86
|
+
* from specified virtual networks).
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* // Basic public DNS zone with automatic version resolution:
|
|
90
|
+
* const dnsZone = new DnsZone(this, "dns", {
|
|
91
|
+
* name: "contoso.com",
|
|
92
|
+
* location: "global",
|
|
93
|
+
* resourceGroupId: resourceGroup.id,
|
|
94
|
+
* });
|
|
95
|
+
*
|
|
96
|
+
* @example
|
|
97
|
+
* // Private DNS zone with virtual network links:
|
|
98
|
+
* const privateDnsZone = new DnsZone(this, "privateDns", {
|
|
99
|
+
* name: "internal.contoso.com",
|
|
100
|
+
* location: "global",
|
|
101
|
+
* resourceGroupId: resourceGroup.id,
|
|
102
|
+
* zoneType: "Private",
|
|
103
|
+
* registrationVirtualNetworks: [{ id: vnet.id }],
|
|
104
|
+
* tags: { environment: "production" }
|
|
105
|
+
* });
|
|
106
|
+
*
|
|
107
|
+
* @example
|
|
108
|
+
* // DNS zone with explicit version pinning:
|
|
109
|
+
* const dnsZone = new DnsZone(this, "dns", {
|
|
110
|
+
* name: "contoso.com",
|
|
111
|
+
* location: "global",
|
|
112
|
+
* resourceGroupId: resourceGroup.id,
|
|
113
|
+
* apiVersion: "2018-05-01",
|
|
114
|
+
* });
|
|
115
|
+
*
|
|
116
|
+
* @stability stable
|
|
117
|
+
*/
|
|
118
|
+
export declare class DnsZone extends AzapiResource {
|
|
119
|
+
readonly props: DnsZoneProps;
|
|
120
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
121
|
+
readonly locationOutput: cdktf.TerraformOutput;
|
|
122
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
123
|
+
readonly tagsOutput: cdktf.TerraformOutput;
|
|
124
|
+
readonly nameServersOutput: cdktf.TerraformOutput;
|
|
125
|
+
/**
|
|
126
|
+
* Creates a new Azure DNS Zone using the VersionedAzapiResource framework
|
|
127
|
+
*
|
|
128
|
+
* @param scope - The scope in which to define this construct
|
|
129
|
+
* @param id - The unique identifier for this instance
|
|
130
|
+
* @param props - Configuration properties for the DNS Zone
|
|
131
|
+
*/
|
|
132
|
+
constructor(scope: Construct, id: string, props: DnsZoneProps);
|
|
133
|
+
/**
|
|
134
|
+
* Gets the default API version to use when no explicit version is specified
|
|
135
|
+
*/
|
|
136
|
+
protected defaultVersion(): string;
|
|
137
|
+
/**
|
|
138
|
+
* Gets the Azure resource type for DNS Zones
|
|
139
|
+
*/
|
|
140
|
+
protected resourceType(): string;
|
|
141
|
+
/**
|
|
142
|
+
* Gets the API schema for the resolved version
|
|
143
|
+
*/
|
|
144
|
+
protected apiSchema(): ApiSchema;
|
|
145
|
+
/**
|
|
146
|
+
* Provides default location for DNS Zones (global resource)
|
|
147
|
+
*/
|
|
148
|
+
protected defaultLocation(): string;
|
|
149
|
+
/**
|
|
150
|
+
* Creates the resource body for the Azure API call
|
|
151
|
+
*/
|
|
152
|
+
protected createResourceBody(props: any): any;
|
|
153
|
+
/**
|
|
154
|
+
* Get the name servers for the DNS Zone
|
|
155
|
+
* These are the Azure DNS name servers that should be configured at your domain registrar
|
|
156
|
+
*/
|
|
157
|
+
get nameServers(): string;
|
|
158
|
+
/**
|
|
159
|
+
* Get the maximum number of record sets that can be created in this DNS zone
|
|
160
|
+
*/
|
|
161
|
+
get maxNumberOfRecordSets(): string;
|
|
162
|
+
/**
|
|
163
|
+
* Get the current number of record sets in this DNS zone
|
|
164
|
+
*/
|
|
165
|
+
get numberOfRecordSets(): string;
|
|
166
|
+
/**
|
|
167
|
+
* Get the zone type (Public or Private)
|
|
168
|
+
*/
|
|
169
|
+
get zoneType(): string;
|
|
170
|
+
/**
|
|
171
|
+
* Add a tag to the DNS Zone
|
|
172
|
+
*/
|
|
173
|
+
addTag(key: string, value: string): void;
|
|
174
|
+
/**
|
|
175
|
+
* Remove a tag from the DNS Zone
|
|
176
|
+
*/
|
|
177
|
+
removeTag(key: string): void;
|
|
178
|
+
/**
|
|
179
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
180
|
+
*/
|
|
181
|
+
private _applyIgnoreChanges;
|
|
182
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.DnsZone = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure DNS Zone implementation using VersionedAzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a single, version-aware implementation that automatically handles
|
|
10
|
+
* version management, schema validation, and property transformation across all
|
|
11
|
+
* supported API versions.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2018-05-01 (Active, Latest)
|
|
15
|
+
*
|
|
16
|
+
* Features:
|
|
17
|
+
* - Automatic latest version resolution when no version is specified
|
|
18
|
+
* - Explicit version pinning for stability requirements
|
|
19
|
+
* - Schema-driven validation and transformation
|
|
20
|
+
* - Full backward compatibility with existing interface
|
|
21
|
+
* - JSII compliance for multi-language support
|
|
22
|
+
* - Support for both Public and Private DNS zones
|
|
23
|
+
*/
|
|
24
|
+
const cdktf = require("cdktf");
|
|
25
|
+
const dns_zone_schemas_1 = require("./dns-zone-schemas");
|
|
26
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
27
|
+
/**
|
|
28
|
+
* Unified Azure DNS Zone implementation
|
|
29
|
+
*
|
|
30
|
+
* This class provides a single, version-aware implementation that replaces all
|
|
31
|
+
* version-specific DNS Zone classes. It automatically handles version
|
|
32
|
+
* resolution, schema validation, and property transformation while maintaining
|
|
33
|
+
* full backward compatibility.
|
|
34
|
+
*
|
|
35
|
+
* Azure DNS Zones are global resources used to host DNS records for a domain.
|
|
36
|
+
* They can be either Public (Internet-accessible) or Private (accessible only
|
|
37
|
+
* from specified virtual networks).
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* // Basic public DNS zone with automatic version resolution:
|
|
41
|
+
* const dnsZone = new DnsZone(this, "dns", {
|
|
42
|
+
* name: "contoso.com",
|
|
43
|
+
* location: "global",
|
|
44
|
+
* resourceGroupId: resourceGroup.id,
|
|
45
|
+
* });
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* // Private DNS zone with virtual network links:
|
|
49
|
+
* const privateDnsZone = new DnsZone(this, "privateDns", {
|
|
50
|
+
* name: "internal.contoso.com",
|
|
51
|
+
* location: "global",
|
|
52
|
+
* resourceGroupId: resourceGroup.id,
|
|
53
|
+
* zoneType: "Private",
|
|
54
|
+
* registrationVirtualNetworks: [{ id: vnet.id }],
|
|
55
|
+
* tags: { environment: "production" }
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* // DNS zone with explicit version pinning:
|
|
60
|
+
* const dnsZone = new DnsZone(this, "dns", {
|
|
61
|
+
* name: "contoso.com",
|
|
62
|
+
* location: "global",
|
|
63
|
+
* resourceGroupId: resourceGroup.id,
|
|
64
|
+
* apiVersion: "2018-05-01",
|
|
65
|
+
* });
|
|
66
|
+
*
|
|
67
|
+
* @stability stable
|
|
68
|
+
*/
|
|
69
|
+
class DnsZone extends azapi_resource_1.AzapiResource {
|
|
70
|
+
// Public properties
|
|
71
|
+
/**
|
|
72
|
+
* Creates a new Azure DNS Zone using the VersionedAzapiResource framework
|
|
73
|
+
*
|
|
74
|
+
* @param scope - The scope in which to define this construct
|
|
75
|
+
* @param id - The unique identifier for this instance
|
|
76
|
+
* @param props - Configuration properties for the DNS Zone
|
|
77
|
+
*/
|
|
78
|
+
constructor(scope, id, props) {
|
|
79
|
+
super(scope, id, props);
|
|
80
|
+
this.props = props;
|
|
81
|
+
// Extract properties from the AZAPI resource outputs
|
|
82
|
+
// Create Terraform outputs
|
|
83
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
84
|
+
value: this.id,
|
|
85
|
+
description: "The ID of the DNS Zone",
|
|
86
|
+
});
|
|
87
|
+
this.locationOutput = new cdktf.TerraformOutput(this, "location", {
|
|
88
|
+
value: `\${${this.terraformResource.fqn}.location}`,
|
|
89
|
+
description: "The location of the DNS Zone",
|
|
90
|
+
});
|
|
91
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
92
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
93
|
+
description: "The name of the DNS Zone",
|
|
94
|
+
});
|
|
95
|
+
this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
|
|
96
|
+
value: `\${${this.terraformResource.fqn}.tags}`,
|
|
97
|
+
description: "The tags assigned to the DNS Zone",
|
|
98
|
+
});
|
|
99
|
+
this.nameServersOutput = new cdktf.TerraformOutput(this, "name_servers", {
|
|
100
|
+
value: `\${${this.terraformResource.fqn}.output.properties.nameServers}`,
|
|
101
|
+
description: "The name servers for the DNS Zone",
|
|
102
|
+
});
|
|
103
|
+
// Override logical IDs
|
|
104
|
+
this.idOutput.overrideLogicalId("id");
|
|
105
|
+
this.locationOutput.overrideLogicalId("location");
|
|
106
|
+
this.nameOutput.overrideLogicalId("name");
|
|
107
|
+
this.tagsOutput.overrideLogicalId("tags");
|
|
108
|
+
this.nameServersOutput.overrideLogicalId("name_servers");
|
|
109
|
+
// Apply ignore changes if specified
|
|
110
|
+
this._applyIgnoreChanges();
|
|
111
|
+
}
|
|
112
|
+
// =============================================================================
|
|
113
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
114
|
+
// =============================================================================
|
|
115
|
+
/**
|
|
116
|
+
* Gets the default API version to use when no explicit version is specified
|
|
117
|
+
*/
|
|
118
|
+
defaultVersion() {
|
|
119
|
+
return "2018-05-01";
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Gets the Azure resource type for DNS Zones
|
|
123
|
+
*/
|
|
124
|
+
resourceType() {
|
|
125
|
+
return dns_zone_schemas_1.DNS_ZONE_TYPE;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Gets the API schema for the resolved version
|
|
129
|
+
*/
|
|
130
|
+
apiSchema() {
|
|
131
|
+
return this.resolveSchema();
|
|
132
|
+
}
|
|
133
|
+
/**
|
|
134
|
+
* Provides default location for DNS Zones (global resource)
|
|
135
|
+
*/
|
|
136
|
+
defaultLocation() {
|
|
137
|
+
return "global";
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Creates the resource body for the Azure API call
|
|
141
|
+
*/
|
|
142
|
+
createResourceBody(props) {
|
|
143
|
+
const typedProps = props;
|
|
144
|
+
const body = {
|
|
145
|
+
location: this.location,
|
|
146
|
+
// Tags are passed separately to createAzapiResource() for proper idempotency
|
|
147
|
+
// Do not include tags in the body
|
|
148
|
+
};
|
|
149
|
+
// Add properties object if zone type or virtual networks are specified
|
|
150
|
+
if (typedProps.zoneType ||
|
|
151
|
+
typedProps.registrationVirtualNetworks ||
|
|
152
|
+
typedProps.resolutionVirtualNetworks) {
|
|
153
|
+
body.properties = {
|
|
154
|
+
zoneType: typedProps.zoneType || "Public",
|
|
155
|
+
registrationVirtualNetworks: typedProps.registrationVirtualNetworks,
|
|
156
|
+
resolutionVirtualNetworks: typedProps.resolutionVirtualNetworks,
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
return body;
|
|
160
|
+
}
|
|
161
|
+
// =============================================================================
|
|
162
|
+
// PUBLIC METHODS FOR DNS ZONE OPERATIONS
|
|
163
|
+
// =============================================================================
|
|
164
|
+
/**
|
|
165
|
+
* Get the name servers for the DNS Zone
|
|
166
|
+
* These are the Azure DNS name servers that should be configured at your domain registrar
|
|
167
|
+
*/
|
|
168
|
+
get nameServers() {
|
|
169
|
+
return `\${${this.terraformResource.fqn}.output.properties.nameServers}`;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Get the maximum number of record sets that can be created in this DNS zone
|
|
173
|
+
*/
|
|
174
|
+
get maxNumberOfRecordSets() {
|
|
175
|
+
return `\${${this.terraformResource.fqn}.output.properties.maxNumberOfRecordSets}`;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Get the current number of record sets in this DNS zone
|
|
179
|
+
*/
|
|
180
|
+
get numberOfRecordSets() {
|
|
181
|
+
return `\${${this.terraformResource.fqn}.output.properties.numberOfRecordSets}`;
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Get the zone type (Public or Private)
|
|
185
|
+
*/
|
|
186
|
+
get zoneType() {
|
|
187
|
+
return this.props.zoneType || "Public";
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Add a tag to the DNS Zone
|
|
191
|
+
*/
|
|
192
|
+
addTag(key, value) {
|
|
193
|
+
if (!this.props.tags) {
|
|
194
|
+
this.props.tags = {};
|
|
195
|
+
}
|
|
196
|
+
this.props.tags[key] = value;
|
|
197
|
+
}
|
|
198
|
+
/**
|
|
199
|
+
* Remove a tag from the DNS Zone
|
|
200
|
+
*/
|
|
201
|
+
removeTag(key) {
|
|
202
|
+
if (this.props.tags && this.props.tags[key]) {
|
|
203
|
+
delete this.props.tags[key];
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
// =============================================================================
|
|
207
|
+
// PRIVATE HELPER METHODS
|
|
208
|
+
// =============================================================================
|
|
209
|
+
/**
|
|
210
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
211
|
+
*/
|
|
212
|
+
_applyIgnoreChanges() {
|
|
213
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
214
|
+
this.terraformResource.addOverride("lifecycle", [
|
|
215
|
+
{
|
|
216
|
+
ignore_changes: this.props.ignoreChanges,
|
|
217
|
+
},
|
|
218
|
+
]);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
exports.DnsZone = DnsZone;
|
|
223
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
224
|
+
DnsZone[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsZone", version: "1.3.0" };
|
|
225
|
+
(() => {
|
|
226
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_zone_schemas_1.DNS_ZONE_TYPE, dns_zone_schemas_1.ALL_DNS_ZONE_VERSIONS);
|
|
227
|
+
})();
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-zone.js","sourceRoot":"","sources":["../../../src/azure-dnszone/lib/dns-zone.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure DNS Zone implementation using VersionedAzapiResource framework\n *\n * This class provides a single, version-aware implementation that automatically handles\n * version management, schema validation, and property transformation across all\n * supported API versions.\n *\n * Supported API Versions:\n * - 2018-05-01 (Active, Latest)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full backward compatibility with existing interface\n * - JSII compliance for multi-language support\n * - Support for both Public and Private DNS zones\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ALL_DNS_ZONE_VERSIONS, DNS_ZONE_TYPE } from \"./dns-zone-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 * Virtual network reference for private DNS zones\n */\nexport interface VirtualNetworkReference {\n  /**\n   * The resource ID of the virtual network\n   */\n  readonly id: string;\n}\n\n/**\n * Properties for the unified Azure DNS Zone\n *\n * Extends AzapiResourceProps with DNS Zone specific properties\n */\nexport interface DnsZoneProps extends AzapiResourceProps {\n  /**\n   * The type of this DNS zone (Public or Private)\n   * @default \"Public\"\n   */\n  readonly zoneType?: \"Public\" | \"Private\";\n\n  /**\n   * A list of references to virtual networks that register hostnames in this DNS zone\n   * Only valid when zoneType is Private\n   */\n  readonly registrationVirtualNetworks?: VirtualNetworkReference[];\n\n  /**\n   * A list of references to virtual networks that resolve records in this DNS zone\n   * Only valid when zoneType is Private\n   */\n  readonly resolutionVirtualNetworks?: VirtualNetworkReference[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n\n  /**\n   * Resource group ID where the DNS Zone will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * The resource body interface for Azure DNS Zone API calls\n * This matches the Azure REST API schema\n */\nexport interface DnsZoneBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties?: { [key: string]: any };\n}\n\n/**\n * Unified Azure DNS Zone implementation\n *\n * This class provides a single, version-aware implementation that replaces all\n * version-specific DNS Zone classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * Azure DNS Zones are global resources used to host DNS records for a domain.\n * They can be either Public (Internet-accessible) or Private (accessible only\n * from specified virtual networks).\n *\n * @example\n * // Basic public DNS zone with automatic version resolution:\n * const dnsZone = new DnsZone(this, \"dns\", {\n *   name: \"contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n * });\n *\n * @example\n * // Private DNS zone with virtual network links:\n * const privateDnsZone = new DnsZone(this, \"privateDns\", {\n *   name: \"internal.contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n *   zoneType: \"Private\",\n *   registrationVirtualNetworks: [{ id: vnet.id }],\n *   tags: { environment: \"production\" }\n * });\n *\n * @example\n * // DNS zone with explicit version pinning:\n * const dnsZone = new DnsZone(this, \"dns\", {\n *   name: \"contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2018-05-01\",\n * });\n *\n * @stability stable\n */\nexport class DnsZone extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(DNS_ZONE_TYPE, ALL_DNS_ZONE_VERSIONS);\n  }\n\n  public readonly props: DnsZoneProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n  public readonly nameServersOutput: cdktf.TerraformOutput;\n\n  // Public properties\n\n  /**\n   * Creates a new Azure DNS Zone using the VersionedAzapiResource framework\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the DNS Zone\n   */\n  constructor(scope: Construct, id: string, props: DnsZoneProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs\n\n    // Create Terraform outputs\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the DNS Zone\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the DNS Zone\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the DNS Zone\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the DNS Zone\",\n    });\n\n    this.nameServersOutput = new cdktf.TerraformOutput(this, \"name_servers\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.nameServers}`,\n      description: \"The name servers for the DNS Zone\",\n    });\n\n    // Override logical IDs\n    this.idOutput.overrideLogicalId(\"id\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n    this.nameServersOutput.overrideLogicalId(\"name_servers\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   */\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for DNS Zones\n   */\n  protected resourceType(): string {\n    return DNS_ZONE_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Provides default location for DNS Zones (global resource)\n   */\n  protected defaultLocation(): string {\n    return \"global\";\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsZoneProps;\n\n    const body: any = {\n      location: this.location!,\n      // Tags are passed separately to createAzapiResource() for proper idempotency\n      // Do not include tags in the body\n    };\n\n    // Add properties object if zone type or virtual networks are specified\n    if (\n      typedProps.zoneType ||\n      typedProps.registrationVirtualNetworks ||\n      typedProps.resolutionVirtualNetworks\n    ) {\n      body.properties = {\n        zoneType: typedProps.zoneType || \"Public\",\n        registrationVirtualNetworks: typedProps.registrationVirtualNetworks,\n        resolutionVirtualNetworks: typedProps.resolutionVirtualNetworks,\n      };\n    }\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR DNS ZONE OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the name servers for the DNS Zone\n   * These are the Azure DNS name servers that should be configured at your domain registrar\n   */\n  public get nameServers(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.nameServers}`;\n  }\n\n  /**\n   * Get the maximum number of record sets that can be created in this DNS zone\n   */\n  public get maxNumberOfRecordSets(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.maxNumberOfRecordSets}`;\n  }\n\n  /**\n   * Get the current number of record sets in this DNS zone\n   */\n  public get numberOfRecordSets(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.numberOfRecordSets}`;\n  }\n\n  /**\n   * Get the zone type (Public or Private)\n   */\n  public get zoneType(): string {\n    return this.props.zoneType || \"Public\";\n  }\n\n  /**\n   * Add a tag to the DNS Zone\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the DNS Zone\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", [\n        {\n          ignore_changes: this.props.ignoreChanges,\n        },\n      ]);\n    }\n  }\n}\n"]}
|