@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,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure DNS Resolver Outbound Endpoint implementation using AzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a unified implementation for DNS Resolver Outbound Endpoints.
|
|
5
|
+
* Outbound Endpoints allow Azure resources to forward DNS queries to external DNS servers
|
|
6
|
+
* such as on-premises DNS servers or other external DNS resolvers.
|
|
7
|
+
*
|
|
8
|
+
* Supported API Versions:
|
|
9
|
+
* - 2022-07-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
|
|
16
|
+
* - JSII compliance for multi-language support
|
|
17
|
+
* - Dedicated subnet requirement with delegation
|
|
18
|
+
* - Used with forwarding rules for conditional DNS forwarding
|
|
19
|
+
*/
|
|
20
|
+
import * as cdktf from "cdktf";
|
|
21
|
+
import { Construct } from "constructs";
|
|
22
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
23
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
24
|
+
/**
|
|
25
|
+
* Properties for the Azure DNS Resolver Outbound Endpoint
|
|
26
|
+
*
|
|
27
|
+
* Extends AzapiResourceProps with Outbound Endpoint specific properties
|
|
28
|
+
*/
|
|
29
|
+
export interface DnsResolverOutboundEndpointProps extends AzapiResourceProps {
|
|
30
|
+
/**
|
|
31
|
+
* Resource ID of the parent DNS Resolver
|
|
32
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/dnsResolvers/my-resolver"
|
|
33
|
+
*/
|
|
34
|
+
readonly dnsResolverId: string;
|
|
35
|
+
/**
|
|
36
|
+
* Resource ID of the subnet where the Outbound Endpoint will be deployed
|
|
37
|
+
* Must be a dedicated subnet between /28 and /24 with delegation to Microsoft.Network/dnsResolvers
|
|
38
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/virtualNetworks/vnet/subnets/outbound-subnet"
|
|
39
|
+
*/
|
|
40
|
+
readonly subnetId: string;
|
|
41
|
+
/**
|
|
42
|
+
* The lifecycle rules to ignore changes
|
|
43
|
+
* @example ["tags"]
|
|
44
|
+
*/
|
|
45
|
+
readonly ignoreChanges?: string[];
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* The resource body interface for Azure Outbound Endpoint API calls
|
|
49
|
+
* This matches the Azure REST API schema
|
|
50
|
+
*/
|
|
51
|
+
export interface DnsResolverOutboundEndpointBody {
|
|
52
|
+
readonly location: string;
|
|
53
|
+
readonly tags?: {
|
|
54
|
+
[key: string]: string;
|
|
55
|
+
};
|
|
56
|
+
readonly properties?: any;
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Azure DNS Resolver Outbound Endpoint implementation
|
|
60
|
+
*
|
|
61
|
+
* Outbound Endpoints enable Azure resources to forward DNS queries to external DNS servers
|
|
62
|
+
* (such as on-premises DNS servers). This enables hybrid DNS scenarios where Azure resources
|
|
63
|
+
* need to resolve names from external DNS zones.
|
|
64
|
+
*
|
|
65
|
+
* Requirements:
|
|
66
|
+
* - Dedicated subnet between /28 and /24
|
|
67
|
+
* - Subnet must be delegated to Microsoft.Network/dnsResolvers
|
|
68
|
+
* - Must be in the same VNet as the parent DNS Resolver
|
|
69
|
+
* - Each DNS Resolver can have multiple outbound endpoints
|
|
70
|
+
* - Outbound endpoints are used with forwarding rules to specify which queries to forward
|
|
71
|
+
*
|
|
72
|
+
* @example
|
|
73
|
+
* // Basic outbound endpoint:
|
|
74
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
75
|
+
* name: "my-outbound-endpoint",
|
|
76
|
+
* location: "eastus",
|
|
77
|
+
* dnsResolverId: dnsResolver.id,
|
|
78
|
+
* subnetId: outboundSubnet.id
|
|
79
|
+
* });
|
|
80
|
+
*
|
|
81
|
+
* @example
|
|
82
|
+
* // Outbound endpoint with tags:
|
|
83
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
84
|
+
* name: "my-outbound-endpoint",
|
|
85
|
+
* location: "eastus",
|
|
86
|
+
* dnsResolverId: dnsResolver.id,
|
|
87
|
+
* subnetId: outboundSubnet.id,
|
|
88
|
+
* tags: {
|
|
89
|
+
* environment: "production",
|
|
90
|
+
* purpose: "hybrid-dns"
|
|
91
|
+
* }
|
|
92
|
+
* });
|
|
93
|
+
*
|
|
94
|
+
* @example
|
|
95
|
+
* // Outbound endpoint with version pinning:
|
|
96
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
97
|
+
* name: "my-outbound-endpoint",
|
|
98
|
+
* location: "eastus",
|
|
99
|
+
* dnsResolverId: dnsResolver.id,
|
|
100
|
+
* subnetId: outboundSubnet.id,
|
|
101
|
+
* apiVersion: "2022-07-01"
|
|
102
|
+
* });
|
|
103
|
+
*
|
|
104
|
+
* @stability stable
|
|
105
|
+
*/
|
|
106
|
+
export declare class DnsResolverOutboundEndpoint extends AzapiResource {
|
|
107
|
+
/**
|
|
108
|
+
* The input properties for this Outbound Endpoint instance
|
|
109
|
+
*/
|
|
110
|
+
readonly props: DnsResolverOutboundEndpointProps;
|
|
111
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
112
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
113
|
+
readonly locationOutput: cdktf.TerraformOutput;
|
|
114
|
+
readonly tagsOutput: cdktf.TerraformOutput;
|
|
115
|
+
readonly provisioningStateOutput: cdktf.TerraformOutput;
|
|
116
|
+
readonly resourceGuidOutput: cdktf.TerraformOutput;
|
|
117
|
+
/**
|
|
118
|
+
* Creates a new Azure DNS Resolver Outbound Endpoint using the AzapiResource framework
|
|
119
|
+
*
|
|
120
|
+
* @param scope - The scope in which to define this construct
|
|
121
|
+
* @param id - The unique identifier for this instance
|
|
122
|
+
* @param props - Configuration properties for the Outbound Endpoint
|
|
123
|
+
*/
|
|
124
|
+
constructor(scope: Construct, id: string, props: DnsResolverOutboundEndpointProps);
|
|
125
|
+
/**
|
|
126
|
+
* Resolves the parent resource ID for the Outbound Endpoint
|
|
127
|
+
* Outbound Endpoints are child resources of DNS Resolvers
|
|
128
|
+
*/
|
|
129
|
+
protected resolveParentId(props: any): string;
|
|
130
|
+
/**
|
|
131
|
+
* Gets the default API version to use when no explicit version is specified
|
|
132
|
+
*/
|
|
133
|
+
protected defaultVersion(): string;
|
|
134
|
+
/**
|
|
135
|
+
* Gets the Azure resource type for Outbound Endpoints
|
|
136
|
+
*/
|
|
137
|
+
protected resourceType(): string;
|
|
138
|
+
/**
|
|
139
|
+
* Gets the API schema for the resolved version
|
|
140
|
+
*/
|
|
141
|
+
protected apiSchema(): ApiSchema;
|
|
142
|
+
/**
|
|
143
|
+
* Indicates that location is required for Outbound Endpoints
|
|
144
|
+
*/
|
|
145
|
+
protected requiresLocation(): boolean;
|
|
146
|
+
/**
|
|
147
|
+
* Creates the resource body for the Azure API call
|
|
148
|
+
*/
|
|
149
|
+
protected createResourceBody(props: any): any;
|
|
150
|
+
/**
|
|
151
|
+
* Get the subnet ID
|
|
152
|
+
* Returns the input value as Azure API doesn't return nested subnet structure reliably
|
|
153
|
+
*/
|
|
154
|
+
get subnetId(): string;
|
|
155
|
+
/**
|
|
156
|
+
* Get the provisioning state of the Outbound Endpoint
|
|
157
|
+
*/
|
|
158
|
+
get provisioningState(): string;
|
|
159
|
+
/**
|
|
160
|
+
* Get the unique identifier for the Outbound Endpoint
|
|
161
|
+
*/
|
|
162
|
+
get resourceGuid(): string;
|
|
163
|
+
/**
|
|
164
|
+
* Add a tag to the Outbound Endpoint
|
|
165
|
+
*/
|
|
166
|
+
addTag(key: string, value: string): void;
|
|
167
|
+
/**
|
|
168
|
+
* Remove a tag from the Outbound Endpoint
|
|
169
|
+
*/
|
|
170
|
+
removeTag(key: string): void;
|
|
171
|
+
/**
|
|
172
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
173
|
+
*/
|
|
174
|
+
private _applyIgnoreChanges;
|
|
175
|
+
}
|
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.DnsResolverOutboundEndpoint = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Azure DNS Resolver Outbound Endpoint implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a unified implementation for DNS Resolver Outbound Endpoints.
|
|
10
|
+
* Outbound Endpoints allow Azure resources to forward DNS queries to external DNS servers
|
|
11
|
+
* such as on-premises DNS servers or other external DNS resolvers.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2022-07-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
|
|
21
|
+
* - JSII compliance for multi-language support
|
|
22
|
+
* - Dedicated subnet requirement with delegation
|
|
23
|
+
* - Used with forwarding rules for conditional DNS forwarding
|
|
24
|
+
*/
|
|
25
|
+
const cdktf = require("cdktf");
|
|
26
|
+
const outbound_endpoint_schemas_1 = require("./outbound-endpoint-schemas");
|
|
27
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
28
|
+
/**
|
|
29
|
+
* Azure DNS Resolver Outbound Endpoint implementation
|
|
30
|
+
*
|
|
31
|
+
* Outbound Endpoints enable Azure resources to forward DNS queries to external DNS servers
|
|
32
|
+
* (such as on-premises DNS servers). This enables hybrid DNS scenarios where Azure resources
|
|
33
|
+
* need to resolve names from external DNS zones.
|
|
34
|
+
*
|
|
35
|
+
* Requirements:
|
|
36
|
+
* - Dedicated subnet between /28 and /24
|
|
37
|
+
* - Subnet must be delegated to Microsoft.Network/dnsResolvers
|
|
38
|
+
* - Must be in the same VNet as the parent DNS Resolver
|
|
39
|
+
* - Each DNS Resolver can have multiple outbound endpoints
|
|
40
|
+
* - Outbound endpoints are used with forwarding rules to specify which queries to forward
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* // Basic outbound endpoint:
|
|
44
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
45
|
+
* name: "my-outbound-endpoint",
|
|
46
|
+
* location: "eastus",
|
|
47
|
+
* dnsResolverId: dnsResolver.id,
|
|
48
|
+
* subnetId: outboundSubnet.id
|
|
49
|
+
* });
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* // Outbound endpoint with tags:
|
|
53
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
54
|
+
* name: "my-outbound-endpoint",
|
|
55
|
+
* location: "eastus",
|
|
56
|
+
* dnsResolverId: dnsResolver.id,
|
|
57
|
+
* subnetId: outboundSubnet.id,
|
|
58
|
+
* tags: {
|
|
59
|
+
* environment: "production",
|
|
60
|
+
* purpose: "hybrid-dns"
|
|
61
|
+
* }
|
|
62
|
+
* });
|
|
63
|
+
*
|
|
64
|
+
* @example
|
|
65
|
+
* // Outbound endpoint with version pinning:
|
|
66
|
+
* const outboundEndpoint = new DnsResolverOutboundEndpoint(this, "outbound-endpoint", {
|
|
67
|
+
* name: "my-outbound-endpoint",
|
|
68
|
+
* location: "eastus",
|
|
69
|
+
* dnsResolverId: dnsResolver.id,
|
|
70
|
+
* subnetId: outboundSubnet.id,
|
|
71
|
+
* apiVersion: "2022-07-01"
|
|
72
|
+
* });
|
|
73
|
+
*
|
|
74
|
+
* @stability stable
|
|
75
|
+
*/
|
|
76
|
+
class DnsResolverOutboundEndpoint extends azapi_resource_1.AzapiResource {
|
|
77
|
+
// Public properties
|
|
78
|
+
/**
|
|
79
|
+
* Creates a new Azure DNS Resolver Outbound Endpoint using the AzapiResource framework
|
|
80
|
+
*
|
|
81
|
+
* @param scope - The scope in which to define this construct
|
|
82
|
+
* @param id - The unique identifier for this instance
|
|
83
|
+
* @param props - Configuration properties for the Outbound Endpoint
|
|
84
|
+
*/
|
|
85
|
+
constructor(scope, id, props) {
|
|
86
|
+
super(scope, id, props);
|
|
87
|
+
this.props = props;
|
|
88
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
89
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
90
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
91
|
+
value: this.id,
|
|
92
|
+
description: "The ID of the Outbound Endpoint",
|
|
93
|
+
});
|
|
94
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
95
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
96
|
+
description: "The name of the Outbound Endpoint",
|
|
97
|
+
});
|
|
98
|
+
this.locationOutput = new cdktf.TerraformOutput(this, "location", {
|
|
99
|
+
value: `\${${this.terraformResource.fqn}.location}`,
|
|
100
|
+
description: "The location of the Outbound Endpoint",
|
|
101
|
+
});
|
|
102
|
+
this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
|
|
103
|
+
value: `\${${this.terraformResource.fqn}.tags}`,
|
|
104
|
+
description: "The tags assigned to the Outbound Endpoint",
|
|
105
|
+
});
|
|
106
|
+
this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioning_state", {
|
|
107
|
+
value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
|
|
108
|
+
description: "The provisioning state of the Outbound Endpoint",
|
|
109
|
+
});
|
|
110
|
+
this.resourceGuidOutput = new cdktf.TerraformOutput(this, "resource_guid", {
|
|
111
|
+
value: `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,
|
|
112
|
+
description: "The unique identifier for the Outbound Endpoint",
|
|
113
|
+
});
|
|
114
|
+
// Override logical IDs to match naming convention
|
|
115
|
+
this.idOutput.overrideLogicalId("id");
|
|
116
|
+
this.nameOutput.overrideLogicalId("name");
|
|
117
|
+
this.locationOutput.overrideLogicalId("location");
|
|
118
|
+
this.tagsOutput.overrideLogicalId("tags");
|
|
119
|
+
this.provisioningStateOutput.overrideLogicalId("provisioning_state");
|
|
120
|
+
this.resourceGuidOutput.overrideLogicalId("resource_guid");
|
|
121
|
+
// Apply ignore changes if specified
|
|
122
|
+
this._applyIgnoreChanges();
|
|
123
|
+
}
|
|
124
|
+
// =============================================================================
|
|
125
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
126
|
+
// =============================================================================
|
|
127
|
+
/**
|
|
128
|
+
* Resolves the parent resource ID for the Outbound Endpoint
|
|
129
|
+
* Outbound Endpoints are child resources of DNS Resolvers
|
|
130
|
+
*/
|
|
131
|
+
resolveParentId(props) {
|
|
132
|
+
const typedProps = props;
|
|
133
|
+
return typedProps.dnsResolverId;
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Gets the default API version to use when no explicit version is specified
|
|
137
|
+
*/
|
|
138
|
+
defaultVersion() {
|
|
139
|
+
return "2022-07-01";
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Gets the Azure resource type for Outbound Endpoints
|
|
143
|
+
*/
|
|
144
|
+
resourceType() {
|
|
145
|
+
return outbound_endpoint_schemas_1.DNS_RESOLVER_OUTBOUND_ENDPOINT_TYPE;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Gets the API schema for the resolved version
|
|
149
|
+
*/
|
|
150
|
+
apiSchema() {
|
|
151
|
+
return this.resolveSchema();
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Indicates that location is required for Outbound Endpoints
|
|
155
|
+
*/
|
|
156
|
+
requiresLocation() {
|
|
157
|
+
return true;
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Creates the resource body for the Azure API call
|
|
161
|
+
*/
|
|
162
|
+
createResourceBody(props) {
|
|
163
|
+
const typedProps = props;
|
|
164
|
+
const body = {
|
|
165
|
+
location: this.location,
|
|
166
|
+
tags: this.allTags(),
|
|
167
|
+
properties: {
|
|
168
|
+
subnet: {
|
|
169
|
+
id: typedProps.subnetId,
|
|
170
|
+
},
|
|
171
|
+
},
|
|
172
|
+
};
|
|
173
|
+
return body;
|
|
174
|
+
}
|
|
175
|
+
// =============================================================================
|
|
176
|
+
// PUBLIC METHODS FOR OUTBOUND ENDPOINT OPERATIONS
|
|
177
|
+
// =============================================================================
|
|
178
|
+
/**
|
|
179
|
+
* Get the subnet ID
|
|
180
|
+
* Returns the input value as Azure API doesn't return nested subnet structure reliably
|
|
181
|
+
*/
|
|
182
|
+
get subnetId() {
|
|
183
|
+
return this.props.subnetId;
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Get the provisioning state of the Outbound Endpoint
|
|
187
|
+
*/
|
|
188
|
+
get provisioningState() {
|
|
189
|
+
return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
|
|
190
|
+
}
|
|
191
|
+
/**
|
|
192
|
+
* Get the unique identifier for the Outbound Endpoint
|
|
193
|
+
*/
|
|
194
|
+
get resourceGuid() {
|
|
195
|
+
return `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Add a tag to the Outbound Endpoint
|
|
199
|
+
*/
|
|
200
|
+
addTag(key, value) {
|
|
201
|
+
if (!this.props.tags) {
|
|
202
|
+
this.props.tags = {};
|
|
203
|
+
}
|
|
204
|
+
this.props.tags[key] = value;
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Remove a tag from the Outbound Endpoint
|
|
208
|
+
*/
|
|
209
|
+
removeTag(key) {
|
|
210
|
+
if (this.props.tags && this.props.tags[key]) {
|
|
211
|
+
delete this.props.tags[key];
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
// =============================================================================
|
|
215
|
+
// PRIVATE HELPER METHODS
|
|
216
|
+
// =============================================================================
|
|
217
|
+
/**
|
|
218
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
219
|
+
*/
|
|
220
|
+
_applyIgnoreChanges() {
|
|
221
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
222
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
223
|
+
ignore_changes: this.props.ignoreChanges,
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
exports.DnsResolverOutboundEndpoint = DnsResolverOutboundEndpoint;
|
|
229
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
230
|
+
DnsResolverOutboundEndpoint[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsResolverOutboundEndpoint", version: "1.3.0" };
|
|
231
|
+
(() => {
|
|
232
|
+
azapi_resource_1.AzapiResource.registerSchemas(outbound_endpoint_schemas_1.DNS_RESOLVER_OUTBOUND_ENDPOINT_TYPE, outbound_endpoint_schemas_1.ALL_DNS_RESOLVER_OUTBOUND_ENDPOINT_VERSIONS);
|
|
233
|
+
})();
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"outbound-endpoint.js","sourceRoot":"","sources":["../../../src/azure-dnsresolver/lib/outbound-endpoint.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure DNS Resolver Outbound Endpoint implementation using AzapiResource framework\n *\n * This class provides a unified implementation for DNS Resolver Outbound Endpoints.\n * Outbound Endpoints allow Azure resources to forward DNS queries to external DNS servers\n * such as on-premises DNS servers or other external DNS resolvers.\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\n * - JSII compliance for multi-language support\n * - Dedicated subnet requirement with delegation\n * - Used with forwarding rules for conditional DNS forwarding\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_DNS_RESOLVER_OUTBOUND_ENDPOINT_VERSIONS,\n  DNS_RESOLVER_OUTBOUND_ENDPOINT_TYPE,\n} from \"./outbound-endpoint-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 Azure DNS Resolver Outbound Endpoint\n *\n * Extends AzapiResourceProps with Outbound Endpoint specific properties\n */\nexport interface DnsResolverOutboundEndpointProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the parent DNS Resolver\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/dnsResolvers/my-resolver\"\n   */\n  readonly dnsResolverId: string;\n\n  /**\n   * Resource ID of the subnet where the Outbound Endpoint will be deployed\n   * Must be a dedicated subnet between /28 and /24 with delegation to Microsoft.Network/dnsResolvers\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/virtualNetworks/vnet/subnets/outbound-subnet\"\n   */\n  readonly subnetId: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * The resource body interface for Azure Outbound Endpoint API calls\n * This matches the Azure REST API schema\n */\nexport interface DnsResolverOutboundEndpointBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties?: any;\n}\n\n/**\n * Azure DNS Resolver Outbound Endpoint implementation\n *\n * Outbound Endpoints enable Azure resources to forward DNS queries to external DNS servers\n * (such as on-premises DNS servers). This enables hybrid DNS scenarios where Azure resources\n * need to resolve names from external DNS zones.\n *\n * Requirements:\n * - Dedicated subnet between /28 and /24\n * - Subnet must be delegated to Microsoft.Network/dnsResolvers\n * - Must be in the same VNet as the parent DNS Resolver\n * - Each DNS Resolver can have multiple outbound endpoints\n * - Outbound endpoints are used with forwarding rules to specify which queries to forward\n *\n * @example\n * // Basic outbound endpoint:\n * const outboundEndpoint = new DnsResolverOutboundEndpoint(this, \"outbound-endpoint\", {\n *   name: \"my-outbound-endpoint\",\n *   location: \"eastus\",\n *   dnsResolverId: dnsResolver.id,\n *   subnetId: outboundSubnet.id\n * });\n *\n * @example\n * // Outbound endpoint with tags:\n * const outboundEndpoint = new DnsResolverOutboundEndpoint(this, \"outbound-endpoint\", {\n *   name: \"my-outbound-endpoint\",\n *   location: \"eastus\",\n *   dnsResolverId: dnsResolver.id,\n *   subnetId: outboundSubnet.id,\n *   tags: {\n *     environment: \"production\",\n *     purpose: \"hybrid-dns\"\n *   }\n * });\n *\n * @example\n * // Outbound endpoint with version pinning:\n * const outboundEndpoint = new DnsResolverOutboundEndpoint(this, \"outbound-endpoint\", {\n *   name: \"my-outbound-endpoint\",\n *   location: \"eastus\",\n *   dnsResolverId: dnsResolver.id,\n *   subnetId: outboundSubnet.id,\n *   apiVersion: \"2022-07-01\"\n * });\n *\n * @stability stable\n */\nexport class DnsResolverOutboundEndpoint extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_RESOLVER_OUTBOUND_ENDPOINT_TYPE,\n      ALL_DNS_RESOLVER_OUTBOUND_ENDPOINT_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Outbound Endpoint instance\n   */\n  public readonly props: DnsResolverOutboundEndpointProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: 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 Resolver Outbound Endpoint 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 Outbound Endpoint\n   */\n  constructor(\n    scope: Construct,\n    id: string,\n    props: DnsResolverOutboundEndpointProps,\n  ) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Outbound Endpoint\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Outbound Endpoint\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Outbound Endpoint\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Outbound Endpoint\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description: \"The provisioning state of the Outbound Endpoint\",\n      },\n    );\n\n    this.resourceGuidOutput = new cdktf.TerraformOutput(this, \"resource_guid\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,\n      description: \"The unique identifier for the Outbound Endpoint\",\n    });\n\n    // Override logical IDs to match naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\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   * Resolves the parent resource ID for the Outbound Endpoint\n   * Outbound Endpoints are child resources of DNS Resolvers\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as DnsResolverOutboundEndpointProps;\n    return typedProps.dnsResolverId;\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 Outbound Endpoints\n   */\n  protected resourceType(): string {\n    return DNS_RESOLVER_OUTBOUND_ENDPOINT_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 Outbound Endpoints\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 DnsResolverOutboundEndpointProps;\n\n    const body: any = {\n      location: this.location!,\n      tags: this.allTags(),\n      properties: {\n        subnet: {\n          id: typedProps.subnetId,\n        },\n      },\n    };\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR OUTBOUND ENDPOINT OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subnet ID\n   * Returns the input value as Azure API doesn't return nested subnet structure reliably\n   */\n  public get subnetId(): string {\n    return this.props.subnetId;\n  }\n\n  /**\n   * Get the provisioning state of the Outbound Endpoint\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Get the unique identifier for the Outbound Endpoint\n   */\n  public get resourceGuid(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;\n  }\n\n  /**\n   * Add a tag to the Outbound Endpoint\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 Outbound Endpoint\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,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure DNS Private Resolver
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates usage of the DnsResolver construct with proper
|
|
5
|
+
* VNet and subnet configuration, and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* Key Requirements:
|
|
8
|
+
* - DNS Resolver requires a dedicated subnet
|
|
9
|
+
* - Subnet must be delegated to Microsoft.Network/dnsResolvers
|
|
10
|
+
* - Subnet must be between /28 and /24 in size
|
|
11
|
+
*
|
|
12
|
+
* Run with: npm run integration:nostream
|
|
13
|
+
*/
|
|
14
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure DNS Private Resolver
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates usage of the DnsResolver construct with proper
|
|
6
|
+
* VNet and subnet configuration, and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* Key Requirements:
|
|
9
|
+
* - DNS Resolver requires a dedicated subnet
|
|
10
|
+
* - Subnet must be delegated to Microsoft.Network/dnsResolvers
|
|
11
|
+
* - Subnet must be between /28 and /24 in size
|
|
12
|
+
*
|
|
13
|
+
* Run with: npm run integration:nostream
|
|
14
|
+
*/
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
const cdktf_1 = require("cdktf");
|
|
17
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
18
|
+
const resource_group_1 = require("../../azure-resourcegroup/lib/resource-group");
|
|
19
|
+
const subnet_1 = require("../../azure-subnet/lib/subnet");
|
|
20
|
+
const virtual_network_1 = require("../../azure-virtualnetwork/lib/virtual-network");
|
|
21
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
22
|
+
const testing_1 = require("../../testing");
|
|
23
|
+
const metadata_1 = require("../../testing/lib/metadata");
|
|
24
|
+
const dns_resolver_1 = require("../lib/dns-resolver");
|
|
25
|
+
// Generate unique test run metadata for this test suite
|
|
26
|
+
const testMetadata = new metadata_1.TestRunMetadata("dnsresolver-integration", {
|
|
27
|
+
maxAgeHours: 4,
|
|
28
|
+
});
|
|
29
|
+
/**
|
|
30
|
+
* Example stack demonstrating DNS Resolver usage
|
|
31
|
+
*/
|
|
32
|
+
class DnsResolverExampleStack extends testing_1.BaseTestStack {
|
|
33
|
+
constructor(scope, id) {
|
|
34
|
+
super(scope, id, {
|
|
35
|
+
testRunOptions: {
|
|
36
|
+
maxAgeHours: testMetadata.maxAgeHours,
|
|
37
|
+
autoCleanup: testMetadata.autoCleanup,
|
|
38
|
+
cleanupPolicy: testMetadata.cleanupPolicy,
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
// Configure AZAPI provider
|
|
42
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
43
|
+
// Generate unique names
|
|
44
|
+
const resourceGroupName = this.generateResourceName("Microsoft.Resources/resourceGroups", "dnsresolver");
|
|
45
|
+
const vnetName = this.generateResourceName("Microsoft.Network/virtualNetworks", "dnsresolver");
|
|
46
|
+
const subnetName = this.generateResourceName("Microsoft.Network/virtualNetworks/subnets", "dnsresolver");
|
|
47
|
+
const dnsResolverName = this.generateResourceName("Microsoft.Network/dnsResolvers", "dnsresolver");
|
|
48
|
+
// Create resource group
|
|
49
|
+
const resourceGroup = new resource_group_1.ResourceGroup(this, "test-rg", {
|
|
50
|
+
name: resourceGroupName,
|
|
51
|
+
location: "eastus",
|
|
52
|
+
tags: {
|
|
53
|
+
...this.systemTags(),
|
|
54
|
+
purpose: "dns-resolver-testing",
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
// Create virtual network for DNS resolver
|
|
58
|
+
const vnet = new virtual_network_1.VirtualNetwork(this, "test-vnet", {
|
|
59
|
+
name: vnetName,
|
|
60
|
+
location: "eastus",
|
|
61
|
+
resourceGroupId: resourceGroup.id,
|
|
62
|
+
addressSpace: {
|
|
63
|
+
addressPrefixes: ["10.0.0.0/16"],
|
|
64
|
+
},
|
|
65
|
+
tags: {
|
|
66
|
+
...this.systemTags(),
|
|
67
|
+
purpose: "dns-resolver-vnet",
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
// Create dedicated subnet for DNS resolver with delegation
|
|
71
|
+
// Subnet must be /28 to /24 in size and delegated to Microsoft.Network/dnsResolvers
|
|
72
|
+
const subnet = new subnet_1.Subnet(this, "dns-resolver-subnet", {
|
|
73
|
+
name: subnetName,
|
|
74
|
+
virtualNetworkName: vnetName,
|
|
75
|
+
virtualNetworkId: vnet.id,
|
|
76
|
+
resourceGroupId: resourceGroup.id,
|
|
77
|
+
addressPrefix: "10.0.1.0/28", // /28 subnet (smallest allowed)
|
|
78
|
+
delegations: [
|
|
79
|
+
{
|
|
80
|
+
name: "Microsoft.Network.dnsResolvers",
|
|
81
|
+
serviceName: "Microsoft.Network/dnsResolvers",
|
|
82
|
+
actions: ["Microsoft.Network/virtualNetworks/subnets/join/action"],
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
});
|
|
86
|
+
// Create DNS resolver with comprehensive configuration
|
|
87
|
+
// Note: Azure only allows one DNS Resolver per Virtual Network
|
|
88
|
+
new dns_resolver_1.DnsResolver(this, "dns-resolver", {
|
|
89
|
+
name: dnsResolverName,
|
|
90
|
+
location: "eastus",
|
|
91
|
+
resourceGroupId: resourceGroup.id,
|
|
92
|
+
virtualNetworkId: vnet.id,
|
|
93
|
+
tags: {
|
|
94
|
+
...this.systemTags(),
|
|
95
|
+
example: "complete",
|
|
96
|
+
environment: "test",
|
|
97
|
+
purpose: "hybrid-dns",
|
|
98
|
+
},
|
|
99
|
+
});
|
|
100
|
+
// Add dependency to ensure subnet is created before resolvers
|
|
101
|
+
// This ensures the delegation is in place
|
|
102
|
+
subnet;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
describe("DnsResolver Integration Test", () => {
|
|
106
|
+
it("should deploy DNS resolver with VNet and delegated subnet, validate idempotency, and cleanup", () => {
|
|
107
|
+
const app = cdktf_1.Testing.app();
|
|
108
|
+
const stack = new DnsResolverExampleStack(app, "test-dnsresolver");
|
|
109
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
110
|
+
// This will:
|
|
111
|
+
// 1. Run terraform apply to deploy resources (VNet, Subnet with delegation, DNS Resolver)
|
|
112
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
113
|
+
// 3. Run terraform destroy to cleanup resources
|
|
114
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
115
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
116
|
+
});
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-resolver.integ.js","sourceRoot":"","sources":["../../../src/azure-dnsresolver/test/dns-resolver.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure DNS Private Resolver\n *\n * This test demonstrates usage of the DnsResolver construct with proper\n * VNet and subnet configuration, and validates deployment, idempotency, and cleanup.\n *\n * Key Requirements:\n * - DNS Resolver requires a dedicated subnet\n * - Subnet must be delegated to Microsoft.Network/dnsResolvers\n * - Subnet must be between /28 and /24 in size\n *\n * Run with: npm run integration:nostream\n */\n\nimport { Testing } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { ResourceGroup } from \"../../azure-resourcegroup/lib/resource-group\";\nimport { Subnet } from \"../../azure-subnet/lib/subnet\";\nimport { VirtualNetwork } from \"../../azure-virtualnetwork/lib/virtual-network\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { DnsResolver } from \"../lib/dns-resolver\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\"dnsresolver-integration\", {\n  maxAgeHours: 4,\n});\n\n/**\n * Example stack demonstrating DNS Resolver usage\n */\nclass DnsResolverExampleStack extends BaseTestStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      testRunOptions: {\n        maxAgeHours: testMetadata.maxAgeHours,\n        autoCleanup: testMetadata.autoCleanup,\n        cleanupPolicy: testMetadata.cleanupPolicy,\n      },\n    });\n\n    // Configure AZAPI provider\n    new AzapiProvider(this, \"azapi\", {});\n\n    // Generate unique names\n    const resourceGroupName = this.generateResourceName(\n      \"Microsoft.Resources/resourceGroups\",\n      \"dnsresolver\",\n    );\n    const vnetName = this.generateResourceName(\n      \"Microsoft.Network/virtualNetworks\",\n      \"dnsresolver\",\n    );\n    const subnetName = this.generateResourceName(\n      \"Microsoft.Network/virtualNetworks/subnets\",\n      \"dnsresolver\",\n    );\n    const dnsResolverName = this.generateResourceName(\n      \"Microsoft.Network/dnsResolvers\",\n      \"dnsresolver\",\n    );\n\n    // Create resource group\n    const resourceGroup = new ResourceGroup(this, \"test-rg\", {\n      name: resourceGroupName,\n      location: \"eastus\",\n      tags: {\n        ...this.systemTags(),\n        purpose: \"dns-resolver-testing\",\n      },\n    });\n\n    // Create virtual network for DNS resolver\n    const vnet = new VirtualNetwork(this, \"test-vnet\", {\n      name: vnetName,\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.0.0.0/16\"],\n      },\n      tags: {\n        ...this.systemTags(),\n        purpose: \"dns-resolver-vnet\",\n      },\n    });\n\n    // Create dedicated subnet for DNS resolver with delegation\n    // Subnet must be /28 to /24 in size and delegated to Microsoft.Network/dnsResolvers\n    const subnet = new Subnet(this, \"dns-resolver-subnet\", {\n      name: subnetName,\n      virtualNetworkName: vnetName,\n      virtualNetworkId: vnet.id,\n      resourceGroupId: resourceGroup.id,\n      addressPrefix: \"10.0.1.0/28\", // /28 subnet (smallest allowed)\n      delegations: [\n        {\n          name: \"Microsoft.Network.dnsResolvers\",\n          serviceName: \"Microsoft.Network/dnsResolvers\",\n          actions: [\"Microsoft.Network/virtualNetworks/subnets/join/action\"],\n        },\n      ],\n    });\n\n    // Create DNS resolver with comprehensive configuration\n    // Note: Azure only allows one DNS Resolver per Virtual Network\n    new DnsResolver(this, \"dns-resolver\", {\n      name: dnsResolverName,\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      virtualNetworkId: vnet.id,\n      tags: {\n        ...this.systemTags(),\n        example: \"complete\",\n        environment: \"test\",\n        purpose: \"hybrid-dns\",\n      },\n    });\n\n    // Add dependency to ensure subnet is created before resolvers\n    // This ensures the delegation is in place\n    subnet;\n  }\n}\n\ndescribe(\"DnsResolver Integration Test\", () => {\n  it(\"should deploy DNS resolver with VNet and delegated subnet, validate idempotency, and cleanup\", () => {\n    const app = Testing.app();\n    const stack = new DnsResolverExampleStack(app, \"test-dnsresolver\");\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources (VNet, Subnet with delegation, DNS Resolver)\n    // 2. Run terraform plan to check idempotency (no changes expected)\n    // 3. Run terraform destroy to cleanup resources\n    TerraformApplyCheckAndDestroy(synthesized, { verifyCleanup: true });\n  }, 600000); // 10 minute timeout for deployment and cleanup\n});\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comprehensive tests for the unified DnsResolver implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the unified DnsResolver class using the
|
|
5
|
+
* VersionedAzapiResource framework. Tests cover automatic version resolution,
|
|
6
|
+
* explicit version pinning, schema validation, property transformation, and
|
|
7
|
+
* full backward compatibility.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|