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