@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,257 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.RoleAssignment = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Role Assignment implementation using VersionedAzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for managing Azure Role Assignments
|
|
10
|
+
* using the AZAPI provider. Role assignments grant specific permissions (roles) to security
|
|
11
|
+
* principals (users, groups, service principals, managed identities) at a particular scope.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2022-04-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 all principal types (User, Group, ServicePrincipal, ForeignGroup, Device)
|
|
21
|
+
* - Conditional role assignments using ABAC (Attribute-Based Access Control)
|
|
22
|
+
* - Delegated managed identity support for group assignments
|
|
23
|
+
* - Assignment at subscription, resource group, or resource scope
|
|
24
|
+
* - JSII compliance for multi-language support
|
|
25
|
+
*/
|
|
26
|
+
const crypto_1 = require("crypto");
|
|
27
|
+
const cdktf = require("cdktf");
|
|
28
|
+
const role_assignment_schemas_1 = require("./role-assignment-schemas");
|
|
29
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
30
|
+
/**
|
|
31
|
+
* Unified Azure Role Assignment implementation
|
|
32
|
+
*
|
|
33
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
34
|
+
* Role Assignments. It automatically handles version resolution, schema validation,
|
|
35
|
+
* and property transformation.
|
|
36
|
+
*
|
|
37
|
+
* **Important Notes:**
|
|
38
|
+
* - Role assignments are scoped resources deployed at subscription, resource group,
|
|
39
|
+
* or resource level. They do not have a location property as they are not region-specific.
|
|
40
|
+
* - The `name` property (inherited from AzapiResourceProps) is not used. Azure automatically
|
|
41
|
+
* generates a deterministic GUID for role assignment names based on the deployment context.
|
|
42
|
+
* This ensures idempotent deployments without duplicate role assignments.
|
|
43
|
+
*
|
|
44
|
+
* @example
|
|
45
|
+
* Basic role assignment - Assign Reader role to a user at subscription scope
|
|
46
|
+
*
|
|
47
|
+
* const assignment = new RoleAssignment(this, "reader-assignment", {
|
|
48
|
+
* roleDefinitionId: "/providers/Microsoft.Authorization/roleDefinitions/acdd72a7-3385-48ef-bd42-f606fba81ae7",
|
|
49
|
+
* principalId: "00000000-0000-0000-0000-000000000000",
|
|
50
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
51
|
+
* principalType: "User",
|
|
52
|
+
* });
|
|
53
|
+
*
|
|
54
|
+
* @example
|
|
55
|
+
* Resource group scoped assignment - Assign Contributor to a service principal
|
|
56
|
+
*
|
|
57
|
+
* const assignment = new RoleAssignment(this, "contributor-assignment", {
|
|
58
|
+
* roleDefinitionId: "/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c",
|
|
59
|
+
* principalId: servicePrincipal.objectId,
|
|
60
|
+
* scope: resourceGroup.id,
|
|
61
|
+
* principalType: "ServicePrincipal",
|
|
62
|
+
* description: "Grants contributor access to the deployment service principal",
|
|
63
|
+
* });
|
|
64
|
+
*
|
|
65
|
+
* @example
|
|
66
|
+
* Conditional assignment with ABAC - Limit access to specific storage containers
|
|
67
|
+
*
|
|
68
|
+
* const assignment = new RoleAssignment(this, "conditional-assignment", {
|
|
69
|
+
* roleDefinitionId: storageRole.id,
|
|
70
|
+
* principalId: user.objectId,
|
|
71
|
+
* scope: storageAccount.id,
|
|
72
|
+
* principalType: "User",
|
|
73
|
+
* condition: "@Resource[Microsoft.Storage/storageAccounts/blobServices/containers:name] StringEquals 'logs'",
|
|
74
|
+
* conditionVersion: "2.0",
|
|
75
|
+
* description: "Grants access only to the logs container",
|
|
76
|
+
* });
|
|
77
|
+
*
|
|
78
|
+
* @stability stable
|
|
79
|
+
*/
|
|
80
|
+
class RoleAssignment extends azapi_resource_1.AzapiResource {
|
|
81
|
+
// Public properties
|
|
82
|
+
/**
|
|
83
|
+
* Creates a new Azure Role Assignment 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 Role Assignment
|
|
91
|
+
*/
|
|
92
|
+
constructor(scope, id, props) {
|
|
93
|
+
// Azure Role Assignments do not support tags at the resource level.
|
|
94
|
+
// We must strip tags from props before passing to the parent constructor
|
|
95
|
+
// to prevent the AZAPI provider from including tags in the resource.
|
|
96
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
97
|
+
const { tags: _unusedTags, ...propsWithoutTags } = props;
|
|
98
|
+
super(scope, id, propsWithoutTags);
|
|
99
|
+
this.props = props;
|
|
100
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
101
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
102
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
103
|
+
value: this.id,
|
|
104
|
+
description: "The ID of the Role Assignment",
|
|
105
|
+
});
|
|
106
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
107
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
108
|
+
description: "The name of the Role Assignment",
|
|
109
|
+
});
|
|
110
|
+
// Override logical IDs to match original naming convention
|
|
111
|
+
this.idOutput.overrideLogicalId("id");
|
|
112
|
+
this.nameOutput.overrideLogicalId("name");
|
|
113
|
+
// Apply ignore changes if specified
|
|
114
|
+
this._applyIgnoreChanges();
|
|
115
|
+
}
|
|
116
|
+
// =============================================================================
|
|
117
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
118
|
+
// =============================================================================
|
|
119
|
+
/**
|
|
120
|
+
* Gets the default API version to use when no explicit version is specified
|
|
121
|
+
* Returns the most recent stable version as the default
|
|
122
|
+
*/
|
|
123
|
+
defaultVersion() {
|
|
124
|
+
return "2022-04-01";
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Gets the Azure resource type for Role Assignments
|
|
128
|
+
*/
|
|
129
|
+
resourceType() {
|
|
130
|
+
return role_assignment_schemas_1.ROLE_ASSIGNMENT_TYPE;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Gets the API schema for the resolved version
|
|
134
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
135
|
+
*/
|
|
136
|
+
apiSchema() {
|
|
137
|
+
return this.resolveSchema();
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Creates the resource body for the Azure API call
|
|
141
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
142
|
+
*
|
|
143
|
+
* Note: Role assignments do not have a location property as they are
|
|
144
|
+
* scoped resources (subscription, resource group, or resource level).
|
|
145
|
+
* The scope property is NOT included in the body as it's read-only and
|
|
146
|
+
* automatically derived from the parentId.
|
|
147
|
+
*/
|
|
148
|
+
createResourceBody(props) {
|
|
149
|
+
const typedProps = props;
|
|
150
|
+
return {
|
|
151
|
+
properties: {
|
|
152
|
+
roleDefinitionId: typedProps.roleDefinitionId,
|
|
153
|
+
principalId: typedProps.principalId,
|
|
154
|
+
// Note: scope is NOT included here - it's read-only and derived from parentId
|
|
155
|
+
principalType: typedProps.principalType,
|
|
156
|
+
description: typedProps.description,
|
|
157
|
+
condition: typedProps.condition,
|
|
158
|
+
conditionVersion: typedProps.conditionVersion,
|
|
159
|
+
delegatedManagedIdentityResourceId: typedProps.delegatedManagedIdentityResourceId,
|
|
160
|
+
},
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Overrides the name resolution to generate deterministic GUIDs for role assignments
|
|
165
|
+
*
|
|
166
|
+
* Role assignments require GUID format IDs. This implementation generates a deterministic
|
|
167
|
+
* UUID based on the role assignment's key properties to ensure:
|
|
168
|
+
* - Same GUID is generated on re-deployments with same parameters
|
|
169
|
+
* - Idempotent deployments (no duplicate role assignments)
|
|
170
|
+
* - Consistent behavior across deployment runs
|
|
171
|
+
*/
|
|
172
|
+
resolveName(props) {
|
|
173
|
+
const typedProps = props;
|
|
174
|
+
// Create a deterministic hash from key role assignment properties
|
|
175
|
+
const hashInput = [
|
|
176
|
+
typedProps.scope,
|
|
177
|
+
typedProps.roleDefinitionId,
|
|
178
|
+
typedProps.principalId,
|
|
179
|
+
].join("|");
|
|
180
|
+
const hash = (0, crypto_1.createHash)("sha256").update(hashInput).digest("hex");
|
|
181
|
+
// Convert hash to UUID format (8-4-4-4-12)
|
|
182
|
+
return [
|
|
183
|
+
hash.substring(0, 8),
|
|
184
|
+
hash.substring(8, 12),
|
|
185
|
+
hash.substring(12, 16),
|
|
186
|
+
hash.substring(16, 20),
|
|
187
|
+
hash.substring(20, 32),
|
|
188
|
+
].join("-");
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Overrides parent ID resolution to use the scope from props
|
|
192
|
+
* Role assignments are scoped resources where the scope IS the parent
|
|
193
|
+
*/
|
|
194
|
+
resolveParentId(props) {
|
|
195
|
+
const typedProps = props;
|
|
196
|
+
return typedProps.scope;
|
|
197
|
+
}
|
|
198
|
+
// =============================================================================
|
|
199
|
+
// PUBLIC METHODS FOR ROLE ASSIGNMENT OPERATIONS
|
|
200
|
+
// =============================================================================
|
|
201
|
+
/**
|
|
202
|
+
* Get the full resource identifier for use in other Azure resources
|
|
203
|
+
* Alias for the id property
|
|
204
|
+
*/
|
|
205
|
+
get resourceId() {
|
|
206
|
+
return this.id;
|
|
207
|
+
}
|
|
208
|
+
/**
|
|
209
|
+
* Get the role definition ID this assignment references
|
|
210
|
+
*/
|
|
211
|
+
get roleDefinitionId() {
|
|
212
|
+
return this.props.roleDefinitionId;
|
|
213
|
+
}
|
|
214
|
+
/**
|
|
215
|
+
* Get the principal ID that was granted this role
|
|
216
|
+
*/
|
|
217
|
+
get principalId() {
|
|
218
|
+
return this.props.principalId;
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Get the scope of this role assignment
|
|
222
|
+
*/
|
|
223
|
+
get assignmentScope() {
|
|
224
|
+
return this.props.scope;
|
|
225
|
+
}
|
|
226
|
+
/**
|
|
227
|
+
* Get the principal type
|
|
228
|
+
*/
|
|
229
|
+
get principalType() {
|
|
230
|
+
return this.props.principalType;
|
|
231
|
+
}
|
|
232
|
+
// =============================================================================
|
|
233
|
+
// PRIVATE HELPER METHODS
|
|
234
|
+
// =============================================================================
|
|
235
|
+
/**
|
|
236
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
237
|
+
* Always includes body.properties.roleDefinitionId to handle Azure API format normalization
|
|
238
|
+
*/
|
|
239
|
+
_applyIgnoreChanges() {
|
|
240
|
+
// Always ignore roleDefinitionId format changes due to Azure API normalization
|
|
241
|
+
// Azure returns subscription-qualified format but accepts non-qualified format
|
|
242
|
+
const ignoreChanges = [
|
|
243
|
+
"body.properties.roleDefinitionId",
|
|
244
|
+
...(this.props.ignoreChanges || []),
|
|
245
|
+
];
|
|
246
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
247
|
+
ignore_changes: ignoreChanges,
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
exports.RoleAssignment = RoleAssignment;
|
|
252
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
253
|
+
RoleAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.RoleAssignment", version: "1.3.1" };
|
|
254
|
+
(() => {
|
|
255
|
+
azapi_resource_1.AzapiResource.registerSchemas(role_assignment_schemas_1.ROLE_ASSIGNMENT_TYPE, role_assignment_schemas_1.ALL_ROLE_ASSIGNMENT_VERSIONS);
|
|
256
|
+
})();
|
|
257
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-assignment.js","sourceRoot":"","sources":["../../../src/azure-roleassignment/lib/role-assignment.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Role Assignment implementation using VersionedAzapiResource framework\n *\n * This class provides a version-aware implementation for managing Azure Role Assignments\n * using the AZAPI provider. Role assignments grant specific permissions (roles) to security\n * principals (users, groups, service principals, managed identities) at a particular scope.\n *\n * Supported API Versions:\n * - 2022-04-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 all principal types (User, Group, ServicePrincipal, ForeignGroup, Device)\n * - Conditional role assignments using ABAC (Attribute-Based Access Control)\n * - Delegated managed identity support for group assignments\n * - Assignment at subscription, resource group, or resource scope\n * - JSII compliance for multi-language support\n */\n\nimport { createHash } from \"crypto\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_ROLE_ASSIGNMENT_VERSIONS,\n  ROLE_ASSIGNMENT_TYPE,\n} from \"./role-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 * Properties for the unified Azure Role Assignment\n *\n * Extends AzapiResourceProps with Role Assignment specific properties.\n *\n * **Note on the `name` property:** While this interface inherits the `name` property\n * from AzapiResourceProps, it is not used for role assignments. Azure role assignments\n * require GUID format names, which are automatically generated by the construct.\n * Any user-provided name value will be ignored in favor of Azure's deterministic\n * GUID generation based on the deployment context.\n */\nexport interface RoleAssignmentProps extends AzapiResourceProps {\n  /**\n   * The role definition ID to assign\n   * This can be a built-in or custom role definition\n   * Required property\n   *\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/providers/Microsoft.Authorization/roleDefinitions/acdd72a7-3385-48ef-bd42-f606fba81ae7\" (Reader)\n   * @example \"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\" (Contributor)\n   */\n  readonly roleDefinitionId: string;\n\n  /**\n   * The principal ID (object ID) to which the role is assigned\n   * This can be a user, group, service principal, or managed identity\n   * Required property\n   *\n   * @example \"00000000-0000-0000-0000-000000000000\"\n   */\n  readonly principalId: string;\n\n  /**\n   * The scope at which the role 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   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-name/providers/Microsoft.Storage/storageAccounts/storage-name\"\n   */\n  readonly scope: string;\n\n  /**\n   * The type of principal\n   * Specifies what kind of identity is being assigned the role\n   *\n   * @default undefined (Azure will auto-detect)\n   * @example \"User\" - An Azure AD user\n   * @example \"Group\" - An Azure AD group\n   * @example \"ServicePrincipal\" - A service principal (application)\n   * @example \"ForeignGroup\" - A group from external directory\n   * @example \"Device\" - A device identity\n   */\n  readonly principalType?: string;\n\n  /**\n   * The role assignment description\n   * Provides detailed information about why the assignment was made\n   *\n   * @example \"Grants read access to monitoring team for resource diagnostics\"\n   */\n  readonly description?: string;\n\n  /**\n   * The conditions on the role assignment\n   * Limits the resources it applies to using ABAC expressions\n   * Requires conditionVersion to be set when used\n   *\n   * @example \"@Resource[Microsoft.Storage/storageAccounts/blobServices/containers:name] StringEquals 'logs'\"\n   */\n  readonly condition?: string;\n\n  /**\n   * Version of the condition syntax\n   * Required when condition is specified\n   *\n   * @default undefined\n   * @example \"2.0\"\n   */\n  readonly conditionVersion?: string;\n\n  /**\n   * The delegated Azure Resource Id which contains a Managed Identity\n   * Applicable only when the principalType is Group\n   * Used for scenarios where a group assignment should use a specific managed identity\n   *\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.ManagedIdentity/userAssignedIdentities/identity\"\n   */\n  readonly delegatedManagedIdentityResourceId?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"description\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties interface for Azure Role Assignment\n * This is required for JSII compliance to support multi-language code generation\n */\nexport interface RoleAssignmentProperties {\n  /**\n   * The role definition ID\n   */\n  readonly roleDefinitionId: string;\n\n  /**\n   * The principal ID\n   */\n  readonly principalId: string;\n\n  /**\n   * The scope of the role assignment\n   */\n  readonly scope: string;\n\n  /**\n   * The type of principal\n   */\n  readonly principalType?: string;\n\n  /**\n   * The role assignment description\n   */\n  readonly description?: string;\n\n  /**\n   * The conditions on the role assignment\n   */\n  readonly condition?: string;\n\n  /**\n   * Version of the condition syntax\n   */\n  readonly conditionVersion?: string;\n\n  /**\n   * The delegated managed identity resource ID\n   */\n  readonly delegatedManagedIdentityResourceId?: string;\n}\n\n/**\n * The resource body interface for Azure Role Assignment API calls\n * This matches the Azure REST API schema for role assignments\n */\nexport interface RoleAssignmentBody {\n  /**\n   * The properties of the role assignment\n   */\n  readonly properties: RoleAssignmentProperties;\n}\n\n/**\n * Unified Azure Role Assignment implementation\n *\n * This class provides a single, version-aware implementation for managing Azure\n * Role Assignments. It automatically handles version resolution, schema validation,\n * and property transformation.\n *\n * **Important Notes:**\n * - Role assignments are scoped resources deployed at subscription, resource group,\n *   or resource level. They do not have a location property as they are not region-specific.\n * - The `name` property (inherited from AzapiResourceProps) is not used. Azure automatically\n *   generates a deterministic GUID for role assignment names based on the deployment context.\n *   This ensures idempotent deployments without duplicate role assignments.\n *\n * @example\n * Basic role assignment - Assign Reader role to a user at subscription scope\n *\n * const assignment = new RoleAssignment(this, \"reader-assignment\", {\n *   roleDefinitionId: \"/providers/Microsoft.Authorization/roleDefinitions/acdd72a7-3385-48ef-bd42-f606fba81ae7\",\n *   principalId: \"00000000-0000-0000-0000-000000000000\",\n *   scope: \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n *   principalType: \"User\",\n * });\n *\n * @example\n * Resource group scoped assignment - Assign Contributor to a service principal\n *\n * const assignment = new RoleAssignment(this, \"contributor-assignment\", {\n *   roleDefinitionId: \"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\",\n *   principalId: servicePrincipal.objectId,\n *   scope: resourceGroup.id,\n *   principalType: \"ServicePrincipal\",\n *   description: \"Grants contributor access to the deployment service principal\",\n * });\n *\n * @example\n * Conditional assignment with ABAC - Limit access to specific storage containers\n *\n * const assignment = new RoleAssignment(this, \"conditional-assignment\", {\n *   roleDefinitionId: storageRole.id,\n *   principalId: user.objectId,\n *   scope: storageAccount.id,\n *   principalType: \"User\",\n *   condition: \"@Resource[Microsoft.Storage/storageAccounts/blobServices/containers:name] StringEquals 'logs'\",\n *   conditionVersion: \"2.0\",\n *   description: \"Grants access only to the logs container\",\n * });\n *\n * @stability stable\n */\nexport class RoleAssignment extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      ROLE_ASSIGNMENT_TYPE,\n      ALL_ROLE_ASSIGNMENT_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Role Assignment instance\n   */\n  public readonly props: RoleAssignmentProps;\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 Role 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 Role Assignment\n   */\n  constructor(scope: Construct, id: string, props: RoleAssignmentProps) {\n    // Azure Role Assignments do not support tags at the resource level.\n    // We must strip tags from props before passing to the parent constructor\n    // to prevent the AZAPI provider from including tags in the resource.\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    const { tags: _unusedTags, ...propsWithoutTags } = props;\n    super(scope, id, propsWithoutTags as RoleAssignmentProps);\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 Role Assignment\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Role 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-04-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Role Assignments\n   */\n  protected resourceType(): string {\n    return ROLE_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: Role 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 RoleAssignmentProps;\n    return {\n      properties: {\n        roleDefinitionId: typedProps.roleDefinitionId,\n        principalId: typedProps.principalId,\n        // Note: scope is NOT included here - it's read-only and derived from parentId\n        principalType: typedProps.principalType,\n        description: typedProps.description,\n        condition: typedProps.condition,\n        conditionVersion: typedProps.conditionVersion,\n        delegatedManagedIdentityResourceId:\n          typedProps.delegatedManagedIdentityResourceId,\n      },\n    };\n  }\n\n  /**\n   * Overrides the name resolution to generate deterministic GUIDs for role assignments\n   *\n   * Role assignments require GUID format IDs. This implementation generates a deterministic\n   * UUID based on the role assignment's key properties to ensure:\n   * - Same GUID is generated on re-deployments with same parameters\n   * - Idempotent deployments (no duplicate role assignments)\n   * - Consistent behavior across deployment runs\n   */\n  protected resolveName(props: AzapiResourceProps): string {\n    const typedProps = props as RoleAssignmentProps;\n\n    // Create a deterministic hash from key role assignment properties\n    const hashInput = [\n      typedProps.scope,\n      typedProps.roleDefinitionId,\n      typedProps.principalId,\n    ].join(\"|\");\n\n    const hash = createHash(\"sha256\").update(hashInput).digest(\"hex\");\n\n    // Convert hash to UUID format (8-4-4-4-12)\n    return [\n      hash.substring(0, 8),\n      hash.substring(8, 12),\n      hash.substring(12, 16),\n      hash.substring(16, 20),\n      hash.substring(20, 32),\n    ].join(\"-\");\n  }\n\n  /**\n   * Overrides parent ID resolution to use the scope from props\n   * Role assignments are scoped resources where the scope IS the parent\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as RoleAssignmentProps;\n    return typedProps.scope;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR ROLE 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 role definition ID this assignment references\n   */\n  public get roleDefinitionId(): string {\n    return this.props.roleDefinitionId;\n  }\n\n  /**\n   * Get the principal ID that was granted this role\n   */\n  public get principalId(): string {\n    return this.props.principalId;\n  }\n\n  /**\n   * Get the scope of this role assignment\n   */\n  public get assignmentScope(): string {\n    return this.props.scope;\n  }\n\n  /**\n   * Get the principal type\n   */\n  public get principalType(): string | undefined {\n    return this.props.principalType;\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   * Always includes body.properties.roleDefinitionId to handle Azure API format normalization\n   */\n  private _applyIgnoreChanges(): void {\n    // Always ignore roleDefinitionId format changes due to Azure API normalization\n    // Azure returns subscription-qualified format but accepts non-qualified format\n    const ignoreChanges = [\n      \"body.properties.roleDefinitionId\",\n      ...(this.props.ignoreChanges || []),\n    ];\n\n    this.terraformResource.addOverride(\"lifecycle\", {\n      ignore_changes: ignoreChanges,\n    });\n  }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Role Assignment
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the RoleAssignment construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* The test assigns built-in Reader role to a test principal
|
|
8
|
+
* at subscription scope.
|
|
9
|
+
*
|
|
10
|
+
* Run with: npm run integration:nostream
|
|
11
|
+
*/
|
|
12
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Role Assignment
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the RoleAssignment construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* The test assigns built-in Reader role to a test principal
|
|
9
|
+
* at subscription scope.
|
|
10
|
+
*
|
|
11
|
+
* Run with: npm run integration:nostream
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
const cdktf_1 = require("cdktf");
|
|
15
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
16
|
+
const child_process_1 = require("child_process");
|
|
17
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
18
|
+
const testing_1 = require("../../testing");
|
|
19
|
+
const metadata_1 = require("../../testing/lib/metadata");
|
|
20
|
+
const role_assignment_1 = require("../lib/role-assignment");
|
|
21
|
+
// Generate unique test run metadata for this test suite
|
|
22
|
+
const testMetadata = new metadata_1.TestRunMetadata("role-assignment-integration", {
|
|
23
|
+
maxAgeHours: 4,
|
|
24
|
+
});
|
|
25
|
+
/**
|
|
26
|
+
* Example stack demonstrating Role Assignment usage
|
|
27
|
+
*/
|
|
28
|
+
class RoleAssignmentExampleStack extends testing_1.BaseTestStack {
|
|
29
|
+
constructor(scope, id) {
|
|
30
|
+
super(scope, id, {
|
|
31
|
+
testRunOptions: {
|
|
32
|
+
maxAgeHours: testMetadata.maxAgeHours,
|
|
33
|
+
autoCleanup: testMetadata.autoCleanup,
|
|
34
|
+
cleanupPolicy: testMetadata.cleanupPolicy,
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
// Configure AZAPI provider
|
|
38
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
39
|
+
// Get the subscription ID dynamically from Azure CLI or environment variable
|
|
40
|
+
let subscriptionId;
|
|
41
|
+
try {
|
|
42
|
+
subscriptionId =
|
|
43
|
+
process.env.ARM_SUBSCRIPTION_ID ||
|
|
44
|
+
(0, child_process_1.execSync)("az account show --query id -o tsv", {
|
|
45
|
+
encoding: "utf-8",
|
|
46
|
+
}).trim();
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
throw new Error("Failed to get Azure subscription ID. Please ensure you are logged in with 'az login' or set ARM_SUBSCRIPTION_ID environment variable.");
|
|
50
|
+
}
|
|
51
|
+
const subscriptionScope = `/subscriptions/${subscriptionId}`;
|
|
52
|
+
// Get test principal ID from environment (required for integration tests)
|
|
53
|
+
// This should be the Object ID of a user, group, or service principal
|
|
54
|
+
const principalId = process.env.ARM_TEST_PRINCIPAL_ID ||
|
|
55
|
+
"00000000-0000-0000-0000-000000000001";
|
|
56
|
+
// Built-in Azure role definition IDs
|
|
57
|
+
const readerRoleId = "/providers/Microsoft.Authorization/roleDefinitions/acdd72a7-3385-48ef-bd42-f606fba81ae7";
|
|
58
|
+
const contributorRoleId = "/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c";
|
|
59
|
+
// Example 1: Assign Reader role at subscription scope
|
|
60
|
+
// Note: name is not needed - Azure generates a deterministic GUID automatically
|
|
61
|
+
new role_assignment_1.RoleAssignment(this, "reader-assignment", {
|
|
62
|
+
roleDefinitionId: readerRoleId,
|
|
63
|
+
principalId: principalId,
|
|
64
|
+
scope: subscriptionScope,
|
|
65
|
+
principalType: "ServicePrincipal",
|
|
66
|
+
description: "Reader role assignment for integration testing",
|
|
67
|
+
tags: {
|
|
68
|
+
...this.systemTags(),
|
|
69
|
+
example: "basic",
|
|
70
|
+
role: "reader",
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
// Example 2: Assign Contributor role at subscription scope with description
|
|
74
|
+
// Note: name is not needed - Azure generates a deterministic GUID automatically
|
|
75
|
+
new role_assignment_1.RoleAssignment(this, "contributor-assignment", {
|
|
76
|
+
roleDefinitionId: contributorRoleId,
|
|
77
|
+
principalId: principalId,
|
|
78
|
+
scope: subscriptionScope,
|
|
79
|
+
principalType: "ServicePrincipal",
|
|
80
|
+
description: "Contributor role assignment for integration testing - allows resource management but not role assignments",
|
|
81
|
+
tags: {
|
|
82
|
+
...this.systemTags(),
|
|
83
|
+
example: "advanced",
|
|
84
|
+
role: "contributor",
|
|
85
|
+
},
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
describe("Role Assignment Integration Test", () => {
|
|
90
|
+
it("should deploy, validate idempotency, and cleanup role assignment resources", () => {
|
|
91
|
+
const app = cdktf_1.Testing.app();
|
|
92
|
+
const stack = new RoleAssignmentExampleStack(app, "test-role-assignment");
|
|
93
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
94
|
+
// This will:
|
|
95
|
+
// 1. Run terraform apply to deploy resources (role assignments)
|
|
96
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
97
|
+
// 3. Run terraform destroy to cleanup resources
|
|
98
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
99
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
100
|
+
});
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-assignment.integ.js","sourceRoot":"","sources":["../../../src/azure-roleassignment/test/role-assignment.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Role Assignment\n *\n * This test demonstrates basic usage of the RoleAssignment construct\n * and validates deployment, idempotency, and cleanup.\n *\n * The test assigns built-in Reader role to a test principal\n * at subscription scope.\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 { execSync } from \"child_process\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { RoleAssignment } from \"../lib/role-assignment\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\"role-assignment-integration\", {\n  maxAgeHours: 4,\n});\n\n/**\n * Example stack demonstrating Role Assignment usage\n */\nclass RoleAssignmentExampleStack 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    // Get the subscription ID dynamically from Azure CLI or environment variable\n    let subscriptionId: string;\n    try {\n      subscriptionId =\n        process.env.ARM_SUBSCRIPTION_ID ||\n        execSync(\"az account show --query id -o tsv\", {\n          encoding: \"utf-8\",\n        }).trim();\n    } catch (error) {\n      throw new Error(\n        \"Failed to get Azure subscription ID. Please ensure you are logged in with 'az login' or set ARM_SUBSCRIPTION_ID environment variable.\",\n      );\n    }\n    const subscriptionScope = `/subscriptions/${subscriptionId}`;\n\n    // Get test principal ID from environment (required for integration tests)\n    // This should be the Object ID of a user, group, or service principal\n    const principalId =\n      process.env.ARM_TEST_PRINCIPAL_ID ||\n      \"00000000-0000-0000-0000-000000000001\";\n\n    // Built-in Azure role definition IDs\n    const readerRoleId =\n      \"/providers/Microsoft.Authorization/roleDefinitions/acdd72a7-3385-48ef-bd42-f606fba81ae7\";\n    const contributorRoleId =\n      \"/providers/Microsoft.Authorization/roleDefinitions/b24988ac-6180-42a0-ab88-20f7382dd24c\";\n\n    // Example 1: Assign Reader role at subscription scope\n    // Note: name is not needed - Azure generates a deterministic GUID automatically\n    new RoleAssignment(this, \"reader-assignment\", {\n      roleDefinitionId: readerRoleId,\n      principalId: principalId,\n      scope: subscriptionScope,\n      principalType: \"ServicePrincipal\",\n      description: \"Reader role assignment for integration testing\",\n      tags: {\n        ...this.systemTags(),\n        example: \"basic\",\n        role: \"reader\",\n      },\n    });\n\n    // Example 2: Assign Contributor role at subscription scope with description\n    // Note: name is not needed - Azure generates a deterministic GUID automatically\n    new RoleAssignment(this, \"contributor-assignment\", {\n      roleDefinitionId: contributorRoleId,\n      principalId: principalId,\n      scope: subscriptionScope,\n      principalType: \"ServicePrincipal\",\n      description:\n        \"Contributor role assignment for integration testing - allows resource management but not role assignments\",\n      tags: {\n        ...this.systemTags(),\n        example: \"advanced\",\n        role: \"contributor\",\n      },\n    });\n  }\n}\n\ndescribe(\"Role Assignment Integration Test\", () => {\n  it(\"should deploy, validate idempotency, and cleanup role assignment resources\", () => {\n    const app = Testing.app();\n    const stack = new RoleAssignmentExampleStack(app, \"test-role-assignment\");\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources (role assignments)\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 RoleAssignment implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the unified RoleAssignment class that uses
|
|
5
|
+
* the VersionedAzapiResource framework. Tests cover automatic version resolution,
|
|
6
|
+
* explicit version pinning, schema validation, property transformation, and
|
|
7
|
+
* role assignment-specific functionality.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|