@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,342 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Azure Policy Assignment implementation using VersionedAzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a version-aware implementation for managing Azure Policy Assignments
|
|
5
|
+
* using the AZAPI provider. Policy assignments apply policy definitions to specific scopes
|
|
6
|
+
* (subscription, resource group, or resource) and can provide parameter values and
|
|
7
|
+
* enforcement settings.
|
|
8
|
+
*
|
|
9
|
+
* Supported API Versions:
|
|
10
|
+
* - 2022-06-01 (Active, Latest)
|
|
11
|
+
*
|
|
12
|
+
* Features:
|
|
13
|
+
* - Automatic latest version resolution when no version is specified
|
|
14
|
+
* - Explicit version pinning for stability requirements
|
|
15
|
+
* - Schema-driven validation and transformation
|
|
16
|
+
* - Support for enforcement modes (Default, DoNotEnforce)
|
|
17
|
+
* - Managed identity support for remediation policies
|
|
18
|
+
* - Custom non-compliance messages
|
|
19
|
+
* - Scope exclusions (notScopes)
|
|
20
|
+
* - JSII compliance for multi-language support
|
|
21
|
+
*/
|
|
22
|
+
import * as cdktf from "cdktf";
|
|
23
|
+
import { Construct } from "constructs";
|
|
24
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
25
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
26
|
+
/**
|
|
27
|
+
* Identity configuration for policy assignments
|
|
28
|
+
* Required for policies with deployIfNotExists or modify effects
|
|
29
|
+
*/
|
|
30
|
+
export interface PolicyAssignmentIdentity {
|
|
31
|
+
/**
|
|
32
|
+
* The type of managed identity
|
|
33
|
+
* @example "SystemAssigned", "UserAssigned", "None"
|
|
34
|
+
*/
|
|
35
|
+
readonly type: string;
|
|
36
|
+
/**
|
|
37
|
+
* The user assigned identities associated with the policy assignment
|
|
38
|
+
* Required when type is UserAssigned
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* {
|
|
42
|
+
* "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.ManagedIdentity/userAssignedIdentities/identity": {}
|
|
43
|
+
* }
|
|
44
|
+
*/
|
|
45
|
+
readonly userAssignedIdentities?: {
|
|
46
|
+
[key: string]: any;
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Non-compliance message configuration
|
|
51
|
+
*/
|
|
52
|
+
export interface PolicyAssignmentNonComplianceMessage {
|
|
53
|
+
/**
|
|
54
|
+
* The non-compliance message for the policy assignment
|
|
55
|
+
*/
|
|
56
|
+
readonly message: string;
|
|
57
|
+
/**
|
|
58
|
+
* The policy definition reference ID within a policy set definition
|
|
59
|
+
* Optional - if specified, this message applies only to the specified policy within the set
|
|
60
|
+
*/
|
|
61
|
+
readonly policyDefinitionReferenceId?: string;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Properties for the unified Azure Policy Assignment
|
|
65
|
+
*
|
|
66
|
+
* Extends AzapiResourceProps with Policy Assignment specific properties
|
|
67
|
+
*/
|
|
68
|
+
export interface PolicyAssignmentProps extends AzapiResourceProps {
|
|
69
|
+
/**
|
|
70
|
+
* The policy definition ID to assign
|
|
71
|
+
* This can be a built-in or custom policy definition
|
|
72
|
+
* Required property
|
|
73
|
+
*
|
|
74
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/policy-name"
|
|
75
|
+
* @example "/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d" (built-in)
|
|
76
|
+
*/
|
|
77
|
+
readonly policyDefinitionId: string;
|
|
78
|
+
/**
|
|
79
|
+
* The scope at which the policy assignment is applied
|
|
80
|
+
* Can be a subscription, resource group, or resource
|
|
81
|
+
* Required property
|
|
82
|
+
*
|
|
83
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000"
|
|
84
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name"
|
|
85
|
+
*/
|
|
86
|
+
readonly scope: string;
|
|
87
|
+
/**
|
|
88
|
+
* The display name of the policy assignment
|
|
89
|
+
* Provides a human-readable name for the assignment
|
|
90
|
+
*
|
|
91
|
+
* @example "Require tag on resources in production"
|
|
92
|
+
*/
|
|
93
|
+
readonly displayName?: string;
|
|
94
|
+
/**
|
|
95
|
+
* The policy assignment description
|
|
96
|
+
* Provides detailed information about the assignment
|
|
97
|
+
*
|
|
98
|
+
* @example "Enforces required tags on all resources in production environment"
|
|
99
|
+
*/
|
|
100
|
+
readonly description?: string;
|
|
101
|
+
/**
|
|
102
|
+
* The enforcement mode of the policy assignment
|
|
103
|
+
* @default "Default"
|
|
104
|
+
* @example "Default" - Policy effect is enforced during resource creation/update
|
|
105
|
+
* @example "DoNotEnforce" - Policy effect is not enforced (audit only)
|
|
106
|
+
*/
|
|
107
|
+
readonly enforcementMode?: string;
|
|
108
|
+
/**
|
|
109
|
+
* Parameters for the policy assignment
|
|
110
|
+
* Provides values for parameters defined in the policy definition
|
|
111
|
+
*
|
|
112
|
+
* @example
|
|
113
|
+
* {
|
|
114
|
+
* tagName: {
|
|
115
|
+
* value: "Environment"
|
|
116
|
+
* },
|
|
117
|
+
* tagValue: {
|
|
118
|
+
* value: "Production"
|
|
119
|
+
* }
|
|
120
|
+
* }
|
|
121
|
+
*/
|
|
122
|
+
readonly parameters?: any;
|
|
123
|
+
/**
|
|
124
|
+
* Metadata for the policy assignment
|
|
125
|
+
* Used to store additional information like assignedBy, parameterScopes, etc.
|
|
126
|
+
*
|
|
127
|
+
* @example
|
|
128
|
+
* {
|
|
129
|
+
* assignedBy: "admin@example.com",
|
|
130
|
+
* parameterScopes: {}
|
|
131
|
+
* }
|
|
132
|
+
*/
|
|
133
|
+
readonly metadata?: any;
|
|
134
|
+
/**
|
|
135
|
+
* The managed identity associated with the policy assignment
|
|
136
|
+
* Required for policies with deployIfNotExists or modify effects
|
|
137
|
+
*
|
|
138
|
+
* @example
|
|
139
|
+
* {
|
|
140
|
+
* type: "SystemAssigned"
|
|
141
|
+
* }
|
|
142
|
+
*/
|
|
143
|
+
readonly identity?: PolicyAssignmentIdentity;
|
|
144
|
+
/**
|
|
145
|
+
* The policy's excluded scopes
|
|
146
|
+
* Resources within these scopes will not be evaluated by the policy
|
|
147
|
+
*
|
|
148
|
+
* @example ["/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/excluded-rg"]
|
|
149
|
+
*/
|
|
150
|
+
readonly notScopes?: string[];
|
|
151
|
+
/**
|
|
152
|
+
* The non-compliance messages for the policy assignment
|
|
153
|
+
* Provides custom messages when resources are non-compliant
|
|
154
|
+
*
|
|
155
|
+
* @example
|
|
156
|
+
* [
|
|
157
|
+
* {
|
|
158
|
+
* message: "Resource must have the Environment tag"
|
|
159
|
+
* }
|
|
160
|
+
* ]
|
|
161
|
+
*/
|
|
162
|
+
readonly nonComplianceMessages?: PolicyAssignmentNonComplianceMessage[];
|
|
163
|
+
/**
|
|
164
|
+
* The lifecycle rules to ignore changes
|
|
165
|
+
* @example ["metadata"]
|
|
166
|
+
*/
|
|
167
|
+
readonly ignoreChanges?: string[];
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Properties interface for Azure Policy Assignment
|
|
171
|
+
* This is required for JSII compliance to support multi-language code generation
|
|
172
|
+
*/
|
|
173
|
+
export interface PolicyAssignmentProperties {
|
|
174
|
+
/**
|
|
175
|
+
* The policy definition ID
|
|
176
|
+
*/
|
|
177
|
+
readonly policyDefinitionId: string;
|
|
178
|
+
/**
|
|
179
|
+
* The scope of the policy assignment
|
|
180
|
+
*/
|
|
181
|
+
readonly scope: string;
|
|
182
|
+
/**
|
|
183
|
+
* The display name of the policy assignment
|
|
184
|
+
*/
|
|
185
|
+
readonly displayName?: string;
|
|
186
|
+
/**
|
|
187
|
+
* The policy assignment description
|
|
188
|
+
*/
|
|
189
|
+
readonly description?: string;
|
|
190
|
+
/**
|
|
191
|
+
* The enforcement mode
|
|
192
|
+
*/
|
|
193
|
+
readonly enforcementMode?: string;
|
|
194
|
+
/**
|
|
195
|
+
* Parameters for the policy assignment
|
|
196
|
+
*/
|
|
197
|
+
readonly parameters?: any;
|
|
198
|
+
/**
|
|
199
|
+
* Metadata for the policy assignment
|
|
200
|
+
*/
|
|
201
|
+
readonly metadata?: any;
|
|
202
|
+
/**
|
|
203
|
+
* The policy's excluded scopes
|
|
204
|
+
*/
|
|
205
|
+
readonly notScopes?: string[];
|
|
206
|
+
/**
|
|
207
|
+
* The non-compliance messages
|
|
208
|
+
*/
|
|
209
|
+
readonly nonComplianceMessages?: PolicyAssignmentNonComplianceMessage[];
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* The resource body interface for Azure Policy Assignment API calls
|
|
213
|
+
* This matches the Azure REST API schema for policy assignments
|
|
214
|
+
*/
|
|
215
|
+
export interface PolicyAssignmentBody {
|
|
216
|
+
/**
|
|
217
|
+
* The properties of the policy assignment
|
|
218
|
+
*/
|
|
219
|
+
readonly properties: PolicyAssignmentProperties;
|
|
220
|
+
/**
|
|
221
|
+
* The managed identity associated with the policy assignment
|
|
222
|
+
*/
|
|
223
|
+
readonly identity?: PolicyAssignmentIdentity;
|
|
224
|
+
}
|
|
225
|
+
/**
|
|
226
|
+
* Unified Azure Policy Assignment implementation
|
|
227
|
+
*
|
|
228
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
229
|
+
* Policy Assignments. It automatically handles version resolution, schema validation,
|
|
230
|
+
* and property transformation.
|
|
231
|
+
*
|
|
232
|
+
* Note: Policy assignments can be deployed at subscription, resource group, or resource scope.
|
|
233
|
+
* Like policy definitions, they do not have a location property as they are not region-specific.
|
|
234
|
+
*
|
|
235
|
+
* @example
|
|
236
|
+
* // Basic policy assignment:
|
|
237
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
238
|
+
* name: "require-tag-assignment",
|
|
239
|
+
* policyDefinitionId: policyDefinition.id,
|
|
240
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name",
|
|
241
|
+
* displayName: "Require tag on resources",
|
|
242
|
+
* description: "Enforces required tags on resources"
|
|
243
|
+
* });
|
|
244
|
+
*
|
|
245
|
+
* @example
|
|
246
|
+
* // Policy assignment with parameters:
|
|
247
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
248
|
+
* name: "require-tag-assignment",
|
|
249
|
+
* policyDefinitionId: policyDefinition.id,
|
|
250
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
251
|
+
* parameters: {
|
|
252
|
+
* tagName: {
|
|
253
|
+
* value: "Environment"
|
|
254
|
+
* },
|
|
255
|
+
* tagValue: {
|
|
256
|
+
* value: "Production"
|
|
257
|
+
* }
|
|
258
|
+
* }
|
|
259
|
+
* });
|
|
260
|
+
*
|
|
261
|
+
* @example
|
|
262
|
+
* // Policy assignment with managed identity:
|
|
263
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
264
|
+
* name: "deploy-monitoring-assignment",
|
|
265
|
+
* policyDefinitionId: "/providers/Microsoft.Authorization/policyDefinitions/policy-id",
|
|
266
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
267
|
+
* identity: {
|
|
268
|
+
* type: "SystemAssigned"
|
|
269
|
+
* }
|
|
270
|
+
* });
|
|
271
|
+
*
|
|
272
|
+
* @stability stable
|
|
273
|
+
*/
|
|
274
|
+
export declare class PolicyAssignment extends AzapiResource {
|
|
275
|
+
/**
|
|
276
|
+
* The input properties for this Policy Assignment instance
|
|
277
|
+
*/
|
|
278
|
+
readonly props: PolicyAssignmentProps;
|
|
279
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
280
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
281
|
+
/**
|
|
282
|
+
* Creates a new Azure Policy Assignment using the VersionedAzapiResource framework
|
|
283
|
+
*
|
|
284
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
285
|
+
* validation, and resource creation.
|
|
286
|
+
*
|
|
287
|
+
* @param scope - The scope in which to define this construct
|
|
288
|
+
* @param id - The unique identifier for this instance
|
|
289
|
+
* @param props - Configuration properties for the Policy Assignment
|
|
290
|
+
*/
|
|
291
|
+
constructor(scope: Construct, id: string, props: PolicyAssignmentProps);
|
|
292
|
+
/**
|
|
293
|
+
* Gets the default API version to use when no explicit version is specified
|
|
294
|
+
* Returns the most recent stable version as the default
|
|
295
|
+
*/
|
|
296
|
+
protected defaultVersion(): string;
|
|
297
|
+
/**
|
|
298
|
+
* Gets the Azure resource type for Policy Assignments
|
|
299
|
+
*/
|
|
300
|
+
protected resourceType(): string;
|
|
301
|
+
/**
|
|
302
|
+
* Gets the API schema for the resolved version
|
|
303
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
304
|
+
*/
|
|
305
|
+
protected apiSchema(): ApiSchema;
|
|
306
|
+
/**
|
|
307
|
+
* Creates the resource body for the Azure API call
|
|
308
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
309
|
+
*
|
|
310
|
+
* Note: Policy assignments do not have a location property as they are
|
|
311
|
+
* scoped resources (subscription, resource group, or resource level).
|
|
312
|
+
* The scope property is NOT included in the body as it's read-only and
|
|
313
|
+
* automatically derived from the parentId.
|
|
314
|
+
*/
|
|
315
|
+
protected createResourceBody(props: any): any;
|
|
316
|
+
/**
|
|
317
|
+
* Overrides parent ID resolution to use the scope from props
|
|
318
|
+
* Policy assignments are scoped resources where the scope IS the parent
|
|
319
|
+
*/
|
|
320
|
+
protected resolveParentId(props: any): string;
|
|
321
|
+
/**
|
|
322
|
+
* Get the full resource identifier for use in other Azure resources
|
|
323
|
+
* Alias for the id property
|
|
324
|
+
*/
|
|
325
|
+
get resourceId(): string;
|
|
326
|
+
/**
|
|
327
|
+
* Get the policy definition ID this assignment references
|
|
328
|
+
*/
|
|
329
|
+
get policyDefinitionId(): string;
|
|
330
|
+
/**
|
|
331
|
+
* Get the scope of this policy assignment
|
|
332
|
+
*/
|
|
333
|
+
get assignmentScope(): string;
|
|
334
|
+
/**
|
|
335
|
+
* Get the enforcement mode
|
|
336
|
+
*/
|
|
337
|
+
get enforcementMode(): string;
|
|
338
|
+
/**
|
|
339
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
340
|
+
*/
|
|
341
|
+
private _applyIgnoreChanges;
|
|
342
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.PolicyAssignment = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Policy Assignment implementation using VersionedAzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for managing Azure Policy Assignments
|
|
10
|
+
* using the AZAPI provider. Policy assignments apply policy definitions to specific scopes
|
|
11
|
+
* (subscription, resource group, or resource) and can provide parameter values and
|
|
12
|
+
* enforcement settings.
|
|
13
|
+
*
|
|
14
|
+
* Supported API Versions:
|
|
15
|
+
* - 2022-06-01 (Active, Latest)
|
|
16
|
+
*
|
|
17
|
+
* Features:
|
|
18
|
+
* - Automatic latest version resolution when no version is specified
|
|
19
|
+
* - Explicit version pinning for stability requirements
|
|
20
|
+
* - Schema-driven validation and transformation
|
|
21
|
+
* - Support for enforcement modes (Default, DoNotEnforce)
|
|
22
|
+
* - Managed identity support for remediation policies
|
|
23
|
+
* - Custom non-compliance messages
|
|
24
|
+
* - Scope exclusions (notScopes)
|
|
25
|
+
* - JSII compliance for multi-language support
|
|
26
|
+
*/
|
|
27
|
+
const cdktf = require("cdktf");
|
|
28
|
+
const policy_assignment_schemas_1 = require("./policy-assignment-schemas");
|
|
29
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
30
|
+
/**
|
|
31
|
+
* Unified Azure Policy Assignment implementation
|
|
32
|
+
*
|
|
33
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
34
|
+
* Policy Assignments. It automatically handles version resolution, schema validation,
|
|
35
|
+
* and property transformation.
|
|
36
|
+
*
|
|
37
|
+
* Note: Policy assignments can be deployed at subscription, resource group, or resource scope.
|
|
38
|
+
* Like policy definitions, they do not have a location property as they are not region-specific.
|
|
39
|
+
*
|
|
40
|
+
* @example
|
|
41
|
+
* // Basic policy assignment:
|
|
42
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
43
|
+
* name: "require-tag-assignment",
|
|
44
|
+
* policyDefinitionId: policyDefinition.id,
|
|
45
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name",
|
|
46
|
+
* displayName: "Require tag on resources",
|
|
47
|
+
* description: "Enforces required tags on resources"
|
|
48
|
+
* });
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* // Policy assignment with parameters:
|
|
52
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
53
|
+
* name: "require-tag-assignment",
|
|
54
|
+
* policyDefinitionId: policyDefinition.id,
|
|
55
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
56
|
+
* parameters: {
|
|
57
|
+
* tagName: {
|
|
58
|
+
* value: "Environment"
|
|
59
|
+
* },
|
|
60
|
+
* tagValue: {
|
|
61
|
+
* value: "Production"
|
|
62
|
+
* }
|
|
63
|
+
* }
|
|
64
|
+
* });
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* // Policy assignment with managed identity:
|
|
68
|
+
* const assignment = new PolicyAssignment(this, "assignment", {
|
|
69
|
+
* name: "deploy-monitoring-assignment",
|
|
70
|
+
* policyDefinitionId: "/providers/Microsoft.Authorization/policyDefinitions/policy-id",
|
|
71
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
72
|
+
* identity: {
|
|
73
|
+
* type: "SystemAssigned"
|
|
74
|
+
* }
|
|
75
|
+
* });
|
|
76
|
+
*
|
|
77
|
+
* @stability stable
|
|
78
|
+
*/
|
|
79
|
+
class PolicyAssignment extends azapi_resource_1.AzapiResource {
|
|
80
|
+
// Public properties
|
|
81
|
+
/**
|
|
82
|
+
* Creates a new Azure Policy Assignment using the VersionedAzapiResource framework
|
|
83
|
+
*
|
|
84
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
85
|
+
* validation, and resource creation.
|
|
86
|
+
*
|
|
87
|
+
* @param scope - The scope in which to define this construct
|
|
88
|
+
* @param id - The unique identifier for this instance
|
|
89
|
+
* @param props - Configuration properties for the Policy Assignment
|
|
90
|
+
*/
|
|
91
|
+
constructor(scope, id, props) {
|
|
92
|
+
super(scope, id, props);
|
|
93
|
+
this.props = props;
|
|
94
|
+
// Validate that location is provided when identity is specified
|
|
95
|
+
if (props.identity && !this.location) {
|
|
96
|
+
throw new Error(`Location is required for Policy Assignment "${props.name || id}" when identity is specified. ` +
|
|
97
|
+
`The managed identity must be provisioned in a specific Azure region.`);
|
|
98
|
+
}
|
|
99
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
100
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
101
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
102
|
+
value: this.id,
|
|
103
|
+
description: "The ID of the Policy Assignment",
|
|
104
|
+
});
|
|
105
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
106
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
107
|
+
description: "The name of the Policy Assignment",
|
|
108
|
+
});
|
|
109
|
+
// Override logical IDs to match original naming convention
|
|
110
|
+
this.idOutput.overrideLogicalId("id");
|
|
111
|
+
this.nameOutput.overrideLogicalId("name");
|
|
112
|
+
// Apply ignore changes if specified
|
|
113
|
+
this._applyIgnoreChanges();
|
|
114
|
+
}
|
|
115
|
+
// =============================================================================
|
|
116
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
117
|
+
// =============================================================================
|
|
118
|
+
/**
|
|
119
|
+
* Gets the default API version to use when no explicit version is specified
|
|
120
|
+
* Returns the most recent stable version as the default
|
|
121
|
+
*/
|
|
122
|
+
defaultVersion() {
|
|
123
|
+
return "2022-06-01";
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Gets the Azure resource type for Policy Assignments
|
|
127
|
+
*/
|
|
128
|
+
resourceType() {
|
|
129
|
+
return policy_assignment_schemas_1.POLICY_ASSIGNMENT_TYPE;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Gets the API schema for the resolved version
|
|
133
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
134
|
+
*/
|
|
135
|
+
apiSchema() {
|
|
136
|
+
return this.resolveSchema();
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Creates the resource body for the Azure API call
|
|
140
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
141
|
+
*
|
|
142
|
+
* Note: Policy assignments do not have a location property as they are
|
|
143
|
+
* scoped resources (subscription, resource group, or resource level).
|
|
144
|
+
* The scope property is NOT included in the body as it's read-only and
|
|
145
|
+
* automatically derived from the parentId.
|
|
146
|
+
*/
|
|
147
|
+
createResourceBody(props) {
|
|
148
|
+
const typedProps = props;
|
|
149
|
+
const body = {
|
|
150
|
+
properties: {
|
|
151
|
+
policyDefinitionId: typedProps.policyDefinitionId,
|
|
152
|
+
// Note: scope is NOT included here - it's read-only and derived from parentId
|
|
153
|
+
displayName: typedProps.displayName,
|
|
154
|
+
description: typedProps.description,
|
|
155
|
+
enforcementMode: typedProps.enforcementMode || "Default",
|
|
156
|
+
parameters: typedProps.parameters,
|
|
157
|
+
metadata: typedProps.metadata,
|
|
158
|
+
notScopes: typedProps.notScopes,
|
|
159
|
+
nonComplianceMessages: typedProps.nonComplianceMessages,
|
|
160
|
+
},
|
|
161
|
+
};
|
|
162
|
+
// Add identity if provided
|
|
163
|
+
if (typedProps.identity) {
|
|
164
|
+
body.identity = typedProps.identity;
|
|
165
|
+
// Azure requires location when identity is specified for managed identity provisioning
|
|
166
|
+
body.location = typedProps.location;
|
|
167
|
+
}
|
|
168
|
+
return body;
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Overrides parent ID resolution to use the scope from props
|
|
172
|
+
* Policy assignments are scoped resources where the scope IS the parent
|
|
173
|
+
*/
|
|
174
|
+
resolveParentId(props) {
|
|
175
|
+
const typedProps = props;
|
|
176
|
+
return typedProps.scope;
|
|
177
|
+
}
|
|
178
|
+
// =============================================================================
|
|
179
|
+
// PUBLIC METHODS FOR POLICY ASSIGNMENT OPERATIONS
|
|
180
|
+
// =============================================================================
|
|
181
|
+
/**
|
|
182
|
+
* Get the full resource identifier for use in other Azure resources
|
|
183
|
+
* Alias for the id property
|
|
184
|
+
*/
|
|
185
|
+
get resourceId() {
|
|
186
|
+
return this.id;
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Get the policy definition ID this assignment references
|
|
190
|
+
*/
|
|
191
|
+
get policyDefinitionId() {
|
|
192
|
+
return this.props.policyDefinitionId;
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Get the scope of this policy assignment
|
|
196
|
+
*/
|
|
197
|
+
get assignmentScope() {
|
|
198
|
+
return this.props.scope;
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* Get the enforcement mode
|
|
202
|
+
*/
|
|
203
|
+
get enforcementMode() {
|
|
204
|
+
return this.props.enforcementMode || "Default";
|
|
205
|
+
}
|
|
206
|
+
// =============================================================================
|
|
207
|
+
// PRIVATE HELPER METHODS
|
|
208
|
+
// =============================================================================
|
|
209
|
+
/**
|
|
210
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
211
|
+
*/
|
|
212
|
+
_applyIgnoreChanges() {
|
|
213
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
214
|
+
this.terraformResource.addOverride("lifecycle", [
|
|
215
|
+
{
|
|
216
|
+
ignore_changes: this.props.ignoreChanges,
|
|
217
|
+
},
|
|
218
|
+
]);
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
exports.PolicyAssignment = PolicyAssignment;
|
|
223
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
224
|
+
PolicyAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyAssignment", version: "1.3.0" };
|
|
225
|
+
(() => {
|
|
226
|
+
azapi_resource_1.AzapiResource.registerSchemas(policy_assignment_schemas_1.POLICY_ASSIGNMENT_TYPE, policy_assignment_schemas_1.ALL_POLICY_ASSIGNMENT_VERSIONS);
|
|
227
|
+
})();
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-assignment.js","sourceRoot":"","sources":["../../../src/azure-policyassignment/lib/policy-assignment.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Policy Assignment implementation using VersionedAzapiResource framework\n *\n * This class provides a version-aware implementation for managing Azure Policy Assignments\n * using the AZAPI provider. Policy assignments apply policy definitions to specific scopes\n * (subscription, resource group, or resource) and can provide parameter values and\n * enforcement settings.\n *\n * Supported API Versions:\n * - 2022-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 enforcement modes (Default, DoNotEnforce)\n * - Managed identity support for remediation policies\n * - Custom non-compliance messages\n * - Scope exclusions (notScopes)\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_POLICY_ASSIGNMENT_VERSIONS,\n  POLICY_ASSIGNMENT_TYPE,\n} from \"./policy-assignment-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 * Identity configuration for policy assignments\n * Required for policies with deployIfNotExists or modify effects\n */\nexport interface PolicyAssignmentIdentity {\n  /**\n   * The type of managed identity\n   * @example \"SystemAssigned\", \"UserAssigned\", \"None\"\n   */\n  readonly type: string;\n\n  /**\n   * The user assigned identities associated with the policy assignment\n   * Required when type is UserAssigned\n   *\n   * @example\n   * {\n   *   \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.ManagedIdentity/userAssignedIdentities/identity\": {}\n   * }\n   */\n  readonly userAssignedIdentities?: { [key: string]: any };\n}\n\n/**\n * Non-compliance message configuration\n */\nexport interface PolicyAssignmentNonComplianceMessage {\n  /**\n   * The non-compliance message for the policy assignment\n   */\n  readonly message: string;\n\n  /**\n   * The policy definition reference ID within a policy set definition\n   * Optional - if specified, this message applies only to the specified policy within the set\n   */\n  readonly policyDefinitionReferenceId?: string;\n}\n\n/**\n * Properties for the unified Azure Policy Assignment\n *\n * Extends AzapiResourceProps with Policy Assignment specific properties\n */\nexport interface PolicyAssignmentProps extends AzapiResourceProps {\n  /**\n   * The policy definition ID to assign\n   * This can be a built-in or custom policy definition\n   * Required property\n   *\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/policyDefinitions/policy-name\"\n   * @example \"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d\" (built-in)\n   */\n  readonly policyDefinitionId: string;\n\n  /**\n   * The scope at which the policy assignment is applied\n   * Can be a subscription, resource group, or resource\n   * Required property\n   *\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000\"\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name\"\n   */\n  readonly scope: string;\n\n  /**\n   * The display name of the policy assignment\n   * Provides a human-readable name for the assignment\n   *\n   * @example \"Require tag on resources in production\"\n   */\n  readonly displayName?: string;\n\n  /**\n   * The policy assignment description\n   * Provides detailed information about the assignment\n   *\n   * @example \"Enforces required tags on all resources in production environment\"\n   */\n  readonly description?: string;\n\n  /**\n   * The enforcement mode of the policy assignment\n   * @default \"Default\"\n   * @example \"Default\" - Policy effect is enforced during resource creation/update\n   * @example \"DoNotEnforce\" - Policy effect is not enforced (audit only)\n   */\n  readonly enforcementMode?: string;\n\n  /**\n   * Parameters for the policy assignment\n   * Provides values for parameters defined in the policy definition\n   *\n   * @example\n   * {\n   *   tagName: {\n   *     value: \"Environment\"\n   *   },\n   *   tagValue: {\n   *     value: \"Production\"\n   *   }\n   * }\n   */\n  readonly parameters?: any;\n\n  /**\n   * Metadata for the policy assignment\n   * Used to store additional information like assignedBy, parameterScopes, etc.\n   *\n   * @example\n   * {\n   *   assignedBy: \"admin@example.com\",\n   *   parameterScopes: {}\n   * }\n   */\n  readonly metadata?: any;\n\n  /**\n   * The managed identity associated with the policy assignment\n   * Required for policies with deployIfNotExists or modify effects\n   *\n   * @example\n   * {\n   *   type: \"SystemAssigned\"\n   * }\n   */\n  readonly identity?: PolicyAssignmentIdentity;\n\n  /**\n   * The policy's excluded scopes\n   * Resources within these scopes will not be evaluated by the policy\n   *\n   * @example [\"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/excluded-rg\"]\n   */\n  readonly notScopes?: string[];\n\n  /**\n   * The non-compliance messages for the policy assignment\n   * Provides custom messages when resources are non-compliant\n   *\n   * @example\n   * [\n   *   {\n   *     message: \"Resource must have the Environment tag\"\n   *   }\n   * ]\n   */\n  readonly nonComplianceMessages?: PolicyAssignmentNonComplianceMessage[];\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 Assignment\n * This is required for JSII compliance to support multi-language code generation\n */\nexport interface PolicyAssignmentProperties {\n  /**\n   * The policy definition ID\n   */\n  readonly policyDefinitionId: string;\n\n  /**\n   * The scope of the policy assignment\n   */\n  readonly scope: string;\n\n  /**\n   * The display name of the policy assignment\n   */\n  readonly displayName?: string;\n\n  /**\n   * The policy assignment description\n   */\n  readonly description?: string;\n\n  /**\n   * The enforcement mode\n   */\n  readonly enforcementMode?: string;\n\n  /**\n   * Parameters for the policy assignment\n   */\n  readonly parameters?: any;\n\n  /**\n   * Metadata for the policy assignment\n   */\n  readonly metadata?: any;\n\n  /**\n   * The policy's excluded scopes\n   */\n  readonly notScopes?: string[];\n\n  /**\n   * The non-compliance messages\n   */\n  readonly nonComplianceMessages?: PolicyAssignmentNonComplianceMessage[];\n}\n\n/**\n * The resource body interface for Azure Policy Assignment API calls\n * This matches the Azure REST API schema for policy assignments\n */\nexport interface PolicyAssignmentBody {\n  /**\n   * The properties of the policy assignment\n   */\n  readonly properties: PolicyAssignmentProperties;\n\n  /**\n   * The managed identity associated with the policy assignment\n   */\n  readonly identity?: PolicyAssignmentIdentity;\n}\n\n/**\n * Unified Azure Policy Assignment implementation\n *\n * This class provides a single, version-aware implementation for managing Azure\n * Policy Assignments. It automatically handles version resolution, schema validation,\n * and property transformation.\n *\n * Note: Policy assignments can be deployed at subscription, resource group, or resource scope.\n * Like policy definitions, they do not have a location property as they are not region-specific.\n *\n * @example\n * // Basic policy assignment:\n * const assignment = new PolicyAssignment(this, \"assignment\", {\n *   name: \"require-tag-assignment\",\n *   policyDefinitionId: policyDefinition.id,\n *   scope: \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name\",\n *   displayName: \"Require tag on resources\",\n *   description: \"Enforces required tags on resources\"\n * });\n *\n * @example\n * // Policy assignment with parameters:\n * const assignment = new PolicyAssignment(this, \"assignment\", {\n *   name: \"require-tag-assignment\",\n *   policyDefinitionId: policyDefinition.id,\n *   scope: \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n *   parameters: {\n *     tagName: {\n *       value: \"Environment\"\n *     },\n *     tagValue: {\n *       value: \"Production\"\n *     }\n *   }\n * });\n *\n * @example\n * // Policy assignment with managed identity:\n * const assignment = new PolicyAssignment(this, \"assignment\", {\n *   name: \"deploy-monitoring-assignment\",\n *   policyDefinitionId: \"/providers/Microsoft.Authorization/policyDefinitions/policy-id\",\n *   scope: \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n *   identity: {\n *     type: \"SystemAssigned\"\n *   }\n * });\n *\n * @stability stable\n */\nexport class PolicyAssignment extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      POLICY_ASSIGNMENT_TYPE,\n      ALL_POLICY_ASSIGNMENT_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Policy Assignment instance\n   */\n  public readonly props: PolicyAssignmentProps;\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 Assignment 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 Assignment\n   */\n  constructor(scope: Construct, id: string, props: PolicyAssignmentProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Validate that location is provided when identity is specified\n    if (props.identity && !this.location) {\n      throw new Error(\n        `Location is required for Policy Assignment \"${props.name || id}\" when identity is specified. ` +\n          `The managed identity must be provisioned in a specific Azure region.`,\n      );\n    }\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 Assignment\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Policy Assignment\",\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 \"2022-06-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Policy Assignments\n   */\n  protected resourceType(): string {\n    return POLICY_ASSIGNMENT_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 assignments do not have a location property as they are\n   * scoped resources (subscription, resource group, or resource level).\n   * The scope property is NOT included in the body as it's read-only and\n   * automatically derived from the parentId.\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as PolicyAssignmentProps;\n\n    const body: any = {\n      properties: {\n        policyDefinitionId: typedProps.policyDefinitionId,\n        // Note: scope is NOT included here - it's read-only and derived from parentId\n        displayName: typedProps.displayName,\n        description: typedProps.description,\n        enforcementMode: typedProps.enforcementMode || \"Default\",\n        parameters: typedProps.parameters,\n        metadata: typedProps.metadata,\n        notScopes: typedProps.notScopes,\n        nonComplianceMessages: typedProps.nonComplianceMessages,\n      },\n    };\n\n    // Add identity if provided\n    if (typedProps.identity) {\n      body.identity = typedProps.identity;\n      // Azure requires location when identity is specified for managed identity provisioning\n      body.location = typedProps.location;\n    }\n\n    return body;\n  }\n\n  /**\n   * Overrides parent ID resolution to use the scope from props\n   * Policy assignments are scoped resources where the scope IS the parent\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as PolicyAssignmentProps;\n    return typedProps.scope;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR POLICY ASSIGNMENT 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 definition ID this assignment references\n   */\n  public get policyDefinitionId(): string {\n    return this.props.policyDefinitionId;\n  }\n\n  /**\n   * Get the scope of this policy assignment\n   */\n  public get assignmentScope(): string {\n    return this.props.scope;\n  }\n\n  /**\n   * Get the enforcement mode\n   */\n  public get enforcementMode(): string {\n    return this.props.enforcementMode || \"Default\";\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,13 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Policy Assignment
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the PolicyAssignment construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* Note: This test requires a policy definition to exist before assigning it.
|
|
8
|
+
* It creates a simple policy definition first, then creates assignments
|
|
9
|
+
* that reference it.
|
|
10
|
+
*
|
|
11
|
+
* Run with: npm run integration:nostream
|
|
12
|
+
*/
|
|
13
|
+
import "cdktf/lib/testing/adapters/jest";
|