@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.1
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 +54630 -26185
- 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 +349 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +237 -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 +281 -0
- package/lib/azure-policydefinition/lib/policy-definition.js +236 -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 +806 -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 +206 -26
- package/lib/core-azure/lib/azapi/azapi-resource.js +379 -91
- 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,214 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.DnsForwardingRuleset = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure DNS Forwarding Ruleset implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a unified implementation for creating DNS Forwarding Rulesets
|
|
10
|
+
* that work with DNS Resolver Outbound Endpoints to enable conditional forwarding rules.
|
|
11
|
+
*
|
|
12
|
+
* Supported API Versions:
|
|
13
|
+
* - 2022-07-01 (Active, Latest)
|
|
14
|
+
*
|
|
15
|
+
* Features:
|
|
16
|
+
* - Automatic latest version resolution when no version is specified
|
|
17
|
+
* - Explicit version pinning for stability requirements
|
|
18
|
+
* - Schema-driven validation and transformation
|
|
19
|
+
* - Full backward compatibility with existing interface
|
|
20
|
+
* - JSII compliance for multi-language support
|
|
21
|
+
* - Conditional DNS forwarding for hybrid scenarios
|
|
22
|
+
*/
|
|
23
|
+
const cdktf = require("cdktf");
|
|
24
|
+
const dns_forwarding_ruleset_schemas_1 = require("./dns-forwarding-ruleset-schemas");
|
|
25
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
26
|
+
/**
|
|
27
|
+
* Unified Azure DNS Forwarding Ruleset implementation
|
|
28
|
+
*
|
|
29
|
+
* This class provides a unified implementation for creating DNS Forwarding Rulesets
|
|
30
|
+
* that enable conditional forwarding of DNS queries. Rulesets work with DNS Resolver
|
|
31
|
+
* Outbound Endpoints to route queries to specific target DNS servers based on domain names.
|
|
32
|
+
*
|
|
33
|
+
* Key Requirements:
|
|
34
|
+
* - Requires at least one DNS Resolver Outbound Endpoint
|
|
35
|
+
* - Each ruleset can contain up to 1000 forwarding rules
|
|
36
|
+
* - Regional resource (must match outbound endpoint location)
|
|
37
|
+
* - Can be linked to multiple virtual networks
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* // Basic DNS forwarding ruleset with automatic version resolution:
|
|
41
|
+
* const ruleset = new DnsForwardingRuleset(this, "ruleset", {
|
|
42
|
+
* name: "my-ruleset",
|
|
43
|
+
* location: "eastus",
|
|
44
|
+
* resourceGroupId: resourceGroup.id,
|
|
45
|
+
* dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
|
|
46
|
+
* });
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* // DNS forwarding ruleset with tags:
|
|
50
|
+
* const ruleset = new DnsForwardingRuleset(this, "ruleset", {
|
|
51
|
+
* name: "my-ruleset",
|
|
52
|
+
* location: "eastus",
|
|
53
|
+
* resourceGroupId: resourceGroup.id,
|
|
54
|
+
* dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
|
|
55
|
+
* tags: {
|
|
56
|
+
* environment: "production",
|
|
57
|
+
* purpose: "hybrid-dns"
|
|
58
|
+
* }
|
|
59
|
+
* });
|
|
60
|
+
*
|
|
61
|
+
* @example
|
|
62
|
+
* // DNS forwarding ruleset with explicit version pinning:
|
|
63
|
+
* const ruleset = new DnsForwardingRuleset(this, "ruleset", {
|
|
64
|
+
* name: "my-ruleset",
|
|
65
|
+
* location: "eastus",
|
|
66
|
+
* resourceGroupId: resourceGroup.id,
|
|
67
|
+
* dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
|
|
68
|
+
* apiVersion: "2022-07-01",
|
|
69
|
+
* });
|
|
70
|
+
*
|
|
71
|
+
* @stability stable
|
|
72
|
+
*/
|
|
73
|
+
class DnsForwardingRuleset extends azapi_resource_1.AzapiResource {
|
|
74
|
+
// Public properties
|
|
75
|
+
/**
|
|
76
|
+
* Creates a new Azure DNS Forwarding Ruleset using the AzapiResource framework
|
|
77
|
+
*
|
|
78
|
+
* @param scope - The scope in which to define this construct
|
|
79
|
+
* @param id - The unique identifier for this instance
|
|
80
|
+
* @param props - Configuration properties for the DNS Forwarding Ruleset
|
|
81
|
+
*/
|
|
82
|
+
constructor(scope, id, props) {
|
|
83
|
+
super(scope, id, props);
|
|
84
|
+
this.props = props;
|
|
85
|
+
// Extract properties from the AZAPI resource outputs
|
|
86
|
+
// Create Terraform outputs
|
|
87
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
88
|
+
value: this.id,
|
|
89
|
+
description: "The ID of the DNS Forwarding Ruleset",
|
|
90
|
+
});
|
|
91
|
+
this.locationOutput = new cdktf.TerraformOutput(this, "location", {
|
|
92
|
+
value: `\${${this.terraformResource.fqn}.location}`,
|
|
93
|
+
description: "The location of the DNS Forwarding Ruleset",
|
|
94
|
+
});
|
|
95
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
96
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
97
|
+
description: "The name of the DNS Forwarding Ruleset",
|
|
98
|
+
});
|
|
99
|
+
this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
|
|
100
|
+
value: `\${${this.terraformResource.fqn}.tags}`,
|
|
101
|
+
description: "The tags assigned to the DNS Forwarding Ruleset",
|
|
102
|
+
});
|
|
103
|
+
this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioning_state", {
|
|
104
|
+
value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
|
|
105
|
+
description: "The provisioning state of the DNS Forwarding Ruleset resource",
|
|
106
|
+
});
|
|
107
|
+
this.resourceGuidOutput = new cdktf.TerraformOutput(this, "resource_guid", {
|
|
108
|
+
value: `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,
|
|
109
|
+
description: "The unique identifier for the DNS Forwarding Ruleset resource",
|
|
110
|
+
});
|
|
111
|
+
// Override logical IDs
|
|
112
|
+
this.idOutput.overrideLogicalId("id");
|
|
113
|
+
this.locationOutput.overrideLogicalId("location");
|
|
114
|
+
this.nameOutput.overrideLogicalId("name");
|
|
115
|
+
this.tagsOutput.overrideLogicalId("tags");
|
|
116
|
+
this.provisioningStateOutput.overrideLogicalId("provisioning_state");
|
|
117
|
+
this.resourceGuidOutput.overrideLogicalId("resource_guid");
|
|
118
|
+
// Apply ignore changes if specified
|
|
119
|
+
this._applyIgnoreChanges();
|
|
120
|
+
}
|
|
121
|
+
// =============================================================================
|
|
122
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
123
|
+
// =============================================================================
|
|
124
|
+
/**
|
|
125
|
+
* Gets the default API version to use when no explicit version is specified
|
|
126
|
+
*/
|
|
127
|
+
defaultVersion() {
|
|
128
|
+
return "2022-07-01";
|
|
129
|
+
}
|
|
130
|
+
/**
|
|
131
|
+
* Gets the Azure resource type for DNS Forwarding Rulesets
|
|
132
|
+
*/
|
|
133
|
+
resourceType() {
|
|
134
|
+
return dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE;
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Gets the API schema for the resolved version
|
|
138
|
+
*/
|
|
139
|
+
apiSchema() {
|
|
140
|
+
return this.resolveSchema();
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Indicates that location is required for DNS Forwarding Rulesets
|
|
144
|
+
*/
|
|
145
|
+
requiresLocation() {
|
|
146
|
+
return true;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Creates the resource body for the Azure API call
|
|
150
|
+
*/
|
|
151
|
+
createResourceBody(props) {
|
|
152
|
+
const typedProps = props;
|
|
153
|
+
const body = {
|
|
154
|
+
location: this.location,
|
|
155
|
+
tags: this.allTags(),
|
|
156
|
+
properties: {
|
|
157
|
+
dnsResolverOutboundEndpoints: typedProps.dnsResolverOutboundEndpointIds.map((id) => ({ id })),
|
|
158
|
+
},
|
|
159
|
+
};
|
|
160
|
+
return body;
|
|
161
|
+
}
|
|
162
|
+
// =============================================================================
|
|
163
|
+
// PUBLIC METHODS FOR DNS FORWARDING RULESET OPERATIONS
|
|
164
|
+
// =============================================================================
|
|
165
|
+
/**
|
|
166
|
+
* Get the provisioning state of the DNS Forwarding Ruleset
|
|
167
|
+
*/
|
|
168
|
+
get provisioningState() {
|
|
169
|
+
return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Get the unique identifier for the DNS Forwarding Ruleset resource
|
|
173
|
+
*/
|
|
174
|
+
get resourceGuid() {
|
|
175
|
+
return `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Add a tag to the DNS Forwarding Ruleset
|
|
179
|
+
*/
|
|
180
|
+
addTag(key, value) {
|
|
181
|
+
if (!this.props.tags) {
|
|
182
|
+
this.props.tags = {};
|
|
183
|
+
}
|
|
184
|
+
this.props.tags[key] = value;
|
|
185
|
+
}
|
|
186
|
+
/**
|
|
187
|
+
* Remove a tag from the DNS Forwarding Ruleset
|
|
188
|
+
*/
|
|
189
|
+
removeTag(key) {
|
|
190
|
+
if (this.props.tags && this.props.tags[key]) {
|
|
191
|
+
delete this.props.tags[key];
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
// =============================================================================
|
|
195
|
+
// PRIVATE HELPER METHODS
|
|
196
|
+
// =============================================================================
|
|
197
|
+
/**
|
|
198
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
199
|
+
*/
|
|
200
|
+
_applyIgnoreChanges() {
|
|
201
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
202
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
203
|
+
ignore_changes: this.props.ignoreChanges,
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
exports.DnsForwardingRuleset = DnsForwardingRuleset;
|
|
209
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
210
|
+
DnsForwardingRuleset[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsForwardingRuleset", version: "1.3.1" };
|
|
211
|
+
(() => {
|
|
212
|
+
azapi_resource_1.AzapiResource.registerSchemas(dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE, dns_forwarding_ruleset_schemas_1.ALL_DNS_FORWARDING_RULESET_VERSIONS);
|
|
213
|
+
})();
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-forwarding-ruleset.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure DNS Forwarding Ruleset implementation using AzapiResource framework\n *\n * This class provides a unified implementation for creating DNS Forwarding Rulesets\n * that work with DNS Resolver Outbound Endpoints to enable conditional forwarding rules.\n *\n * Supported API Versions:\n * - 2022-07-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 * - Conditional DNS forwarding for hybrid scenarios\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_DNS_FORWARDING_RULESET_VERSIONS,\n  DNS_FORWARDING_RULESET_TYPE,\n} from \"./dns-forwarding-ruleset-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 * Properties for the unified Azure DNS Forwarding Ruleset\n *\n * Extends AzapiResourceProps with DNS Forwarding Ruleset specific properties\n */\nexport interface DnsForwardingRulesetProps extends AzapiResourceProps {\n  /**\n   * Array of resource IDs of DNS Resolver Outbound Endpoints\n   * The ruleset uses these endpoints to forward DNS queries based on the rules\n   * @example [\"/subscriptions/.../dnsResolvers/resolver1/outboundEndpoints/endpoint1\"]\n   */\n  readonly dnsResolverOutboundEndpointIds: string[];\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 Forwarding Ruleset will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * The resource body interface for Azure DNS Forwarding Ruleset API calls\n * This matches the Azure REST API schema\n */\n/**\n * DNS Resolver Outbound Endpoint reference\n */\nexport interface DnsResolverOutboundEndpointReference {\n  readonly id: string;\n}\n\n/**\n * Properties for the DNS Forwarding Ruleset body\n */\nexport interface DnsForwardingRulesetProperties {\n  readonly dnsResolverOutboundEndpoints: DnsResolverOutboundEndpointReference[];\n}\n\n/**\n * The resource body interface for Azure DNS Forwarding Ruleset API calls\n * This matches the Azure REST API schema\n */\nexport interface DnsForwardingRulesetBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties: DnsForwardingRulesetProperties;\n}\n\n/**\n * Unified Azure DNS Forwarding Ruleset implementation\n *\n * This class provides a unified implementation for creating DNS Forwarding Rulesets\n * that enable conditional forwarding of DNS queries. Rulesets work with DNS Resolver\n * Outbound Endpoints to route queries to specific target DNS servers based on domain names.\n *\n * Key Requirements:\n * - Requires at least one DNS Resolver Outbound Endpoint\n * - Each ruleset can contain up to 1000 forwarding rules\n * - Regional resource (must match outbound endpoint location)\n * - Can be linked to multiple virtual networks\n *\n * @example\n * // Basic DNS forwarding ruleset with automatic version resolution:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n * });\n *\n * @example\n * // DNS forwarding ruleset with tags:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n *   tags: {\n *     environment: \"production\",\n *     purpose: \"hybrid-dns\"\n *   }\n * });\n *\n * @example\n * // DNS forwarding ruleset with explicit version pinning:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n *   apiVersion: \"2022-07-01\",\n * });\n *\n * @stability stable\n */\nexport class DnsForwardingRuleset extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_FORWARDING_RULESET_TYPE,\n      ALL_DNS_FORWARDING_RULESET_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsForwardingRulesetProps;\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 provisioningStateOutput: cdktf.TerraformOutput;\n  public readonly resourceGuidOutput: cdktf.TerraformOutput;\n\n  // Public properties\n\n  /**\n   * Creates a new Azure DNS Forwarding Ruleset using the AzapiResource 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 Forwarding Ruleset\n   */\n  constructor(scope: Construct, id: string, props: DnsForwardingRulesetProps) {\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 Forwarding Ruleset\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the DNS Forwarding Ruleset\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the DNS Forwarding Ruleset\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the DNS Forwarding Ruleset\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description:\n          \"The provisioning state of the DNS Forwarding Ruleset resource\",\n      },\n    );\n\n    this.resourceGuidOutput = new cdktf.TerraformOutput(this, \"resource_guid\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,\n      description:\n        \"The unique identifier for the DNS Forwarding Ruleset resource\",\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.provisioningStateOutput.overrideLogicalId(\"provisioning_state\");\n    this.resourceGuidOutput.overrideLogicalId(\"resource_guid\");\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 \"2022-07-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for DNS Forwarding Rulesets\n   */\n  protected resourceType(): string {\n    return DNS_FORWARDING_RULESET_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   * Indicates that location is required for DNS Forwarding Rulesets\n   */\n  protected requiresLocation(): boolean {\n    return true;\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 DnsForwardingRulesetProps;\n\n    const body: DnsForwardingRulesetBody = {\n      location: this.location!,\n      tags: this.allTags(),\n      properties: {\n        dnsResolverOutboundEndpoints:\n          typedProps.dnsResolverOutboundEndpointIds.map((id) => ({ id })),\n      },\n    };\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR DNS FORWARDING RULESET OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the provisioning state of the DNS Forwarding Ruleset\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Get the unique identifier for the DNS Forwarding Ruleset resource\n   */\n  public get resourceGuid(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;\n  }\n\n  /**\n   * Add a tag to the DNS Forwarding Ruleset\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 Forwarding Ruleset\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        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API schemas for Azure DNS Forwarding Rule across all supported versions
|
|
3
|
+
*
|
|
4
|
+
* This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules
|
|
5
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
6
|
+
* framework for validation, transformation, and version management.
|
|
7
|
+
*/
|
|
8
|
+
import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
9
|
+
/**
|
|
10
|
+
* API Schema for Forwarding Rule version 2022-07-01
|
|
11
|
+
*/
|
|
12
|
+
export declare const FORWARDING_RULE_SCHEMA_2022_07_01: ApiSchema;
|
|
13
|
+
/**
|
|
14
|
+
* Version configuration for Forwarding Rule 2022-07-01
|
|
15
|
+
*/
|
|
16
|
+
export declare const FORWARDING_RULE_VERSION_2022_07_01: VersionConfig;
|
|
17
|
+
/**
|
|
18
|
+
* All supported Forwarding Rule versions for registration
|
|
19
|
+
*/
|
|
20
|
+
export declare const ALL_FORWARDING_RULE_VERSIONS: VersionConfig[];
|
|
21
|
+
/**
|
|
22
|
+
* Resource type constant
|
|
23
|
+
*/
|
|
24
|
+
export declare const FORWARDING_RULE_TYPE = "Microsoft.Network/dnsForwardingRulesets/forwardingRules";
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* API schemas for Azure DNS Forwarding Rule across all supported versions
|
|
4
|
+
*
|
|
5
|
+
* This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules
|
|
6
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
7
|
+
* framework for validation, transformation, and version management.
|
|
8
|
+
*/
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.FORWARDING_RULE_TYPE = exports.ALL_FORWARDING_RULE_VERSIONS = exports.FORWARDING_RULE_VERSION_2022_07_01 = exports.FORWARDING_RULE_SCHEMA_2022_07_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 Forwarding Rule versions
|
|
17
|
+
*/
|
|
18
|
+
const COMMON_PROPERTIES = {
|
|
19
|
+
name: {
|
|
20
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
21
|
+
required: true,
|
|
22
|
+
description: "The name of the Forwarding Rule. Must be unique within the ruleset.",
|
|
23
|
+
validation: [
|
|
24
|
+
{
|
|
25
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
26
|
+
message: "Forwarding Rule name is required",
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
30
|
+
value: "^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$",
|
|
31
|
+
message: "Forwarding Rule name must start and end with alphanumeric characters and can contain hyphens",
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
|
|
35
|
+
value: { minLength: 1, maxLength: 80 },
|
|
36
|
+
message: "Forwarding Rule name must be between 1 and 80 characters",
|
|
37
|
+
},
|
|
38
|
+
],
|
|
39
|
+
},
|
|
40
|
+
dnsForwardingRulesetId: {
|
|
41
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
42
|
+
required: true,
|
|
43
|
+
description: "The resource ID of the parent DNS Forwarding Ruleset that this rule belongs to",
|
|
44
|
+
validation: [
|
|
45
|
+
{
|
|
46
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
47
|
+
message: "DNS Forwarding Ruleset ID is required",
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
51
|
+
value: "^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/dnsForwardingRulesets/[^/]+$",
|
|
52
|
+
message: "DNS Forwarding Ruleset ID must be a valid resource ID",
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
},
|
|
56
|
+
domainName: {
|
|
57
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
58
|
+
required: true,
|
|
59
|
+
description: "The domain name to forward (e.g., 'contoso.com.'). Must end with a dot for FQDN.",
|
|
60
|
+
validation: [
|
|
61
|
+
{
|
|
62
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
63
|
+
message: "Domain name is required for Forwarding Rules",
|
|
64
|
+
},
|
|
65
|
+
{
|
|
66
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
67
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
68
|
+
message: "Domain name must be a string",
|
|
69
|
+
},
|
|
70
|
+
],
|
|
71
|
+
},
|
|
72
|
+
targetDnsServers: {
|
|
73
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
74
|
+
required: true,
|
|
75
|
+
description: "Array of target DNS servers to forward queries to. Maximum of 6 servers per rule. Each server requires ipAddress, and optionally port (default 53).",
|
|
76
|
+
validation: [
|
|
77
|
+
{
|
|
78
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
79
|
+
message: "At least one target DNS server is required for Forwarding Rules",
|
|
80
|
+
},
|
|
81
|
+
{
|
|
82
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
83
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
84
|
+
message: "TargetDnsServers must be an array",
|
|
85
|
+
},
|
|
86
|
+
],
|
|
87
|
+
},
|
|
88
|
+
forwardingRuleState: {
|
|
89
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
90
|
+
required: false,
|
|
91
|
+
defaultValue: "Enabled",
|
|
92
|
+
description: "The state of the forwarding rule. Possible values: 'Enabled' or 'Disabled'. Default is 'Enabled'.",
|
|
93
|
+
validation: [
|
|
94
|
+
{
|
|
95
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
96
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
97
|
+
message: "ForwardingRuleState must be a string",
|
|
98
|
+
},
|
|
99
|
+
],
|
|
100
|
+
},
|
|
101
|
+
metadata: {
|
|
102
|
+
dataType: version_interfaces_1.PropertyType.OBJECT,
|
|
103
|
+
required: false,
|
|
104
|
+
defaultValue: {},
|
|
105
|
+
description: "Metadata attached to the forwarding rule as key-value pairs",
|
|
106
|
+
validation: [
|
|
107
|
+
{
|
|
108
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
109
|
+
value: version_interfaces_1.PropertyType.OBJECT,
|
|
110
|
+
message: "Metadata must be an object with string key-value pairs",
|
|
111
|
+
},
|
|
112
|
+
],
|
|
113
|
+
},
|
|
114
|
+
ignoreChanges: {
|
|
115
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
116
|
+
required: false,
|
|
117
|
+
description: "Array of property names to ignore during updates",
|
|
118
|
+
validation: [
|
|
119
|
+
{
|
|
120
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
121
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
122
|
+
message: "IgnoreChanges must be an array of strings",
|
|
123
|
+
},
|
|
124
|
+
],
|
|
125
|
+
},
|
|
126
|
+
};
|
|
127
|
+
// =============================================================================
|
|
128
|
+
// READ-ONLY PROPERTY DEFINITIONS
|
|
129
|
+
// =============================================================================
|
|
130
|
+
/**
|
|
131
|
+
* Read-only properties that are populated by Azure after creation
|
|
132
|
+
* These properties should not be included in the request body
|
|
133
|
+
*/
|
|
134
|
+
const READ_ONLY_PROPERTIES = {
|
|
135
|
+
provisioningState: {
|
|
136
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
137
|
+
required: false,
|
|
138
|
+
description: "The provisioning state of the Forwarding Rule resource (read-only)",
|
|
139
|
+
validation: [
|
|
140
|
+
{
|
|
141
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
142
|
+
value: version_interfaces_1.PropertyType.STRING,
|
|
143
|
+
message: "ProvisioningState must be a string",
|
|
144
|
+
},
|
|
145
|
+
],
|
|
146
|
+
},
|
|
147
|
+
};
|
|
148
|
+
// =============================================================================
|
|
149
|
+
// VERSION-SPECIFIC SCHEMAS
|
|
150
|
+
// =============================================================================
|
|
151
|
+
/**
|
|
152
|
+
* API Schema for Forwarding Rule version 2022-07-01
|
|
153
|
+
*/
|
|
154
|
+
exports.FORWARDING_RULE_SCHEMA_2022_07_01 = {
|
|
155
|
+
resourceType: "Microsoft.Network/dnsForwardingRulesets/forwardingRules",
|
|
156
|
+
version: "2022-07-01",
|
|
157
|
+
properties: {
|
|
158
|
+
...COMMON_PROPERTIES,
|
|
159
|
+
...READ_ONLY_PROPERTIES,
|
|
160
|
+
},
|
|
161
|
+
required: [
|
|
162
|
+
"name",
|
|
163
|
+
"dnsForwardingRulesetId",
|
|
164
|
+
"domainName",
|
|
165
|
+
"targetDnsServers",
|
|
166
|
+
],
|
|
167
|
+
optional: ["forwardingRuleState", "metadata", "ignoreChanges"],
|
|
168
|
+
deprecated: [],
|
|
169
|
+
transformationRules: {},
|
|
170
|
+
validationRules: [
|
|
171
|
+
{
|
|
172
|
+
property: "name",
|
|
173
|
+
rules: [
|
|
174
|
+
{
|
|
175
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
176
|
+
message: "Name is required for Forwarding Rules",
|
|
177
|
+
},
|
|
178
|
+
],
|
|
179
|
+
},
|
|
180
|
+
{
|
|
181
|
+
property: "dnsForwardingRulesetId",
|
|
182
|
+
rules: [
|
|
183
|
+
{
|
|
184
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
185
|
+
message: "DNS Forwarding Ruleset ID is required for Forwarding Rules",
|
|
186
|
+
},
|
|
187
|
+
],
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
property: "domainName",
|
|
191
|
+
rules: [
|
|
192
|
+
{
|
|
193
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
194
|
+
message: "Domain name is required for Forwarding Rules",
|
|
195
|
+
},
|
|
196
|
+
],
|
|
197
|
+
},
|
|
198
|
+
{
|
|
199
|
+
property: "targetDnsServers",
|
|
200
|
+
rules: [
|
|
201
|
+
{
|
|
202
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
203
|
+
message: "At least one target DNS server is required",
|
|
204
|
+
},
|
|
205
|
+
],
|
|
206
|
+
},
|
|
207
|
+
],
|
|
208
|
+
};
|
|
209
|
+
// =============================================================================
|
|
210
|
+
// VERSION CONFIGURATIONS
|
|
211
|
+
// =============================================================================
|
|
212
|
+
/**
|
|
213
|
+
* Version configuration for Forwarding Rule 2022-07-01
|
|
214
|
+
*/
|
|
215
|
+
exports.FORWARDING_RULE_VERSION_2022_07_01 = {
|
|
216
|
+
version: "2022-07-01",
|
|
217
|
+
schema: exports.FORWARDING_RULE_SCHEMA_2022_07_01,
|
|
218
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
219
|
+
releaseDate: "2022-07-01",
|
|
220
|
+
deprecationDate: undefined,
|
|
221
|
+
sunsetDate: undefined,
|
|
222
|
+
breakingChanges: [],
|
|
223
|
+
migrationGuide: "/docs/forwarding-rule/migration-2022-07-01",
|
|
224
|
+
changeLog: [
|
|
225
|
+
{
|
|
226
|
+
changeType: "added",
|
|
227
|
+
description: "Stable release of Forwarding Rule API with support for conditional DNS forwarding",
|
|
228
|
+
breaking: false,
|
|
229
|
+
},
|
|
230
|
+
],
|
|
231
|
+
};
|
|
232
|
+
/**
|
|
233
|
+
* All supported Forwarding Rule versions for registration
|
|
234
|
+
*/
|
|
235
|
+
exports.ALL_FORWARDING_RULE_VERSIONS = [
|
|
236
|
+
exports.FORWARDING_RULE_VERSION_2022_07_01,
|
|
237
|
+
];
|
|
238
|
+
/**
|
|
239
|
+
* Resource type constant
|
|
240
|
+
*/
|
|
241
|
+
exports.FORWARDING_RULE_TYPE = "Microsoft.Network/dnsForwardingRulesets/forwardingRules";
|
|
242
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forwarding-rule-schemas.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,2GAO4E;AAE5E,gFAAgF;AAChF,8BAA8B;AAC9B,gFAAgF;AAEhF;;GAEG;AACH,MAAM,iBAAiB,GAA0C;IAC/D,IAAI,EAAE;QACJ,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,qEAAqE;QACvE,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,kCAAkC;aAC5C;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,aAAa;gBAC1C,KAAK,EAAE,0CAA0C;gBACjD,OAAO,EACL,8FAA8F;aACjG;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,WAAW;gBACxC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;gBACtC,OAAO,EAAE,0DAA0D;aACpE;SACF;KACF;IACD,sBAAsB,EAAE;QACtB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,gFAAgF;QAClF,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,uCAAuC;aACjD;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,aAAa;gBAC1C,KAAK,EACH,qGAAqG;gBACvG,OAAO,EAAE,uDAAuD;aACjE;SACF;KACF;IACD,UAAU,EAAE;QACV,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,kFAAkF;QACpF,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,8CAA8C;aACxD;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,8BAA8B;aACxC;SACF;KACF;IACD,gBAAgB,EAAE;QAChB,QAAQ,EAAE,iCAAY,CAAC,KAAK;QAC5B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,qJAAqJ;QACvJ,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EACL,iEAAiE;aACpE;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,KAAK;gBACzB,OAAO,EAAE,mCAAmC;aAC7C;SACF;KACF;IACD,mBAAmB,EAAE;QACnB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,SAAS;QACvB,WAAW,EACT,mGAAmG;QACrG,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,sCAAsC;aAChD;SACF;KACF;IACD,QAAQ,EAAE;QACR,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE;QAChB,WAAW,EAAE,6DAA6D;QAC1E,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,wDAAwD;aAClE;SACF;KACF;IACD,aAAa,EAAE;QACb,QAAQ,EAAE,iCAAY,CAAC,KAAK;QAC5B,QAAQ,EAAE,KAAK;QACf,WAAW,EAAE,kDAAkD;QAC/D,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,KAAK;gBACzB,OAAO,EAAE,2CAA2C;aACrD;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,iCAAiC;AACjC,gFAAgF;AAEhF;;;GAGG;AACH,MAAM,oBAAoB,GAA0C;IAClE,iBAAiB,EAAE;QACjB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,WAAW,EACT,oEAAoE;QACtE,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,oCAAoC;aAC9C;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,2BAA2B;AAC3B,gFAAgF;AAEhF;;GAEG;AACU,QAAA,iCAAiC,GAAc;IAC1D,YAAY,EAAE,yDAAyD;IACvE,OAAO,EAAE,YAAY;IACrB,UAAU,EAAE;QACV,GAAG,iBAAiB;QACpB,GAAG,oBAAoB;KACxB;IACD,QAAQ,EAAE;QACR,MAAM;QACN,wBAAwB;QACxB,YAAY;QACZ,kBAAkB;KACnB;IACD,QAAQ,EAAE,CAAC,qBAAqB,EAAE,UAAU,EAAE,eAAe,CAAC;IAC9D,UAAU,EAAE,EAAE;IACd,mBAAmB,EAAE,EAAE;IACvB,eAAe,EAAE;QACf;YACE,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,uCAAuC;iBACjD;aACF;SACF;QACD;YACE,QAAQ,EAAE,wBAAwB;YAClC,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,4DAA4D;iBACtE;aACF;SACF;QACD;YACE,QAAQ,EAAE,YAAY;YACtB,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,8CAA8C;iBACxD;aACF;SACF;QACD;YACE,QAAQ,EAAE,kBAAkB;YAC5B,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,4CAA4C;iBACtD;aACF;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,yBAAyB;AACzB,gFAAgF;AAEhF;;GAEG;AACU,QAAA,kCAAkC,GAAkB;IAC/D,OAAO,EAAE,YAAY;IACrB,MAAM,EAAE,yCAAiC;IACzC,YAAY,EAAE,wCAAmB,CAAC,MAAM;IACxC,WAAW,EAAE,YAAY;IACzB,eAAe,EAAE,SAAS;IAC1B,UAAU,EAAE,SAAS;IACrB,eAAe,EAAE,EAAE;IACnB,cAAc,EAAE,4CAA4C;IAC5D,SAAS,EAAE;QACT;YACE,UAAU,EAAE,OAAO;YACnB,WAAW,EACT,mFAAmF;YACrF,QAAQ,EAAE,KAAK;SAChB;KACF;CACF,CAAC;AAEF;;GAEG;AACU,QAAA,4BAA4B,GAAoB;IAC3D,0CAAkC;CACnC,CAAC;AAEF;;GAEG;AACU,QAAA,oBAAoB,GAC/B,yDAAyD,CAAC","sourcesContent":["/**\n * API schemas for Azure DNS Forwarding Rule across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules\n * across all supported API versions. The schemas are used by the AzapiResource\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 Forwarding Rule versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The name of the Forwarding Rule. Must be unique within the ruleset.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Forwarding Rule name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$\",\n        message:\n          \"Forwarding Rule name must start and end with alphanumeric characters and can contain hyphens\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 80 },\n        message: \"Forwarding Rule name must be between 1 and 80 characters\",\n      },\n    ],\n  },\n  dnsForwardingRulesetId: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The resource ID of the parent DNS Forwarding Ruleset that this rule belongs to\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"DNS Forwarding Ruleset ID is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value:\n          \"^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/dnsForwardingRulesets/[^/]+$\",\n        message: \"DNS Forwarding Ruleset ID must be a valid resource ID\",\n      },\n    ],\n  },\n  domainName: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The domain name to forward (e.g., 'contoso.com.'). Must end with a dot for FQDN.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Domain name is required for Forwarding Rules\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"Domain name must be a string\",\n      },\n    ],\n  },\n  targetDnsServers: {\n    dataType: PropertyType.ARRAY,\n    required: true,\n    description:\n      \"Array of target DNS servers to forward queries to. Maximum of 6 servers per rule. Each server requires ipAddress, and optionally port (default 53).\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message:\n          \"At least one target DNS server is required for Forwarding Rules\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"TargetDnsServers must be an array\",\n      },\n    ],\n  },\n  forwardingRuleState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Enabled\",\n    description:\n      \"The state of the forwarding rule. Possible values: 'Enabled' or 'Disabled'. Default is 'Enabled'.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ForwardingRuleState must be a string\",\n      },\n    ],\n  },\n  metadata: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description: \"Metadata attached to the forwarding rule as key-value pairs\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Metadata must be an object with string key-value pairs\",\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// READ-ONLY PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Read-only properties that are populated by Azure after creation\n * These properties should not be included in the request body\n */\nconst READ_ONLY_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  provisioningState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The provisioning state of the Forwarding Rule resource (read-only)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ProvisioningState must be a string\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Forwarding Rule version 2022-07-01\n */\nexport const FORWARDING_RULE_SCHEMA_2022_07_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/dnsForwardingRulesets/forwardingRules\",\n  version: \"2022-07-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n    ...READ_ONLY_PROPERTIES,\n  },\n  required: [\n    \"name\",\n    \"dnsForwardingRulesetId\",\n    \"domainName\",\n    \"targetDnsServers\",\n  ],\n  optional: [\"forwardingRuleState\", \"metadata\", \"ignoreChanges\"],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"dnsForwardingRulesetId\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"DNS Forwarding Ruleset ID is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"domainName\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Domain name is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"targetDnsServers\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"At least one target DNS server is required\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Forwarding Rule 2022-07-01\n */\nexport const FORWARDING_RULE_VERSION_2022_07_01: VersionConfig = {\n  version: \"2022-07-01\",\n  schema: FORWARDING_RULE_SCHEMA_2022_07_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2022-07-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/forwarding-rule/migration-2022-07-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of Forwarding Rule API with support for conditional DNS forwarding\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Forwarding Rule versions for registration\n */\nexport const ALL_FORWARDING_RULE_VERSIONS: VersionConfig[] = [\n  FORWARDING_RULE_VERSION_2022_07_01,\n];\n\n/**\n * Resource type constant\n */\nexport const FORWARDING_RULE_TYPE =\n  \"Microsoft.Network/dnsForwardingRulesets/forwardingRules\";\n"]}
|