@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,192 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.RoleDefinition = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Role Definition implementation using VersionedAzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for managing Azure Role Definitions
|
|
10
|
+
* using the AZAPI provider. Role definitions define custom RBAC roles with specific
|
|
11
|
+
* permissions that can be assigned to users, groups, or service principals.
|
|
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 custom role permissions (actions, notActions, dataActions, notDataActions)
|
|
21
|
+
* - Assignable scopes configuration (subscription, resource group, management group)
|
|
22
|
+
* - JSII compliance for multi-language support
|
|
23
|
+
*/
|
|
24
|
+
const crypto_1 = require("crypto");
|
|
25
|
+
const cdktf = require("cdktf");
|
|
26
|
+
const role_definition_schemas_1 = require("./role-definition-schemas");
|
|
27
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
28
|
+
/**
|
|
29
|
+
* Unified Azure Role Definition implementation
|
|
30
|
+
*
|
|
31
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
32
|
+
* Role Definitions. It automatically handles version resolution, schema validation,
|
|
33
|
+
* and property transformation.
|
|
34
|
+
*
|
|
35
|
+
* Note: Role definitions are tenant-specific resources deployed at subscription or
|
|
36
|
+
* management group scope. Unlike most Azure resources, they do not have a location
|
|
37
|
+
* property as they are not region-specific.
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* Basic custom role definition for read-only access to compute resources
|
|
41
|
+
*
|
|
42
|
+
* Advanced features like data plane actions and complex permissions are supported
|
|
43
|
+
*
|
|
44
|
+
* @stability stable
|
|
45
|
+
*/
|
|
46
|
+
class RoleDefinition extends azapi_resource_1.AzapiResource {
|
|
47
|
+
// Public properties
|
|
48
|
+
/**
|
|
49
|
+
* Creates a new Azure Role Definition using the VersionedAzapiResource framework
|
|
50
|
+
*
|
|
51
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
52
|
+
* validation, and resource creation.
|
|
53
|
+
*
|
|
54
|
+
* @param scope - The scope in which to define this construct
|
|
55
|
+
* @param id - The unique identifier for this instance
|
|
56
|
+
* @param props - Configuration properties for the Role Definition
|
|
57
|
+
*/
|
|
58
|
+
constructor(scope, id, props) {
|
|
59
|
+
super(scope, id, props);
|
|
60
|
+
this.props = props;
|
|
61
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
62
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
63
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
64
|
+
value: this.id,
|
|
65
|
+
description: "The ID of the Role Definition",
|
|
66
|
+
});
|
|
67
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
68
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
69
|
+
description: "The name of the Role Definition",
|
|
70
|
+
});
|
|
71
|
+
// Override logical IDs to match original naming convention
|
|
72
|
+
this.idOutput.overrideLogicalId("id");
|
|
73
|
+
this.nameOutput.overrideLogicalId("name");
|
|
74
|
+
// Apply ignore changes if specified
|
|
75
|
+
this._applyIgnoreChanges();
|
|
76
|
+
}
|
|
77
|
+
// =============================================================================
|
|
78
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
79
|
+
// =============================================================================
|
|
80
|
+
/**
|
|
81
|
+
* Gets the default API version to use when no explicit version is specified
|
|
82
|
+
* Returns the most recent stable version as the default
|
|
83
|
+
*/
|
|
84
|
+
defaultVersion() {
|
|
85
|
+
return "2022-04-01";
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Gets the Azure resource type for Role Definitions
|
|
89
|
+
*/
|
|
90
|
+
resourceType() {
|
|
91
|
+
return role_definition_schemas_1.ROLE_DEFINITION_TYPE;
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Gets the API schema for the resolved version
|
|
95
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
96
|
+
*/
|
|
97
|
+
apiSchema() {
|
|
98
|
+
return this.resolveSchema();
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Overrides the name resolution to generate deterministic GUIDs for role definitions
|
|
102
|
+
*
|
|
103
|
+
* Role definitions require GUID format IDs. This implementation generates a deterministic
|
|
104
|
+
* UUID based on the role definition's key properties to ensure:
|
|
105
|
+
* - Same GUID is generated on re-deployments with same parameters
|
|
106
|
+
* - Idempotent deployments (no duplicate role definitions)
|
|
107
|
+
* - Consistent behavior across deployment runs
|
|
108
|
+
*/
|
|
109
|
+
resolveName(props) {
|
|
110
|
+
const typedProps = props;
|
|
111
|
+
// Create a deterministic hash from key role definition properties
|
|
112
|
+
const hashInput = [
|
|
113
|
+
typedProps.roleName,
|
|
114
|
+
JSON.stringify(typedProps.assignableScopes),
|
|
115
|
+
].join("|");
|
|
116
|
+
const hash = (0, crypto_1.createHash)("sha256").update(hashInput).digest("hex");
|
|
117
|
+
// Convert hash to UUID format (8-4-4-4-12)
|
|
118
|
+
return [
|
|
119
|
+
hash.substring(0, 8),
|
|
120
|
+
hash.substring(8, 12),
|
|
121
|
+
hash.substring(12, 16),
|
|
122
|
+
hash.substring(16, 20),
|
|
123
|
+
hash.substring(20, 32),
|
|
124
|
+
].join("-");
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Creates the resource body for the Azure API call
|
|
128
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
129
|
+
*
|
|
130
|
+
* Note: Role definitions do not have a location property as they are
|
|
131
|
+
* tenant-specific resources deployed at subscription or management group scope.
|
|
132
|
+
*/
|
|
133
|
+
createResourceBody(props) {
|
|
134
|
+
const typedProps = props;
|
|
135
|
+
return {
|
|
136
|
+
properties: {
|
|
137
|
+
roleName: typedProps.roleName,
|
|
138
|
+
description: typedProps.description,
|
|
139
|
+
type: typedProps.type || "CustomRole",
|
|
140
|
+
permissions: typedProps.permissions,
|
|
141
|
+
assignableScopes: typedProps.assignableScopes,
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
// =============================================================================
|
|
146
|
+
// PUBLIC METHODS FOR ROLE DEFINITION OPERATIONS
|
|
147
|
+
// =============================================================================
|
|
148
|
+
/**
|
|
149
|
+
* Get the full resource identifier for use in other Azure resources
|
|
150
|
+
* Alias for the id property
|
|
151
|
+
*/
|
|
152
|
+
get resourceId() {
|
|
153
|
+
return this.id;
|
|
154
|
+
}
|
|
155
|
+
/**
|
|
156
|
+
* Get the role name
|
|
157
|
+
*/
|
|
158
|
+
get roleName() {
|
|
159
|
+
return this.props.roleName;
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get the role type
|
|
163
|
+
*/
|
|
164
|
+
get roleType() {
|
|
165
|
+
return this.props.type || "CustomRole";
|
|
166
|
+
}
|
|
167
|
+
// =============================================================================
|
|
168
|
+
// PRIVATE HELPER METHODS
|
|
169
|
+
// =============================================================================
|
|
170
|
+
/**
|
|
171
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
172
|
+
* Always includes body.properties.assignableScopes to handle Azure API format normalization
|
|
173
|
+
*/
|
|
174
|
+
_applyIgnoreChanges() {
|
|
175
|
+
// Always ignore assignableScopes format changes due to Azure API normalization
|
|
176
|
+
// Azure may return subscription-qualified format but accepts non-qualified format
|
|
177
|
+
const ignoreChanges = [
|
|
178
|
+
"body.properties.assignableScopes",
|
|
179
|
+
...(this.props.ignoreChanges || []),
|
|
180
|
+
];
|
|
181
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
182
|
+
ignore_changes: ignoreChanges,
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
exports.RoleDefinition = RoleDefinition;
|
|
187
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
188
|
+
RoleDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.RoleDefinition", version: "1.3.1" };
|
|
189
|
+
(() => {
|
|
190
|
+
azapi_resource_1.AzapiResource.registerSchemas(role_definition_schemas_1.ROLE_DEFINITION_TYPE, role_definition_schemas_1.ALL_ROLE_DEFINITION_VERSIONS);
|
|
191
|
+
})();
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-definition.js","sourceRoot":"","sources":["../../../src/azure-roledefinition/lib/role-definition.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,mCAAoC;AACpC,+BAA+B;AAE/B,uEAGmC;AACnC,8EAGmD;AAkJnD;;;;;;;;;;;;;;;;;GAiBG;AACH,MAAa,cAAe,SAAQ,8BAAa;IAiB/C,oBAAoB;IAEpB;;;;;;;;;OASG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,mFAAmF;QAEnF,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,+BAA+B;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,iCAAiC;SAC/C,CAAC,CAAC;QAEH,2DAA2D;QAC3D,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE1C,oCAAoC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gFAAgF;IAChF,+CAA+C;IAC/C,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,8CAAoB,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;;;;;;;OAQG;IACO,WAAW,CAAC,KAAyB;QAC7C,MAAM,UAAU,GAAG,KAA4B,CAAC;QAEhD,kEAAkE;QAClE,MAAM,SAAS,GAAG;YAChB,UAAU,CAAC,QAAQ;YACnB,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,gBAAgB,CAAC;SAC5C,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAEZ,MAAM,IAAI,GAAG,IAAA,mBAAU,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAElE,2CAA2C;QAC3C,OAAO;YACL,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;YACpB,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;YACrB,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,EAAE,CAAC;SACvB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACd,CAAC;IAED;;;;;;OAMG;IACO,kBAAkB,CAAC,KAAU;QACrC,MAAM,UAAU,GAAG,KAA4B,CAAC;QAChD,OAAO;YACL,UAAU,EAAE;gBACV,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,YAAY;gBACrC,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,gBAAgB,EAAE,UAAU,CAAC,gBAAgB;aAC9C;SACF,CAAC;IACJ,CAAC;IAED,gFAAgF;IAChF,gDAAgD;IAChD,gFAAgF;IAEhF;;;OAGG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED;;OAEG;IACH,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,YAAY,CAAC;IACzC,CAAC;IAED,gFAAgF;IAChF,yBAAyB;IACzB,gFAAgF;IAEhF;;;OAGG;IACK,mBAAmB;QACzB,+EAA+E;QAC/E,kFAAkF;QAClF,MAAM,aAAa,GAAG;YACpB,kCAAkC;YAClC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,EAAE,CAAC;SACpC,CAAC;QAEF,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,WAAW,EAAE;YAC9C,cAAc,EAAE,aAAa;SAC9B,CAAC,CAAC;IACL,CAAC;;AAjLH,wCAkLC;;;AAjLC;IACE,8BAAa,CAAC,eAAe,CAC3B,8CAAoB,EACpB,sDAA4B,CAC7B,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Unified Azure Role Definition implementation using VersionedAzapiResource framework\n *\n * This class provides a version-aware implementation for managing Azure Role Definitions\n * using the AZAPI provider. Role definitions define custom RBAC roles with specific\n * permissions that can be assigned to users, groups, or service principals.\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 custom role permissions (actions, notActions, dataActions, notDataActions)\n * - Assignable scopes configuration (subscription, resource group, management group)\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_DEFINITION_VERSIONS,\n  ROLE_DEFINITION_TYPE,\n} from \"./role-definition-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Permission configuration for role definitions\n * Defines what actions the role can perform on control plane and data plane\n */\nexport interface RoleDefinitionPermission {\n  /**\n   * Array of allowed control plane actions\n   * Actions are operations that can be performed on Azure resources\n   *\n   * @example [\"Microsoft.Compute/virtualMachines/read\", \"Microsoft.Compute/virtualMachines/start/action\"]\n   */\n  readonly actions?: string[];\n\n  /**\n   * Array of excluded control plane actions\n   * Actions that are explicitly denied even if included in actions array\n   *\n   * @example [\"Microsoft.Compute/virtualMachines/delete\"]\n   */\n  readonly notActions?: string[];\n\n  /**\n   * Array of allowed data plane actions\n   * Data actions are operations that can be performed on data within resources\n   *\n   * @example [\"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\"]\n   */\n  readonly dataActions?: string[];\n\n  /**\n   * Array of excluded data plane actions\n   * Data actions that are explicitly denied\n   *\n   * @example [\"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete\"]\n   */\n  readonly notDataActions?: string[];\n}\n\n/**\n * Properties for the unified Azure Role Definition\n *\n * Extends AzapiResourceProps with Role Definition specific properties\n */\nexport interface RoleDefinitionProps extends AzapiResourceProps {\n  /**\n   * The name of the role definition\n   * This is the display name shown in the Azure portal\n   * Required property\n   *\n   * @example \"Virtual Machine Reader\"\n   */\n  readonly roleName: string;\n\n  /**\n   * The role definition description\n   * Provides detailed information about what the role allows\n   *\n   * @example \"Can view virtual machines and their properties\"\n   */\n  readonly description?: string;\n\n  /**\n   * The type of role definition\n   * @default \"CustomRole\"\n   * @example \"CustomRole\", \"BuiltInRole\"\n   */\n  readonly type?: string;\n\n  /**\n   * An array of permissions objects that define what actions the role can perform\n   * Required property\n   *\n   * @example\n   * [\n   *   {\n   *     actions: [\"Microsoft.Compute/virtualMachines/read\"],\n   *     notActions: [],\n   *     dataActions: [],\n   *     notDataActions: []\n   *   }\n   * ]\n   */\n  readonly permissions: RoleDefinitionPermission[];\n\n  /**\n   * An array of scopes where this role can be assigned\n   * Can include subscription, resource group, or management group scopes\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 assignableScopes: 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 Definition\n * This is required for JSII compliance to support multi-language code generation\n */\nexport interface RoleDefinitionProperties {\n  /**\n   * The name of the role definition\n   */\n  readonly roleName: string;\n\n  /**\n   * The role definition description\n   */\n  readonly description?: string;\n\n  /**\n   * The type of role definition\n   */\n  readonly type?: string;\n\n  /**\n   * An array of permissions objects\n   */\n  readonly permissions: RoleDefinitionPermission[];\n\n  /**\n   * An array of assignable scopes\n   */\n  readonly assignableScopes: string[];\n}\n\n/**\n * The resource body interface for Azure Role Definition API calls\n * This matches the Azure REST API schema for role definitions\n */\nexport interface RoleDefinitionBody {\n  /**\n   * The properties of the role definition\n   */\n  readonly properties: RoleDefinitionProperties;\n}\n\n/**\n * Unified Azure Role Definition implementation\n *\n * This class provides a single, version-aware implementation for managing Azure\n * Role Definitions. It automatically handles version resolution, schema validation,\n * and property transformation.\n *\n * Note: Role definitions are tenant-specific resources deployed at subscription or\n * management group scope. Unlike most Azure resources, they do not have a location\n * property as they are not region-specific.\n *\n * @example\n * Basic custom role definition for read-only access to compute resources\n *\n * Advanced features like data plane actions and complex permissions are supported\n *\n * @stability stable\n */\nexport class RoleDefinition extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      ROLE_DEFINITION_TYPE,\n      ALL_ROLE_DEFINITION_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Role Definition instance\n   */\n  public readonly props: RoleDefinitionProps;\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 Definition using the VersionedAzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Role Definition\n   */\n  constructor(scope: Construct, id: string, props: RoleDefinitionProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Role Definition\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Role Definition\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the most recent stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2022-04-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Role Definitions\n   */\n  protected resourceType(): string {\n    return ROLE_DEFINITION_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Overrides the name resolution to generate deterministic GUIDs for role definitions\n   *\n   * Role definitions require GUID format IDs. This implementation generates a deterministic\n   * UUID based on the role definition's key properties to ensure:\n   * - Same GUID is generated on re-deployments with same parameters\n   * - Idempotent deployments (no duplicate role definitions)\n   * - Consistent behavior across deployment runs\n   */\n  protected resolveName(props: AzapiResourceProps): string {\n    const typedProps = props as RoleDefinitionProps;\n\n    // Create a deterministic hash from key role definition properties\n    const hashInput = [\n      typedProps.roleName,\n      JSON.stringify(typedProps.assignableScopes),\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   * 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 definitions do not have a location property as they are\n   * tenant-specific resources deployed at subscription or management group scope.\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as RoleDefinitionProps;\n    return {\n      properties: {\n        roleName: typedProps.roleName,\n        description: typedProps.description,\n        type: typedProps.type || \"CustomRole\",\n        permissions: typedProps.permissions,\n        assignableScopes: typedProps.assignableScopes,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR ROLE DEFINITION OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Get the role name\n   */\n  public get roleName(): string {\n    return this.props.roleName;\n  }\n\n  /**\n   * Get the role type\n   */\n  public get roleType(): string {\n    return this.props.type || \"CustomRole\";\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.assignableScopes to handle Azure API format normalization\n   */\n  private _applyIgnoreChanges(): void {\n    // Always ignore assignableScopes format changes due to Azure API normalization\n    // Azure may return subscription-qualified format but accepts non-qualified format\n    const ignoreChanges = [\n      \"body.properties.assignableScopes\",\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 Definition
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the RoleDefinition construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* The test creates custom RBAC roles with various permission configurations
|
|
8
|
+
* at subscription scope.
|
|
9
|
+
*
|
|
10
|
+
* Run with: npm run integration:nostream
|
|
11
|
+
*/
|
|
12
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Role Definition
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the RoleDefinition construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* The test creates custom RBAC roles with various permission configurations
|
|
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_definition_1 = require("../lib/role-definition");
|
|
21
|
+
// Generate unique test run metadata for this test suite
|
|
22
|
+
const testMetadata = new metadata_1.TestRunMetadata("role-definition-integration", {
|
|
23
|
+
maxAgeHours: 4,
|
|
24
|
+
});
|
|
25
|
+
/**
|
|
26
|
+
* Example stack demonstrating Role Definition usage
|
|
27
|
+
*/
|
|
28
|
+
class RoleDefinitionExampleStack 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
|
+
// Note: Role definition IDs are auto-generated as GUIDs by Azure.
|
|
53
|
+
// The 'name' parameter is not needed - Azure uses guid() to generate
|
|
54
|
+
// deterministic IDs based on deployment context for idempotency.
|
|
55
|
+
// Use 'roleName' for the human-readable display name and 'description'
|
|
56
|
+
// for additional context.
|
|
57
|
+
// Example 1: Basic read-only role for compute resources
|
|
58
|
+
new role_definition_1.RoleDefinition(this, "vm-reader-role", {
|
|
59
|
+
roleName: "Virtual Machine Reader",
|
|
60
|
+
description: "Can view virtual machines and their properties but cannot perform any actions",
|
|
61
|
+
type: "CustomRole",
|
|
62
|
+
permissions: [
|
|
63
|
+
{
|
|
64
|
+
actions: [
|
|
65
|
+
"Microsoft.Compute/virtualMachines/read",
|
|
66
|
+
"Microsoft.Compute/virtualMachines/instanceView/read",
|
|
67
|
+
"Microsoft.Compute/disks/read",
|
|
68
|
+
"Microsoft.Compute/snapshots/read",
|
|
69
|
+
"Microsoft.Network/networkInterfaces/read",
|
|
70
|
+
"Microsoft.Network/publicIPAddresses/read",
|
|
71
|
+
],
|
|
72
|
+
notActions: [],
|
|
73
|
+
dataActions: [],
|
|
74
|
+
notDataActions: [],
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
assignableScopes: [subscriptionScope],
|
|
78
|
+
tags: {
|
|
79
|
+
...this.systemTags(),
|
|
80
|
+
example: "basic",
|
|
81
|
+
purpose: "read-only-compute",
|
|
82
|
+
},
|
|
83
|
+
});
|
|
84
|
+
// Example 2: Advanced role with control plane and data plane permissions
|
|
85
|
+
new role_definition_1.RoleDefinition(this, "storage-operator-role", {
|
|
86
|
+
roleName: "Storage Operator",
|
|
87
|
+
description: "Can manage storage accounts and read/write blob data but cannot delete resources",
|
|
88
|
+
type: "CustomRole",
|
|
89
|
+
permissions: [
|
|
90
|
+
{
|
|
91
|
+
// Control plane actions - manage storage accounts
|
|
92
|
+
actions: [
|
|
93
|
+
"Microsoft.Storage/storageAccounts/read",
|
|
94
|
+
"Microsoft.Storage/storageAccounts/write",
|
|
95
|
+
"Microsoft.Storage/storageAccounts/listkeys/action",
|
|
96
|
+
"Microsoft.Storage/storageAccounts/regeneratekey/action",
|
|
97
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/read",
|
|
98
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/write",
|
|
99
|
+
],
|
|
100
|
+
// Explicitly deny delete operations
|
|
101
|
+
notActions: [
|
|
102
|
+
"Microsoft.Storage/storageAccounts/delete",
|
|
103
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/delete",
|
|
104
|
+
],
|
|
105
|
+
// Data plane actions - read and write blobs
|
|
106
|
+
dataActions: [
|
|
107
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read",
|
|
108
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/write",
|
|
109
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/add/action",
|
|
110
|
+
],
|
|
111
|
+
// Explicitly deny delete operations on data plane
|
|
112
|
+
notDataActions: [
|
|
113
|
+
"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete",
|
|
114
|
+
],
|
|
115
|
+
},
|
|
116
|
+
],
|
|
117
|
+
assignableScopes: [
|
|
118
|
+
subscriptionScope,
|
|
119
|
+
// Can also be assigned at resource group level
|
|
120
|
+
`${subscriptionScope}/resourceGroups/storage-rg`,
|
|
121
|
+
],
|
|
122
|
+
tags: {
|
|
123
|
+
...this.systemTags(),
|
|
124
|
+
example: "advanced",
|
|
125
|
+
purpose: "storage-operations",
|
|
126
|
+
},
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
describe("Role Definition Integration Test", () => {
|
|
131
|
+
it("should deploy, validate idempotency, and cleanup role definition resources", () => {
|
|
132
|
+
const app = cdktf_1.Testing.app();
|
|
133
|
+
const stack = new RoleDefinitionExampleStack(app, "test-role-definition");
|
|
134
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
135
|
+
// This will:
|
|
136
|
+
// 1. Run terraform apply to deploy resources (custom role definitions)
|
|
137
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
138
|
+
// 3. Run terraform destroy to cleanup resources
|
|
139
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
140
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
141
|
+
});
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"role-definition.integ.js","sourceRoot":"","sources":["../../../src/azure-roledefinition/test/role-definition.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Role Definition\n *\n * This test demonstrates basic usage of the RoleDefinition construct\n * and validates deployment, idempotency, and cleanup.\n *\n * The test creates custom RBAC roles with various permission configurations\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 { RoleDefinition } from \"../lib/role-definition\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\"role-definition-integration\", {\n  maxAgeHours: 4,\n});\n\n/**\n * Example stack demonstrating Role Definition usage\n */\nclass RoleDefinitionExampleStack 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    // Note: Role definition IDs are auto-generated as GUIDs by Azure.\n    // The 'name' parameter is not needed - Azure uses guid() to generate\n    // deterministic IDs based on deployment context for idempotency.\n    // Use 'roleName' for the human-readable display name and 'description'\n    // for additional context.\n\n    // Example 1: Basic read-only role for compute resources\n    new RoleDefinition(this, \"vm-reader-role\", {\n      roleName: \"Virtual Machine Reader\",\n      description:\n        \"Can view virtual machines and their properties but cannot perform any actions\",\n      type: \"CustomRole\",\n      permissions: [\n        {\n          actions: [\n            \"Microsoft.Compute/virtualMachines/read\",\n            \"Microsoft.Compute/virtualMachines/instanceView/read\",\n            \"Microsoft.Compute/disks/read\",\n            \"Microsoft.Compute/snapshots/read\",\n            \"Microsoft.Network/networkInterfaces/read\",\n            \"Microsoft.Network/publicIPAddresses/read\",\n          ],\n          notActions: [],\n          dataActions: [],\n          notDataActions: [],\n        },\n      ],\n      assignableScopes: [subscriptionScope],\n      tags: {\n        ...this.systemTags(),\n        example: \"basic\",\n        purpose: \"read-only-compute\",\n      },\n    });\n\n    // Example 2: Advanced role with control plane and data plane permissions\n    new RoleDefinition(this, \"storage-operator-role\", {\n      roleName: \"Storage Operator\",\n      description:\n        \"Can manage storage accounts and read/write blob data but cannot delete resources\",\n      type: \"CustomRole\",\n      permissions: [\n        {\n          // Control plane actions - manage storage accounts\n          actions: [\n            \"Microsoft.Storage/storageAccounts/read\",\n            \"Microsoft.Storage/storageAccounts/write\",\n            \"Microsoft.Storage/storageAccounts/listkeys/action\",\n            \"Microsoft.Storage/storageAccounts/regeneratekey/action\",\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/read\",\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/write\",\n          ],\n          // Explicitly deny delete operations\n          notActions: [\n            \"Microsoft.Storage/storageAccounts/delete\",\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/delete\",\n          ],\n          // Data plane actions - read and write blobs\n          dataActions: [\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/read\",\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/write\",\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/add/action\",\n          ],\n          // Explicitly deny delete operations on data plane\n          notDataActions: [\n            \"Microsoft.Storage/storageAccounts/blobServices/containers/blobs/delete\",\n          ],\n        },\n      ],\n      assignableScopes: [\n        subscriptionScope,\n        // Can also be assigned at resource group level\n        `${subscriptionScope}/resourceGroups/storage-rg`,\n      ],\n      tags: {\n        ...this.systemTags(),\n        example: \"advanced\",\n        purpose: \"storage-operations\",\n      },\n    });\n  }\n}\n\ndescribe(\"Role Definition Integration Test\", () => {\n  it(\"should deploy, validate idempotency, and cleanup role definition resources\", () => {\n    const app = Testing.app();\n    const stack = new RoleDefinitionExampleStack(app, \"test-role-definition\");\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources (custom role definitions)\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 RoleDefinition implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the unified RoleDefinition class that uses
|
|
5
|
+
* the VersionedAzapiResource framework. Tests cover automatic version resolution,
|
|
6
|
+
* explicit version pinning, schema validation, property transformation, and
|
|
7
|
+
* role definition-specific functionality.
|
|
8
|
+
*/
|
|
9
|
+
export {};
|