@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,236 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.PolicyDefinition = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Policy Definition implementation using VersionedAzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for managing Azure Policy Definitions
|
|
10
|
+
* using the AZAPI provider. Policy definitions are deployed at subscription or management
|
|
11
|
+
* group scope and define the rules and parameters for policy enforcement.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2021-06-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
|
+
* - Support for custom policy rules and parameters
|
|
21
|
+
* - JSII compliance for multi-language support
|
|
22
|
+
*/
|
|
23
|
+
const cdktf = require("cdktf");
|
|
24
|
+
const policy_definition_schemas_1 = require("./policy-definition-schemas");
|
|
25
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
26
|
+
/**
|
|
27
|
+
* Unified Azure Policy Definition implementation
|
|
28
|
+
*
|
|
29
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
30
|
+
* Policy Definitions. It automatically handles version resolution, schema validation,
|
|
31
|
+
* and property transformation.
|
|
32
|
+
*
|
|
33
|
+
* Note: Policy definitions are deployed at subscription or management group scope.
|
|
34
|
+
* Unlike most Azure resources, they do not have a location property as they are
|
|
35
|
+
* not region-specific.
|
|
36
|
+
*
|
|
37
|
+
* @example
|
|
38
|
+
* // Basic custom policy definition:
|
|
39
|
+
* const policyDefinition = new PolicyDefinition(this, "policy", {
|
|
40
|
+
* name: "require-tag-policy",
|
|
41
|
+
* displayName: "Require tag on resources",
|
|
42
|
+
* description: "Enforces a required tag on resources",
|
|
43
|
+
* policyRule: {
|
|
44
|
+
* if: {
|
|
45
|
+
* field: "tags['Environment']",
|
|
46
|
+
* exists: "false"
|
|
47
|
+
* },
|
|
48
|
+
* then: {
|
|
49
|
+
* effect: "deny"
|
|
50
|
+
* }
|
|
51
|
+
* }
|
|
52
|
+
* });
|
|
53
|
+
*
|
|
54
|
+
* @example
|
|
55
|
+
* // Policy definition with parameters:
|
|
56
|
+
* const policyDefinition = new PolicyDefinition(this, "policy", {
|
|
57
|
+
* name: "require-tag-policy",
|
|
58
|
+
* displayName: "Require tag on resources",
|
|
59
|
+
* policyRule: {
|
|
60
|
+
* if: {
|
|
61
|
+
* field: "[concat('tags[', parameters('tagName'), ']')]",
|
|
62
|
+
* exists: "false"
|
|
63
|
+
* },
|
|
64
|
+
* then: {
|
|
65
|
+
* effect: "deny"
|
|
66
|
+
* }
|
|
67
|
+
* },
|
|
68
|
+
* parameters: {
|
|
69
|
+
* tagName: {
|
|
70
|
+
* type: "String",
|
|
71
|
+
* metadata: {
|
|
72
|
+
* displayName: "Tag Name"
|
|
73
|
+
* }
|
|
74
|
+
* }
|
|
75
|
+
* }
|
|
76
|
+
* });
|
|
77
|
+
*
|
|
78
|
+
* @stability stable
|
|
79
|
+
*/
|
|
80
|
+
class PolicyDefinition extends azapi_resource_1.AzapiResource {
|
|
81
|
+
// Public properties
|
|
82
|
+
/**
|
|
83
|
+
* Creates a new Azure Policy Definition using the VersionedAzapiResource framework
|
|
84
|
+
*
|
|
85
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
86
|
+
* validation, and resource creation.
|
|
87
|
+
*
|
|
88
|
+
* @param scope - The scope in which to define this construct
|
|
89
|
+
* @param id - The unique identifier for this instance
|
|
90
|
+
* @param props - Configuration properties for the Policy Definition
|
|
91
|
+
*/
|
|
92
|
+
constructor(scope, id, props) {
|
|
93
|
+
super(scope, id, props);
|
|
94
|
+
this.props = props;
|
|
95
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
96
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
97
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
98
|
+
value: this.id,
|
|
99
|
+
description: "The ID of the Policy Definition",
|
|
100
|
+
});
|
|
101
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
102
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
103
|
+
description: "The name of the Policy Definition",
|
|
104
|
+
});
|
|
105
|
+
// Override logical IDs to match original naming convention
|
|
106
|
+
this.idOutput.overrideLogicalId("id");
|
|
107
|
+
this.nameOutput.overrideLogicalId("name");
|
|
108
|
+
// Apply ignore changes if specified
|
|
109
|
+
this._applyIgnoreChanges();
|
|
110
|
+
}
|
|
111
|
+
// =============================================================================
|
|
112
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
113
|
+
// =============================================================================
|
|
114
|
+
/**
|
|
115
|
+
* Gets the default API version to use when no explicit version is specified
|
|
116
|
+
* Returns the most recent stable version as the default
|
|
117
|
+
*/
|
|
118
|
+
defaultVersion() {
|
|
119
|
+
return "2021-06-01";
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Gets the Azure resource type for Policy Definitions
|
|
123
|
+
*/
|
|
124
|
+
resourceType() {
|
|
125
|
+
return policy_definition_schemas_1.POLICY_DEFINITION_TYPE;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Gets the API schema for the resolved version
|
|
129
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
130
|
+
*/
|
|
131
|
+
apiSchema() {
|
|
132
|
+
return this.resolveSchema();
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Creates the resource body for the Azure API call
|
|
136
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
137
|
+
*
|
|
138
|
+
* Note: Policy definitions do not have a location property as they are
|
|
139
|
+
* subscription or management group scoped resources.
|
|
140
|
+
*/
|
|
141
|
+
createResourceBody(props) {
|
|
142
|
+
const typedProps = props;
|
|
143
|
+
return {
|
|
144
|
+
properties: {
|
|
145
|
+
displayName: typedProps.displayName,
|
|
146
|
+
description: typedProps.description,
|
|
147
|
+
policyType: typedProps.policyType || "Custom",
|
|
148
|
+
mode: typedProps.mode || "All",
|
|
149
|
+
// Deep clone policyRule to preserve all nested objects and Azure Policy expressions
|
|
150
|
+
// This ensures complex DeployIfNotExists policies with ARM templates are fully serialized
|
|
151
|
+
// Azure Policy expressions like [field()], [parameters()], [variables()] are preserved
|
|
152
|
+
policyRule: JSON.parse(JSON.stringify(typedProps.policyRule)),
|
|
153
|
+
parameters: typedProps.parameters,
|
|
154
|
+
metadata: typedProps.metadata,
|
|
155
|
+
},
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Policy Definitions do not support tags at the resource level
|
|
160
|
+
* Tags are not a valid property for Microsoft.Authorization/policyDefinitions
|
|
161
|
+
* @returns false - Policy Definitions cannot have tags
|
|
162
|
+
* @override
|
|
163
|
+
*/
|
|
164
|
+
supportsTags() {
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Customizes the AZAPI ResourceConfig for policy-specific requirements
|
|
169
|
+
*
|
|
170
|
+
* Policy definitions require special handling because:
|
|
171
|
+
* 1. They contain complex nested objects (ARM templates in DeployIfNotExists policies)
|
|
172
|
+
* 2. They use Azure Policy expressions like [field()], [parameters()], [variables()]
|
|
173
|
+
* which are NOT Terraform interpolations but Azure-native expressions
|
|
174
|
+
* 3. Schema validation may strip unknown properties from deeply nested structures
|
|
175
|
+
*
|
|
176
|
+
* @param config - The base ResourceConfig
|
|
177
|
+
* @returns Modified ResourceConfig with policy-specific settings
|
|
178
|
+
* @override
|
|
179
|
+
*/
|
|
180
|
+
customizeResourceConfig(config) {
|
|
181
|
+
return {
|
|
182
|
+
...config,
|
|
183
|
+
// Disable schema validation to preserve all nested properties
|
|
184
|
+
// Azure Policy definitions can contain deeply nested ARM templates and expressions
|
|
185
|
+
// that the AZAPI provider's schema validation may not recognize
|
|
186
|
+
schemaValidationEnabled: false,
|
|
187
|
+
// Allow properties not in the schema to prevent stripping of nested content
|
|
188
|
+
// This is essential for DeployIfNotExists policies with ARM template deployments
|
|
189
|
+
ignoreMissingProperty: true,
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
// =============================================================================
|
|
193
|
+
// PUBLIC METHODS FOR POLICY DEFINITION OPERATIONS
|
|
194
|
+
// =============================================================================
|
|
195
|
+
/**
|
|
196
|
+
* Get the full resource identifier for use in other Azure resources
|
|
197
|
+
* Alias for the id property
|
|
198
|
+
*/
|
|
199
|
+
get resourceId() {
|
|
200
|
+
return this.id;
|
|
201
|
+
}
|
|
202
|
+
/**
|
|
203
|
+
* Get the policy type
|
|
204
|
+
*/
|
|
205
|
+
get policyType() {
|
|
206
|
+
return this.props.policyType || "Custom";
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Get the policy mode
|
|
210
|
+
*/
|
|
211
|
+
get policyMode() {
|
|
212
|
+
return this.props.mode || "All";
|
|
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
|
+
{
|
|
224
|
+
ignore_changes: this.props.ignoreChanges,
|
|
225
|
+
},
|
|
226
|
+
]);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
exports.PolicyDefinition = PolicyDefinition;
|
|
231
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
232
|
+
PolicyDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyDefinition", version: "1.3.1" };
|
|
233
|
+
(() => {
|
|
234
|
+
azapi_resource_1.AzapiResource.registerSchemas(policy_definition_schemas_1.POLICY_DEFINITION_TYPE, policy_definition_schemas_1.ALL_POLICY_DEFINITION_VERSIONS);
|
|
235
|
+
})();
|
|
236
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-definition.js","sourceRoot":"","sources":["../../../src/azure-policydefinition/lib/policy-definition.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;GAgBG;AAEH,+BAA+B;AAE/B,2EAGqC;AACrC,8EAGmD;AAkJnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqDG;AACH,MAAa,gBAAiB,SAAQ,8BAAa;IAiBjD,oBAAoB;IAEpB;;;;;;;;;OASG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA4B;QACpE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,mFAAmF;QAEnF,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,iCAAiC;SAC/C,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,mCAAmC;SACjD,CAAC,CAAC;QAEH,2DAA2D;QAC3D,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE1C,oCAAoC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gFAAgF;IAChF,+CAA+C;IAC/C,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,kDAAsB,CAAC;IAChC,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;;;;;OAMG;IACO,kBAAkB,CAAC,KAAU;QACrC,MAAM,UAAU,GAAG,KAA8B,CAAC;QAClD,OAAO;YACL,UAAU,EAAE;gBACV,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,UAAU,EAAE,UAAU,CAAC,UAAU,IAAI,QAAQ;gBAC7C,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,KAAK;gBAC9B,oFAAoF;gBACpF,0FAA0F;gBAC1F,uFAAuF;gBACvF,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;gBAC7D,UAAU,EAAE,UAAU,CAAC,UAAU;gBACjC,QAAQ,EAAE,UAAU,CAAC,QAAQ;aAC9B;SACF,CAAC;IACJ,CAAC;IAED;;;;;OAKG;IACO,YAAY;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;;;;;;;;OAYG;IACO,uBAAuB,CAAC,MAAW;QAC3C,OAAO;YACL,GAAG,MAAM;YACT,8DAA8D;YAC9D,mFAAmF;YACnF,gEAAgE;YAChE,uBAAuB,EAAE,KAAK;YAC9B,4EAA4E;YAC5E,iFAAiF;YACjF,qBAAqB,EAAE,IAAI;SAC5B,CAAC;IACJ,CAAC;IAED,gFAAgF;IAChF,kDAAkD;IAClD,gFAAgF;IAEhF;;;OAGG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,IAAI,QAAQ,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC;IAClC,CAAC;IAED,gFAAgF;IAChF,yBAAyB;IACzB,gFAAgF;IAEhF;;OAEG;IACK,mBAAmB;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,WAAW,EAAE;gBAC9C;oBACE,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;iBACzC;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAxLH,4CAyLC;;;AAxLC;IACE,8BAAa,CAAC,eAAe,CAC3B,kDAAsB,EACtB,0DAA8B,CAC/B,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Unified Azure Policy Definition implementation using VersionedAzapiResource framework\n *\n * This class provides a version-aware implementation for managing Azure Policy Definitions\n * using the AZAPI provider. Policy definitions are deployed at subscription or management\n * group scope and define the rules and parameters for policy enforcement.\n *\n * Supported API Versions:\n * - 2021-06-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 * - Support for custom policy rules and parameters\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_POLICY_DEFINITION_VERSIONS,\n  POLICY_DEFINITION_TYPE,\n} from \"./policy-definition-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 Policy Definition\n *\n * Extends AzapiResourceProps with Policy Definition specific properties\n */\nexport interface PolicyDefinitionProps extends AzapiResourceProps {\n  /**\n   * The display name of the policy definition\n   * Provides a human-readable name for the policy\n   *\n   * @example \"Require tag and its value on resources\"\n   */\n  readonly displayName?: string;\n\n  /**\n   * The policy definition description\n   * Provides detailed information about what the policy enforces\n   *\n   * @example \"Enforces a required tag and its value on resources\"\n   */\n  readonly description?: string;\n\n  /**\n   * The type of policy definition\n   * @default \"Custom\"\n   * @example \"Custom\", \"BuiltIn\", \"Static\", \"NotSpecified\"\n   */\n  readonly policyType?: string;\n\n  /**\n   * The policy mode\n   * Determines which resource types will be evaluated\n   * @default \"All\"\n   * @example \"All\", \"Indexed\", \"Microsoft.KeyVault.Data\"\n   */\n  readonly mode?: string;\n\n  /**\n   * The policy rule as a JSON object\n   * Defines the if/then logic that determines policy enforcement\n   * This is required for all policy definitions\n   *\n   * @example\n   * {\n   *   if: {\n   *     field: \"tags['Environment']\",\n   *     exists: \"false\"\n   *   },\n   *   then: {\n   *     effect: \"deny\"\n   *   }\n   * }\n   */\n  readonly policyRule: any;\n\n  /**\n   * Parameters for the policy definition\n   * Allows policy assignments to provide values that are used in the policy rule\n   *\n   * @example\n   * {\n   *   tagName: {\n   *     type: \"String\",\n   *     metadata: {\n   *       displayName: \"Tag Name\",\n   *       description: \"Name of the tag to enforce\"\n   *     }\n   *   }\n   * }\n   */\n  readonly parameters?: any;\n\n  /**\n   * Metadata for the policy definition\n   * Used to store additional information like category, version, etc.\n   *\n   * @example\n   * {\n   *   category: \"Tags\",\n   *   version: \"1.0.0\"\n   * }\n   */\n  readonly metadata?: any;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"metadata\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties interface for Azure Policy Definition\n * This is required for JSII compliance to support multi-language code generation\n */\nexport interface PolicyDefinitionProperties {\n  /**\n   * The display name of the policy definition\n   */\n  readonly displayName?: string;\n\n  /**\n   * The policy definition description\n   */\n  readonly description?: string;\n\n  /**\n   * The type of policy definition\n   */\n  readonly policyType?: string;\n\n  /**\n   * The policy mode\n   */\n  readonly mode?: string;\n\n  /**\n   * The policy rule object\n   */\n  readonly policyRule: any;\n\n  /**\n   * Parameters for the policy definition\n   */\n  readonly parameters?: any;\n\n  /**\n   * Metadata for the policy definition\n   */\n  readonly metadata?: any;\n}\n\n/**\n * The resource body interface for Azure Policy Definition API calls\n * This matches the Azure REST API schema for policy definitions\n */\nexport interface PolicyDefinitionBody {\n  /**\n   * The properties of the policy definition\n   */\n  readonly properties: PolicyDefinitionProperties;\n}\n\n/**\n * Unified Azure Policy Definition implementation\n *\n * This class provides a single, version-aware implementation for managing Azure\n * Policy Definitions. It automatically handles version resolution, schema validation,\n * and property transformation.\n *\n * Note: Policy definitions are deployed at subscription or management group scope.\n * Unlike most Azure resources, they do not have a location property as they are\n * not region-specific.\n *\n * @example\n * // Basic custom policy definition:\n * const policyDefinition = new PolicyDefinition(this, \"policy\", {\n *   name: \"require-tag-policy\",\n *   displayName: \"Require tag on resources\",\n *   description: \"Enforces a required tag on resources\",\n *   policyRule: {\n *     if: {\n *       field: \"tags['Environment']\",\n *       exists: \"false\"\n *     },\n *     then: {\n *       effect: \"deny\"\n *     }\n *   }\n * });\n *\n * @example\n * // Policy definition with parameters:\n * const policyDefinition = new PolicyDefinition(this, \"policy\", {\n *   name: \"require-tag-policy\",\n *   displayName: \"Require tag on resources\",\n *   policyRule: {\n *     if: {\n *       field: \"[concat('tags[', parameters('tagName'), ']')]\",\n *       exists: \"false\"\n *     },\n *     then: {\n *       effect: \"deny\"\n *     }\n *   },\n *   parameters: {\n *     tagName: {\n *       type: \"String\",\n *       metadata: {\n *         displayName: \"Tag Name\"\n *       }\n *     }\n *   }\n * });\n *\n * @stability stable\n */\nexport class PolicyDefinition extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      POLICY_DEFINITION_TYPE,\n      ALL_POLICY_DEFINITION_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Policy Definition instance\n   */\n  public readonly props: PolicyDefinitionProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n\n  // Public properties\n\n  /**\n   * Creates a new Azure Policy Definition using the VersionedAzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\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 Policy Definition\n   */\n  constructor(scope: Construct, id: string, props: PolicyDefinitionProps) {\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 Policy Definition\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Policy Definition\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\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   * Returns the most recent stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2021-06-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Policy Definitions\n   */\n  protected resourceType(): string {\n    return POLICY_DEFINITION_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   * Transforms the input properties into the JSON format expected by Azure REST API\n   *\n   * Note: Policy definitions do not have a location property as they are\n   * subscription or management group scoped resources.\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as PolicyDefinitionProps;\n    return {\n      properties: {\n        displayName: typedProps.displayName,\n        description: typedProps.description,\n        policyType: typedProps.policyType || \"Custom\",\n        mode: typedProps.mode || \"All\",\n        // Deep clone policyRule to preserve all nested objects and Azure Policy expressions\n        // This ensures complex DeployIfNotExists policies with ARM templates are fully serialized\n        // Azure Policy expressions like [field()], [parameters()], [variables()] are preserved\n        policyRule: JSON.parse(JSON.stringify(typedProps.policyRule)),\n        parameters: typedProps.parameters,\n        metadata: typedProps.metadata,\n      },\n    };\n  }\n\n  /**\n   * Policy Definitions do not support tags at the resource level\n   * Tags are not a valid property for Microsoft.Authorization/policyDefinitions\n   * @returns false - Policy Definitions cannot have tags\n   * @override\n   */\n  protected supportsTags(): boolean {\n    return false;\n  }\n\n  /**\n   * Customizes the AZAPI ResourceConfig for policy-specific requirements\n   *\n   * Policy definitions require special handling because:\n   * 1. They contain complex nested objects (ARM templates in DeployIfNotExists policies)\n   * 2. They use Azure Policy expressions like [field()], [parameters()], [variables()]\n   *    which are NOT Terraform interpolations but Azure-native expressions\n   * 3. Schema validation may strip unknown properties from deeply nested structures\n   *\n   * @param config - The base ResourceConfig\n   * @returns Modified ResourceConfig with policy-specific settings\n   * @override\n   */\n  protected customizeResourceConfig(config: any): any {\n    return {\n      ...config,\n      // Disable schema validation to preserve all nested properties\n      // Azure Policy definitions can contain deeply nested ARM templates and expressions\n      // that the AZAPI provider's schema validation may not recognize\n      schemaValidationEnabled: false,\n      // Allow properties not in the schema to prevent stripping of nested content\n      // This is essential for DeployIfNotExists policies with ARM template deployments\n      ignoreMissingProperty: true,\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR POLICY DEFINITION OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Get the policy type\n   */\n  public get policyType(): string {\n    return this.props.policyType || \"Custom\";\n  }\n\n  /**\n   * Get the policy mode\n   */\n  public get policyMode(): string {\n    return this.props.mode || \"All\";\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", [\n        {\n          ignore_changes: this.props.ignoreChanges,\n        },\n      ]);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Policy Definition
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the PolicyDefinition construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* Run with: npm run integration:nostream
|
|
8
|
+
*/
|
|
9
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Policy Definition
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the PolicyDefinition construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* Run with: npm run integration:nostream
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
const cdktf_1 = require("cdktf");
|
|
12
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
13
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
14
|
+
const testing_1 = require("../../testing");
|
|
15
|
+
const metadata_1 = require("../../testing/lib/metadata");
|
|
16
|
+
const policy_definition_1 = require("../lib/policy-definition");
|
|
17
|
+
// Generate unique test run metadata for this test suite
|
|
18
|
+
const testMetadata = new metadata_1.TestRunMetadata("policy-definition-integration", {
|
|
19
|
+
maxAgeHours: 4,
|
|
20
|
+
});
|
|
21
|
+
/**
|
|
22
|
+
* Example stack demonstrating Policy Definition usage
|
|
23
|
+
*/
|
|
24
|
+
class PolicyDefinitionExampleStack extends testing_1.BaseTestStack {
|
|
25
|
+
constructor(scope, id) {
|
|
26
|
+
super(scope, id, {
|
|
27
|
+
testRunOptions: {
|
|
28
|
+
maxAgeHours: testMetadata.maxAgeHours,
|
|
29
|
+
autoCleanup: testMetadata.autoCleanup,
|
|
30
|
+
cleanupPolicy: testMetadata.cleanupPolicy,
|
|
31
|
+
},
|
|
32
|
+
});
|
|
33
|
+
// Configure AZAPI provider
|
|
34
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
35
|
+
// Generate unique names for policy definitions
|
|
36
|
+
const basicPolicyName = this.generateResourceName("Microsoft.Authorization/policyDefinitions", "basic");
|
|
37
|
+
const parameterizedPolicyName = this.generateResourceName("Microsoft.Authorization/policyDefinitions", "param");
|
|
38
|
+
// Example 1: Basic policy definition that denies resources without required tags
|
|
39
|
+
new policy_definition_1.PolicyDefinition(this, "basic-policy", {
|
|
40
|
+
name: basicPolicyName,
|
|
41
|
+
displayName: "Require Environment Tag",
|
|
42
|
+
description: "This policy ensures that resources have an Environment tag",
|
|
43
|
+
policyType: "Custom",
|
|
44
|
+
mode: "Indexed",
|
|
45
|
+
policyRule: {
|
|
46
|
+
if: {
|
|
47
|
+
field: "tags['Environment']",
|
|
48
|
+
exists: "false",
|
|
49
|
+
},
|
|
50
|
+
then: {
|
|
51
|
+
effect: "deny",
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
metadata: {
|
|
55
|
+
category: "Tags",
|
|
56
|
+
version: "1.0.0",
|
|
57
|
+
},
|
|
58
|
+
tags: {
|
|
59
|
+
...this.systemTags(),
|
|
60
|
+
example: "basic",
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
// Example 2: Policy definition with parameters for flexible enforcement
|
|
64
|
+
new policy_definition_1.PolicyDefinition(this, "parameterized-policy", {
|
|
65
|
+
name: parameterizedPolicyName,
|
|
66
|
+
displayName: "Require Specific Tag with Allowed Values",
|
|
67
|
+
description: "This policy ensures that resources have a specific tag with a value from an allowed list",
|
|
68
|
+
policyType: "Custom",
|
|
69
|
+
mode: "All",
|
|
70
|
+
policyRule: {
|
|
71
|
+
if: {
|
|
72
|
+
allOf: [
|
|
73
|
+
{
|
|
74
|
+
field: "[concat('tags[', parameters('tagName'), ']')]",
|
|
75
|
+
exists: "true",
|
|
76
|
+
},
|
|
77
|
+
{
|
|
78
|
+
field: "[concat('tags[', parameters('tagName'), ']')]",
|
|
79
|
+
notIn: "[parameters('allowedValues')]",
|
|
80
|
+
},
|
|
81
|
+
],
|
|
82
|
+
},
|
|
83
|
+
then: {
|
|
84
|
+
effect: "[parameters('effect')]",
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
parameters: {
|
|
88
|
+
tagName: {
|
|
89
|
+
type: "String",
|
|
90
|
+
metadata: {
|
|
91
|
+
displayName: "Tag Name",
|
|
92
|
+
description: "Name of the tag to check",
|
|
93
|
+
},
|
|
94
|
+
defaultValue: "CostCenter",
|
|
95
|
+
},
|
|
96
|
+
allowedValues: {
|
|
97
|
+
type: "Array",
|
|
98
|
+
metadata: {
|
|
99
|
+
displayName: "Allowed Tag Values",
|
|
100
|
+
description: "List of allowed values for the tag",
|
|
101
|
+
},
|
|
102
|
+
defaultValue: ["Engineering", "Marketing", "Operations"],
|
|
103
|
+
},
|
|
104
|
+
effect: {
|
|
105
|
+
type: "String",
|
|
106
|
+
metadata: {
|
|
107
|
+
displayName: "Effect",
|
|
108
|
+
description: "The effect of the policy (audit or deny)",
|
|
109
|
+
},
|
|
110
|
+
allowedValues: ["audit", "deny"],
|
|
111
|
+
defaultValue: "audit",
|
|
112
|
+
},
|
|
113
|
+
},
|
|
114
|
+
metadata: {
|
|
115
|
+
category: "Tags",
|
|
116
|
+
version: "1.0.0",
|
|
117
|
+
},
|
|
118
|
+
tags: {
|
|
119
|
+
...this.systemTags(),
|
|
120
|
+
example: "parameterized",
|
|
121
|
+
},
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
describe("Policy Definition Integration Test", () => {
|
|
126
|
+
it("should deploy, validate idempotency, and cleanup policy definition resources", () => {
|
|
127
|
+
const app = cdktf_1.Testing.app();
|
|
128
|
+
const stack = new PolicyDefinitionExampleStack(app, "test-policy-definition");
|
|
129
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
130
|
+
// This will:
|
|
131
|
+
// 1. Run terraform apply to deploy resources
|
|
132
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
133
|
+
// 3. Run terraform destroy to cleanup resources
|
|
134
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
135
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
136
|
+
});
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-definition.integ.js","sourceRoot":"","sources":["../../../src/azure-policydefinition/test/policy-definition.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Policy Definition\n *\n * This test demonstrates basic usage of the PolicyDefinition construct\n * and validates deployment, idempotency, and cleanup.\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 { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { PolicyDefinition } from \"../lib/policy-definition\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\"policy-definition-integration\", {\n  maxAgeHours: 4,\n});\n\n/**\n * Example stack demonstrating Policy Definition usage\n */\nclass PolicyDefinitionExampleStack 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 for policy definitions\n    const basicPolicyName = this.generateResourceName(\n      \"Microsoft.Authorization/policyDefinitions\",\n      \"basic\",\n    );\n    const parameterizedPolicyName = this.generateResourceName(\n      \"Microsoft.Authorization/policyDefinitions\",\n      \"param\",\n    );\n\n    // Example 1: Basic policy definition that denies resources without required tags\n    new PolicyDefinition(this, \"basic-policy\", {\n      name: basicPolicyName,\n      displayName: \"Require Environment Tag\",\n      description: \"This policy ensures that resources have an Environment tag\",\n      policyType: \"Custom\",\n      mode: \"Indexed\",\n      policyRule: {\n        if: {\n          field: \"tags['Environment']\",\n          exists: \"false\",\n        },\n        then: {\n          effect: \"deny\",\n        },\n      },\n      metadata: {\n        category: \"Tags\",\n        version: \"1.0.0\",\n      },\n      tags: {\n        ...this.systemTags(),\n        example: \"basic\",\n      },\n    });\n\n    // Example 2: Policy definition with parameters for flexible enforcement\n    new PolicyDefinition(this, \"parameterized-policy\", {\n      name: parameterizedPolicyName,\n      displayName: \"Require Specific Tag with Allowed Values\",\n      description:\n        \"This policy ensures that resources have a specific tag with a value from an allowed list\",\n      policyType: \"Custom\",\n      mode: \"All\",\n      policyRule: {\n        if: {\n          allOf: [\n            {\n              field: \"[concat('tags[', parameters('tagName'), ']')]\",\n              exists: \"true\",\n            },\n            {\n              field: \"[concat('tags[', parameters('tagName'), ']')]\",\n              notIn: \"[parameters('allowedValues')]\",\n            },\n          ],\n        },\n        then: {\n          effect: \"[parameters('effect')]\",\n        },\n      },\n      parameters: {\n        tagName: {\n          type: \"String\",\n          metadata: {\n            displayName: \"Tag Name\",\n            description: \"Name of the tag to check\",\n          },\n          defaultValue: \"CostCenter\",\n        },\n        allowedValues: {\n          type: \"Array\",\n          metadata: {\n            displayName: \"Allowed Tag Values\",\n            description: \"List of allowed values for the tag\",\n          },\n          defaultValue: [\"Engineering\", \"Marketing\", \"Operations\"],\n        },\n        effect: {\n          type: \"String\",\n          metadata: {\n            displayName: \"Effect\",\n            description: \"The effect of the policy (audit or deny)\",\n          },\n          allowedValues: [\"audit\", \"deny\"],\n          defaultValue: \"audit\",\n        },\n      },\n      metadata: {\n        category: \"Tags\",\n        version: \"1.0.0\",\n      },\n      tags: {\n        ...this.systemTags(),\n        example: \"parameterized\",\n      },\n    });\n  }\n}\n\ndescribe(\"Policy Definition Integration Test\", () => {\n  it(\"should deploy, validate idempotency, and cleanup policy definition resources\", () => {\n    const app = Testing.app();\n    const stack = new PolicyDefinitionExampleStack(\n      app,\n      \"test-policy-definition\",\n    );\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources\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 PolicyDefinition implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the unified PolicyDefinition class that uses
|
|
5
|
+
* the VersionedAzapiResource framework. Tests cover automatic version resolution,
|
|
6
|
+
* explicit version pinning, schema validation, property transformation, and
|
|
7
|
+
* policy-specific functionality.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|