@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/.jsii +54846 -26661
  2. package/API.md +72091 -23784
  3. package/lib/azure-actiongroup/index.d.ts +0 -10
  4. package/lib/azure-actiongroup/index.js +1 -11
  5. package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
  6. package/lib/azure-actiongroup/lib/action-group.js +6 -32
  7. package/lib/azure-actiongroup/lib/index.d.ts +1 -4
  8. package/lib/azure-actiongroup/lib/index.js +2 -5
  9. package/lib/azure-activitylogalert/index.d.ts +0 -10
  10. package/lib/azure-activitylogalert/index.js +1 -11
  11. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
  12. package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
  13. package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
  14. package/lib/azure-activitylogalert/lib/index.js +2 -5
  15. package/lib/azure-aks/index.d.ts +0 -8
  16. package/lib/azure-aks/index.js +1 -11
  17. package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
  18. package/lib/azure-aks/lib/aks-cluster.js +13 -36
  19. package/lib/azure-aks/lib/index.d.ts +1 -10
  20. package/lib/azure-aks/lib/index.js +2 -21
  21. package/lib/azure-diagnosticsettings/index.d.ts +0 -6
  22. package/lib/azure-diagnosticsettings/index.js +1 -7
  23. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
  24. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
  25. package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
  26. package/lib/azure-diagnosticsettings/lib/index.js +2 -8
  27. package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
  28. package/lib/azure-dnsforwardingruleset/index.js +18 -0
  29. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
  30. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
  31. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
  32. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
  33. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
  34. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
  35. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
  36. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
  37. package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
  38. package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
  39. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
  40. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
  41. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
  42. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
  43. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
  44. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
  45. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
  46. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
  47. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
  48. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
  49. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
  50. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
  51. package/lib/azure-dnsresolver/index.d.ts +1 -0
  52. package/lib/azure-dnsresolver/index.js +18 -0
  53. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
  54. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
  55. package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
  56. package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
  57. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
  58. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
  59. package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
  60. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
  61. package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
  62. package/lib/azure-dnsresolver/lib/index.js +23 -0
  63. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
  64. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
  65. package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
  66. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
  67. package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
  68. package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
  69. package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
  70. package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
  71. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
  72. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
  73. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
  74. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
  75. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
  76. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
  77. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
  78. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
  79. package/lib/azure-dnszone/index.d.ts +1 -0
  80. package/lib/azure-dnszone/index.js +18 -0
  81. package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
  82. package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
  83. package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
  84. package/lib/azure-dnszone/lib/dns-zone.js +228 -0
  85. package/lib/azure-dnszone/lib/index.d.ts +2 -0
  86. package/lib/azure-dnszone/lib/index.js +19 -0
  87. package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
  88. package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
  89. package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
  90. package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
  91. package/lib/azure-metricalert/index.d.ts +0 -10
  92. package/lib/azure-metricalert/index.js +1 -11
  93. package/lib/azure-metricalert/lib/index.d.ts +1 -4
  94. package/lib/azure-metricalert/lib/index.js +2 -5
  95. package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
  96. package/lib/azure-metricalert/lib/metric-alert.js +6 -32
  97. package/lib/azure-networkinterface/index.d.ts +0 -3
  98. package/lib/azure-networkinterface/index.js +1 -4
  99. package/lib/azure-networkinterface/lib/index.d.ts +1 -5
  100. package/lib/azure-networkinterface/lib/index.js +2 -5
  101. package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
  102. package/lib/azure-networkinterface/lib/network-interface.js +14 -29
  103. package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
  104. package/lib/azure-networksecuritygroup/index.d.ts +0 -5
  105. package/lib/azure-networksecuritygroup/index.js +1 -6
  106. package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
  107. package/lib/azure-networksecuritygroup/lib/index.js +17 -14
  108. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
  109. package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
  110. package/lib/azure-policyassignment/index.d.ts +1 -0
  111. package/lib/azure-policyassignment/index.js +18 -0
  112. package/lib/azure-policyassignment/lib/index.d.ts +2 -0
  113. package/lib/azure-policyassignment/lib/index.js +19 -0
  114. package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
  115. package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
  116. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +342 -0
  117. package/lib/azure-policyassignment/lib/policy-assignment.js +228 -0
  118. package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
  119. package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
  120. package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
  121. package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
  122. package/lib/azure-policydefinition/index.d.ts +1 -0
  123. package/lib/azure-policydefinition/index.js +18 -0
  124. package/lib/azure-policydefinition/lib/index.d.ts +2 -0
  125. package/lib/azure-policydefinition/lib/index.js +19 -0
  126. package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
  127. package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
  128. package/lib/azure-policydefinition/lib/policy-definition.d.ts +260 -0
  129. package/lib/azure-policydefinition/lib/policy-definition.js +199 -0
  130. package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
  131. package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
  132. package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
  133. package/lib/azure-policydefinition/test/policy-definition.spec.js +596 -0
  134. package/lib/azure-privatednszone/index.d.ts +1 -0
  135. package/lib/azure-privatednszone/index.js +18 -0
  136. package/lib/azure-privatednszone/lib/index.d.ts +2 -0
  137. package/lib/azure-privatednszone/lib/index.js +19 -0
  138. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
  139. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
  140. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
  141. package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
  142. package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
  143. package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
  144. package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
  145. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
  146. package/lib/azure-privatednszonelink/index.d.ts +1 -0
  147. package/lib/azure-privatednszonelink/index.js +18 -0
  148. package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
  149. package/lib/azure-privatednszonelink/lib/index.js +19 -0
  150. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
  151. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
  152. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
  153. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
  154. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
  155. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
  156. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
  157. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
  158. package/lib/azure-publicipaddress/index.d.ts +0 -5
  159. package/lib/azure-publicipaddress/index.js +1 -6
  160. package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
  161. package/lib/azure-publicipaddress/lib/index.js +17 -17
  162. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
  163. package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
  164. package/lib/azure-resourcegroup/index.d.ts +0 -37
  165. package/lib/azure-resourcegroup/index.js +1 -39
  166. package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
  167. package/lib/azure-resourcegroup/lib/index.js +2 -43
  168. package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
  169. package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
  170. package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
  171. package/lib/azure-roleassignment/index.d.ts +1 -0
  172. package/lib/azure-roleassignment/index.js +18 -0
  173. package/lib/azure-roleassignment/lib/index.d.ts +2 -0
  174. package/lib/azure-roleassignment/lib/index.js +19 -0
  175. package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
  176. package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
  177. package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
  178. package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
  179. package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
  180. package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
  181. package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
  182. package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
  183. package/lib/azure-roledefinition/index.d.ts +1 -0
  184. package/lib/azure-roledefinition/index.js +18 -0
  185. package/lib/azure-roledefinition/lib/index.d.ts +2 -0
  186. package/lib/azure-roledefinition/lib/index.js +19 -0
  187. package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
  188. package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
  189. package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
  190. package/lib/azure-roledefinition/lib/role-definition.js +192 -0
  191. package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
  192. package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
  193. package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
  194. package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
  195. package/lib/azure-storageaccount/index.d.ts +0 -19
  196. package/lib/azure-storageaccount/index.js +1 -20
  197. package/lib/azure-storageaccount/lib/index.d.ts +1 -7
  198. package/lib/azure-storageaccount/lib/index.js +2 -8
  199. package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
  200. package/lib/azure-storageaccount/lib/storage-account.js +15 -29
  201. package/lib/azure-subnet/index.d.ts +0 -3
  202. package/lib/azure-subnet/index.js +1 -4
  203. package/lib/azure-subnet/lib/index.d.ts +1 -4
  204. package/lib/azure-subnet/lib/index.js +2 -5
  205. package/lib/azure-subnet/lib/subnet.d.ts +3 -14
  206. package/lib/azure-subnet/lib/subnet.js +28 -47
  207. package/lib/azure-subnet/test/subnet.integ.js +19 -7
  208. package/lib/azure-subnet/test/subnet.spec.js +1 -2
  209. package/lib/azure-virtualmachine/index.d.ts +0 -6
  210. package/lib/azure-virtualmachine/index.js +1 -7
  211. package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
  212. package/lib/azure-virtualmachine/lib/index.js +2 -21
  213. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
  214. package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
  215. package/lib/azure-virtualnetwork/index.d.ts +0 -9
  216. package/lib/azure-virtualnetwork/index.js +1 -11
  217. package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
  218. package/lib/azure-virtualnetwork/lib/index.js +17 -20
  219. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
  220. package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
  221. package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
  222. package/lib/azure-virtualnetworkmanager/index.js +18 -0
  223. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
  224. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
  225. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
  226. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
  227. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
  228. package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
  229. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
  230. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
  231. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
  232. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
  233. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
  234. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
  235. package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
  236. package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
  237. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
  238. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
  239. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
  240. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
  241. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
  242. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
  243. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
  244. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
  245. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
  246. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
  247. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
  248. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
  249. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
  250. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
  251. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
  252. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
  253. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
  254. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
  255. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
  256. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
  257. package/lib/azure-vmss/index.d.ts +0 -5
  258. package/lib/azure-vmss/index.js +1 -6
  259. package/lib/azure-vmss/lib/index.d.ts +0 -7
  260. package/lib/azure-vmss/lib/index.js +1 -21
  261. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
  262. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
  263. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
  264. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
  265. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +178 -26
  266. package/lib/core-azure/lib/azapi/azapi-resource.js +328 -90
  267. package/lib/core-azure/lib/azapi/azapi-resource.spec.js +2 -2
  268. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  269. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  270. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +5 -3
  271. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  272. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  273. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  274. package/lib/core-azure/lib/azapi/resource-schema-validator.d.ts +118 -0
  275. package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
  276. package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
  277. package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
  278. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
  279. package/lib/core-azure/lib/index.d.ts +2 -2
  280. package/lib/core-azure/lib/index.js +5 -5
  281. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  282. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  283. package/lib/index.d.ts +19 -0
  284. package/lib/index.js +21 -2
  285. package/lib/testing/index.js +2 -2
  286. package/lib/testing/lib/cleanup.d.ts +1 -0
  287. package/lib/testing/lib/cleanup.js +19 -12
  288. package/lib/testing/lib/metadata.js +19 -16
  289. package/package.json +1 -1
  290. package/scripts/cleanup-test-resources.ts +22 -4
  291. 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.0" };
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 {};