@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
@@ -183,15 +183,6 @@ export interface NetworkSecurityGroupProps extends AzapiResourceProps {
183
183
  * @stability stable
184
184
  */
185
185
  export declare class NetworkSecurityGroup extends AzapiResource {
186
- /**
187
- * Static initialization flag to ensure schemas are registered only once
188
- */
189
- private static schemasRegistered;
190
- /**
191
- * Ensures that Network Security Group schemas are registered with the ApiVersionManager
192
- * This is called once during the first NetworkSecurityGroup instantiation
193
- */
194
- private static ensureSchemasRegistered;
195
186
  /**
196
187
  * The input properties for this Network Security Group instance
197
188
  */
@@ -201,10 +192,6 @@ export declare class NetworkSecurityGroup extends AzapiResource {
201
192
  readonly locationOutput: cdktf.TerraformOutput;
202
193
  readonly securityRulesOutput: cdktf.TerraformOutput;
203
194
  readonly tagsOutput: cdktf.TerraformOutput;
204
- readonly id: string;
205
- readonly tags: {
206
- [key: string]: string;
207
- };
208
195
  /**
209
196
  * Creates a new Azure Network Security Group using the AzapiResource framework
210
197
  *
@@ -231,6 +218,10 @@ export declare class NetworkSecurityGroup extends AzapiResource {
231
218
  * Uses the framework's schema resolution to get the appropriate schema
232
219
  */
233
220
  protected apiSchema(): ApiSchema;
221
+ /**
222
+ * Indicates that location is required for Network Security Groups
223
+ */
224
+ protected requiresLocation(): boolean;
234
225
  /**
235
226
  * Creates the resource body for the Azure API call
236
227
  * Transforms the input properties into the JSON format expected by Azure REST API
@@ -25,7 +25,6 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
25
25
  const cdktf = require("cdktf");
26
26
  const network_security_group_schemas_1 = require("./network-security-group-schemas");
27
27
  const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
28
- const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-version-manager");
29
28
  /**
30
29
  * Azure Network Security Group implementation
31
30
  *
@@ -66,28 +65,7 @@ const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-
66
65
  * @stability stable
67
66
  */
68
67
  class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
69
- /**
70
- * Ensures that Network Security Group schemas are registered with the ApiVersionManager
71
- * This is called once during the first NetworkSecurityGroup instantiation
72
- */
73
- static ensureSchemasRegistered() {
74
- if (NetworkSecurityGroup.schemasRegistered) {
75
- return;
76
- }
77
- const apiVersionManager = api_version_manager_1.ApiVersionManager.instance();
78
- try {
79
- // Register all Network Security Group versions
80
- apiVersionManager.registerResourceType(network_security_group_schemas_1.NETWORK_SECURITY_GROUP_TYPE, network_security_group_schemas_1.ALL_NETWORK_SECURITY_GROUP_VERSIONS);
81
- NetworkSecurityGroup.schemasRegistered = true;
82
- console.log(`Registered ${network_security_group_schemas_1.ALL_NETWORK_SECURITY_GROUP_VERSIONS.length} API versions for ${network_security_group_schemas_1.NETWORK_SECURITY_GROUP_TYPE}`);
83
- }
84
- catch (error) {
85
- console.warn(`Failed to register Network Security Group schemas: ${error}. ` +
86
- `This may indicate the schemas are already registered or there's a configuration issue.`);
87
- // Don't throw here as the schemas might already be registered
88
- NetworkSecurityGroup.schemasRegistered = true;
89
- }
90
- }
68
+ // Public properties that match the original NetworkSecurityGroup interface
91
69
  /**
92
70
  * Creates a new Azure Network Security Group using the AzapiResource framework
93
71
  *
@@ -100,14 +78,9 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
100
78
  * @param props - Configuration properties for the Network Security Group
101
79
  */
102
80
  constructor(scope, id, props) {
103
- // Ensure schemas are registered before calling super
104
- NetworkSecurityGroup.ensureSchemasRegistered();
105
- // Call the parent constructor with the props
106
81
  super(scope, id, props);
107
82
  this.props = props;
108
83
  // Extract properties from the AZAPI resource outputs using Terraform interpolation
109
- this.id = `\${${this.terraformResource.fqn}.id}`;
110
- this.tags = props.tags || {};
111
84
  // Create Terraform outputs for easy access and referencing from other resources
112
85
  this.idOutput = new cdktf.TerraformOutput(this, "id", {
113
86
  value: this.id,
@@ -161,6 +134,12 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
161
134
  apiSchema() {
162
135
  return this.resolveSchema();
163
136
  }
137
+ /**
138
+ * Indicates that location is required for Network Security Groups
139
+ */
140
+ requiresLocation() {
141
+ return true;
142
+ }
164
143
  /**
165
144
  * Creates the resource body for the Azure API call
166
145
  * Transforms the input properties into the JSON format expected by Azure REST API
@@ -168,8 +147,8 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
168
147
  createResourceBody(props) {
169
148
  const typedProps = props;
170
149
  return {
171
- location: typedProps.location || "eastus",
172
- tags: typedProps.tags || {},
150
+ location: this.location,
151
+ tags: this.allTags(),
173
152
  properties: {
174
153
  securityRules: typedProps.securityRules,
175
154
  flushConnection: typedProps.flushConnection || false,
@@ -240,9 +219,8 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
240
219
  }
241
220
  exports.NetworkSecurityGroup = NetworkSecurityGroup;
242
221
  _a = JSII_RTTI_SYMBOL_1;
243
- NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.2.0" };
244
- /**
245
- * Static initialization flag to ensure schemas are registered only once
246
- */
247
- NetworkSecurityGroup.schemasRegistered = false;
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-security-group.js","sourceRoot":"","sources":["../../../src/azure-networksecuritygroup/lib/network-security-group.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,+BAA+B;AAE/B,qFAG0C;AAC1C,8EAGmD;AACnD,kGAA6F;AAkJ7F;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsCG;AACH,MAAa,oBAAqB,SAAQ,8BAAa;IAMrD;;;OAGG;IACK,MAAM,CAAC,uBAAuB;QACpC,IAAI,oBAAoB,CAAC,iBAAiB,EAAE,CAAC;YAC3C,OAAO;QACT,CAAC;QAED,MAAM,iBAAiB,GAAG,uCAAiB,CAAC,QAAQ,EAAE,CAAC;QAEvD,IAAI,CAAC;YACH,+CAA+C;YAC/C,iBAAiB,CAAC,oBAAoB,CACpC,4DAA2B,EAC3B,oEAAmC,CACpC,CAAC;YAEF,oBAAoB,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAE9C,OAAO,CAAC,GAAG,CACT,cAAc,oEAAmC,CAAC,MAAM,qBAAqB,4DAA2B,EAAE,CAC3G,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CACV,sDAAsD,KAAK,IAAI;gBAC7D,wFAAwF,CAC3F,CAAC;YACF,8DAA8D;YAC9D,oBAAoB,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAChD,CAAC;IACH,CAAC;IAkBD;;;;;;;;;;OAUG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAgC;QACxE,qDAAqD;QACrD,oBAAoB,CAAC,uBAAuB,EAAE,CAAC;QAE/C,6CAA6C;QAC7C,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,mFAAmF;QACnF,IAAI,CAAC,EAAE,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,MAAM,CAAC;QACjD,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;QAE7B,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,sCAAsC;SACpD,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,wCAAwC;SACtD,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YAChE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,YAAY;YACnD,WAAW,EAAE,4CAA4C;SAC1D,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,GAAG,IAAI,KAAK,CAAC,eAAe,CAClD,IAAI,EACJ,eAAe,EACf;YACE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,mCAAmC;YAC1E,WAAW,EAAE,8CAA8C;SAC5D,CACF,CAAC;QAEF,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,iDAAiD;SAC/D,CAAC,CAAC;QAEH,2DAA2D;QAC3D,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,mBAAmB,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QAC5D,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE1C,oCAAoC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gFAAgF;IAChF,wDAAwD;IACxD,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,4DAA2B,CAAC;IACrC,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACO,kBAAkB,CAAC,KAAU;QACrC,MAAM,UAAU,GAAG,KAAkC,CAAC;QACtD,OAAO;YACL,QAAQ,EAAE,UAAU,CAAC,QAAQ,IAAI,QAAQ;YACzC,IAAI,EAAE,UAAU,CAAC,IAAI,IAAI,EAAE;YAC3B,UAAU,EAAE;gBACV,aAAa,EAAE,UAAU,CAAC,aAAa;gBACvC,eAAe,EAAE,UAAU,CAAC,eAAe,IAAI,KAAK;aACrD;SACF,CAAC;IACJ,CAAC;IAED,gFAAgF;IAChF,uDAAuD;IACvD,gFAAgF;IAEhF;;;OAGG;IACH,IAAW,cAAc;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,iBAAiB,GAAG,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC3D,IAAI,iBAAiB,KAAK,CAAC,CAAC,IAAI,iBAAiB,GAAG,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACvE,OAAO,OAAO,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC;QACxC,CAAC;QACD,MAAM,IAAI,KAAK,CACb,kEAAkE,CACnE,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED;;;OAGG;IACH,IAAW,aAAa;QACtB,OAAO,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,mCAAmC,CAAC;IAC7E,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,GAAW,EAAE,KAAa;QACtC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACpB,IAAI,CAAC,KAAa,CAAC,IAAI,GAAG,EAAE,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,IAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAED;;;OAGG;IACI,SAAS,CAAC,GAAW;QAC1B,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,gFAAgF;IAChF,yBAAyB;IACzB,gFAAgF;IAEhF;;OAEG;IACK,mBAAmB;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,WAAW,EAAE;gBAC9C,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;aACzC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAxOH,oDAyOC;;;AAxOC;;GAEG;AACY,sCAAiB,GAAG,KAAK,CAAC","sourcesContent":["/**\n * Azure Network Security Group implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Network Security Groups that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2024-07-01 (Active)\n * - 2024-10-01 (Active)\n * - 2025-01-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 * - Full backward compatibility\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_NETWORK_SECURITY_GROUP_VERSIONS,\n  NETWORK_SECURITY_GROUP_TYPE,\n} from \"./network-security-group-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiVersionManager } from \"../../core-azure/lib/version-manager/api-version-manager\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Security rule configuration for Network Security Group\n */\nexport interface SecurityRule {\n  /**\n   * The name of the security rule\n   * Must be unique within the NSG\n   */\n  readonly name: string;\n\n  /**\n   * Properties of the security rule\n   */\n  readonly properties: SecurityRuleProperties;\n}\n\n/**\n * Properties for a security rule\n */\nexport interface SecurityRuleProperties {\n  /**\n   * Network protocol this rule applies to\n   * @example \"Tcp\", \"Udp\", \"Icmp\", \"Esp\", \"Ah\", \"*\"\n   */\n  readonly protocol: string;\n\n  /**\n   * The source port or range\n   * @example \"80\", \"8000-8999\", \"*\"\n   */\n  readonly sourcePortRange?: string;\n\n  /**\n   * The source port ranges (for multiple ranges)\n   * @example [\"80\", \"443\", \"8080-8090\"]\n   */\n  readonly sourcePortRanges?: string[];\n\n  /**\n   * The destination port or range\n   * @example \"443\", \"3389\", \"*\"\n   */\n  readonly destinationPortRange?: string;\n\n  /**\n   * The destination port ranges (for multiple ranges)\n   * @example [\"80\", \"443\"]\n   */\n  readonly destinationPortRanges?: string[];\n\n  /**\n   * The source address prefix\n   * @example \"10.0.0.0/16\", \"VirtualNetwork\", \"Internet\", \"*\"\n   */\n  readonly sourceAddressPrefix?: string;\n\n  /**\n   * The source address prefixes (for multiple sources)\n   * @example [\"10.0.0.0/16\", \"10.1.0.0/16\"]\n   */\n  readonly sourceAddressPrefixes?: string[];\n\n  /**\n   * The destination address prefix\n   * @example \"10.0.1.0/24\", \"VirtualNetwork\", \"*\"\n   */\n  readonly destinationAddressPrefix?: string;\n\n  /**\n   * The destination address prefixes (for multiple destinations)\n   * @example [\"10.0.1.0/24\", \"10.0.2.0/24\"]\n   */\n  readonly destinationAddressPrefixes?: string[];\n\n  /**\n   * Source application security groups\n   */\n  readonly sourceApplicationSecurityGroups?: any[];\n\n  /**\n   * Destination application security groups\n   */\n  readonly destinationApplicationSecurityGroups?: any[];\n\n  /**\n   * The network traffic is allowed or denied\n   * Must be \"Allow\" or \"Deny\"\n   */\n  readonly access: string;\n\n  /**\n   * The priority of the rule\n   * Value must be between 100 and 4096\n   * Lower values have higher priority\n   */\n  readonly priority: number;\n\n  /**\n   * The direction of the rule\n   * Must be \"Inbound\" or \"Outbound\"\n   */\n  readonly direction: string;\n\n  /**\n   * A description for this rule\n   * Restricted to 140 characters\n   */\n  readonly description?: string;\n}\n\n/**\n * Properties for the Azure Network Security Group\n *\n * Extends AzapiResourceProps with Network Security Group specific properties\n */\nexport interface NetworkSecurityGroupProps extends AzapiResourceProps {\n  /**\n   * Security rules for the network security group\n   * Optional - rules can also be added after creation\n   */\n  readonly securityRules?: SecurityRule[];\n\n  /**\n   * When enabled, flows created from NSG connections will be re-evaluated when rules are updated\n   * @defaultValue false\n   */\n  readonly flushConnection?: boolean;\n\n  /**\n   * Resource group ID where the NSG will be created\n   * Optional - will use the subscription scope if not provided\n   */\n  readonly resourceGroupId?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   *\n   * @example [\"tags\", \"securityRules\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Azure Network Security Group implementation\n *\n * This class provides a single, version-aware implementation that replaces\n * version-specific Network Security Group classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * @example\n * // Basic usage with automatic version resolution:\n * const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n *   name: \"my-nsg\",\n *   location: \"eastus\",\n *   securityRules: [{\n *     name: \"allow-ssh\",\n *     properties: {\n *       protocol: \"Tcp\",\n *       sourcePortRange: \"*\",\n *       destinationPortRange: \"22\",\n *       sourceAddressPrefix: \"*\",\n *       destinationAddressPrefix: \"*\",\n *       access: \"Allow\",\n *       priority: 100,\n *       direction: \"Inbound\"\n *     }\n *   }]\n * });\n *\n * @example\n * // Usage with explicit version pinning:\n * const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n *   name: \"my-nsg\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-07-01\",\n *   securityRules: [...]\n * });\n *\n * @stability stable\n */\nexport class NetworkSecurityGroup extends AzapiResource {\n  /**\n   * Static initialization flag to ensure schemas are registered only once\n   */\n  private static schemasRegistered = false;\n\n  /**\n   * Ensures that Network Security Group schemas are registered with the ApiVersionManager\n   * This is called once during the first NetworkSecurityGroup instantiation\n   */\n  private static ensureSchemasRegistered(): void {\n    if (NetworkSecurityGroup.schemasRegistered) {\n      return;\n    }\n\n    const apiVersionManager = ApiVersionManager.instance();\n\n    try {\n      // Register all Network Security Group versions\n      apiVersionManager.registerResourceType(\n        NETWORK_SECURITY_GROUP_TYPE,\n        ALL_NETWORK_SECURITY_GROUP_VERSIONS,\n      );\n\n      NetworkSecurityGroup.schemasRegistered = true;\n\n      console.log(\n        `Registered ${ALL_NETWORK_SECURITY_GROUP_VERSIONS.length} API versions for ${NETWORK_SECURITY_GROUP_TYPE}`,\n      );\n    } catch (error) {\n      console.warn(\n        `Failed to register Network Security Group schemas: ${error}. ` +\n          `This may indicate the schemas are already registered or there's a configuration issue.`,\n      );\n      // Don't throw here as the schemas might already be registered\n      NetworkSecurityGroup.schemasRegistered = true;\n    }\n  }\n\n  /**\n   * The input properties for this Network Security Group instance\n   */\n  public readonly props: NetworkSecurityGroupProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly securityRulesOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n\n  // Public properties that match the original NetworkSecurityGroup interface\n  public readonly id: string;\n  public readonly tags: { [key: string]: string };\n\n  /**\n   * Creates a new Azure Network Security Group using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation. It maintains full backward compatibility\n   * with existing Network Security Group implementations.\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 Network Security Group\n   */\n  constructor(scope: Construct, id: string, props: NetworkSecurityGroupProps) {\n    // Ensure schemas are registered before calling super\n    NetworkSecurityGroup.ensureSchemasRegistered();\n\n    // Call the parent constructor with the props\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n    this.id = `\\${${this.terraformResource.fqn}.id}`;\n    this.tags = props.tags || {};\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 Network Security Group\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Network Security Group\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Network Security Group\",\n    });\n\n    this.securityRulesOutput = new cdktf.TerraformOutput(\n      this,\n      \"securityRules\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.securityRules}`,\n        description: \"Security rules of the Network Security Group\",\n      },\n    );\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Network Security Group\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.securityRulesOutput.overrideLogicalId(\"securityRules\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource\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 \"2024-10-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Network Security Groups\n   */\n  protected resourceType(): string {\n    return NETWORK_SECURITY_GROUP_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  protected createResourceBody(props: any): any {\n    const typedProps = props as NetworkSecurityGroupProps;\n    return {\n      location: typedProps.location || \"eastus\",\n      tags: typedProps.tags || {},\n      properties: {\n        securityRules: typedProps.securityRules,\n        flushConnection: typedProps.flushConnection || false,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR NETWORK SECURITY GROUP OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subscription ID from the Network Security Group ID\n   * Extracts the subscription ID from the Azure resource ID format\n   */\n  public get subscriptionId(): string {\n    const idParts = this.id.split(\"/\");\n    const subscriptionIndex = idParts.indexOf(\"subscriptions\");\n    if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {\n      return idParts[subscriptionIndex + 1];\n    }\n    throw new Error(\n      \"Unable to extract subscription ID from Network Security Group ID\",\n    );\n  }\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property to match original interface\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Get the security rules output value\n   * Returns the Terraform interpolation string for the security rules\n   */\n  public get securityRules(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.securityRules}`;\n  }\n\n  /**\n   * Add a tag to the Network Security Group\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the Network Security Group\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\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        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
222
+ NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.3.0" };
223
+ (() => {
224
+ azapi_resource_1.AzapiResource.registerSchemas(network_security_group_schemas_1.NETWORK_SECURITY_GROUP_TYPE, network_security_group_schemas_1.ALL_NETWORK_SECURITY_GROUP_VERSIONS);
225
+ })();
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-security-group.js","sourceRoot":"","sources":["../../../src/azure-networksecuritygroup/lib/network-security-group.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Network Security Group implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Network Security Groups that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2024-07-01 (Active)\n * - 2024-10-01 (Active)\n * - 2025-01-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 * - Full backward compatibility\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_NETWORK_SECURITY_GROUP_VERSIONS,\n  NETWORK_SECURITY_GROUP_TYPE,\n} from \"./network-security-group-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 * Security rule configuration for Network Security Group\n */\nexport interface SecurityRule {\n  /**\n   * The name of the security rule\n   * Must be unique within the NSG\n   */\n  readonly name: string;\n\n  /**\n   * Properties of the security rule\n   */\n  readonly properties: SecurityRuleProperties;\n}\n\n/**\n * Properties for a security rule\n */\nexport interface SecurityRuleProperties {\n  /**\n   * Network protocol this rule applies to\n   * @example \"Tcp\", \"Udp\", \"Icmp\", \"Esp\", \"Ah\", \"*\"\n   */\n  readonly protocol: string;\n\n  /**\n   * The source port or range\n   * @example \"80\", \"8000-8999\", \"*\"\n   */\n  readonly sourcePortRange?: string;\n\n  /**\n   * The source port ranges (for multiple ranges)\n   * @example [\"80\", \"443\", \"8080-8090\"]\n   */\n  readonly sourcePortRanges?: string[];\n\n  /**\n   * The destination port or range\n   * @example \"443\", \"3389\", \"*\"\n   */\n  readonly destinationPortRange?: string;\n\n  /**\n   * The destination port ranges (for multiple ranges)\n   * @example [\"80\", \"443\"]\n   */\n  readonly destinationPortRanges?: string[];\n\n  /**\n   * The source address prefix\n   * @example \"10.0.0.0/16\", \"VirtualNetwork\", \"Internet\", \"*\"\n   */\n  readonly sourceAddressPrefix?: string;\n\n  /**\n   * The source address prefixes (for multiple sources)\n   * @example [\"10.0.0.0/16\", \"10.1.0.0/16\"]\n   */\n  readonly sourceAddressPrefixes?: string[];\n\n  /**\n   * The destination address prefix\n   * @example \"10.0.1.0/24\", \"VirtualNetwork\", \"*\"\n   */\n  readonly destinationAddressPrefix?: string;\n\n  /**\n   * The destination address prefixes (for multiple destinations)\n   * @example [\"10.0.1.0/24\", \"10.0.2.0/24\"]\n   */\n  readonly destinationAddressPrefixes?: string[];\n\n  /**\n   * Source application security groups\n   */\n  readonly sourceApplicationSecurityGroups?: any[];\n\n  /**\n   * Destination application security groups\n   */\n  readonly destinationApplicationSecurityGroups?: any[];\n\n  /**\n   * The network traffic is allowed or denied\n   * Must be \"Allow\" or \"Deny\"\n   */\n  readonly access: string;\n\n  /**\n   * The priority of the rule\n   * Value must be between 100 and 4096\n   * Lower values have higher priority\n   */\n  readonly priority: number;\n\n  /**\n   * The direction of the rule\n   * Must be \"Inbound\" or \"Outbound\"\n   */\n  readonly direction: string;\n\n  /**\n   * A description for this rule\n   * Restricted to 140 characters\n   */\n  readonly description?: string;\n}\n\n/**\n * Properties for the Azure Network Security Group\n *\n * Extends AzapiResourceProps with Network Security Group specific properties\n */\nexport interface NetworkSecurityGroupProps extends AzapiResourceProps {\n  /**\n   * Security rules for the network security group\n   * Optional - rules can also be added after creation\n   */\n  readonly securityRules?: SecurityRule[];\n\n  /**\n   * When enabled, flows created from NSG connections will be re-evaluated when rules are updated\n   * @defaultValue false\n   */\n  readonly flushConnection?: boolean;\n\n  /**\n   * Resource group ID where the NSG will be created\n   * Optional - will use the subscription scope if not provided\n   */\n  readonly resourceGroupId?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   *\n   * @example [\"tags\", \"securityRules\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Azure Network Security Group implementation\n *\n * This class provides a single, version-aware implementation that replaces\n * version-specific Network Security Group classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * @example\n * // Basic usage with automatic version resolution:\n * const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n *   name: \"my-nsg\",\n *   location: \"eastus\",\n *   securityRules: [{\n *     name: \"allow-ssh\",\n *     properties: {\n *       protocol: \"Tcp\",\n *       sourcePortRange: \"*\",\n *       destinationPortRange: \"22\",\n *       sourceAddressPrefix: \"*\",\n *       destinationAddressPrefix: \"*\",\n *       access: \"Allow\",\n *       priority: 100,\n *       direction: \"Inbound\"\n *     }\n *   }]\n * });\n *\n * @example\n * // Usage with explicit version pinning:\n * const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n *   name: \"my-nsg\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-07-01\",\n *   securityRules: [...]\n * });\n *\n * @stability stable\n */\nexport class NetworkSecurityGroup extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      NETWORK_SECURITY_GROUP_TYPE,\n      ALL_NETWORK_SECURITY_GROUP_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Network Security Group instance\n   */\n  public readonly props: NetworkSecurityGroupProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly securityRulesOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n\n  // Public properties that match the original NetworkSecurityGroup interface\n\n  /**\n   * Creates a new Azure Network Security Group using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation. It maintains full backward compatibility\n   * with existing Network Security Group implementations.\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 Network Security Group\n   */\n  constructor(scope: Construct, id: string, props: NetworkSecurityGroupProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Network Security Group\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Network Security Group\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Network Security Group\",\n    });\n\n    this.securityRulesOutput = new cdktf.TerraformOutput(\n      this,\n      \"securityRules\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.securityRules}`,\n        description: \"Security rules of the Network Security Group\",\n      },\n    );\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Network Security Group\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.securityRulesOutput.overrideLogicalId(\"securityRules\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource\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 \"2024-10-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Network Security Groups\n   */\n  protected resourceType(): string {\n    return NETWORK_SECURITY_GROUP_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   * Indicates that location is required for Network Security Groups\n   */\n  protected requiresLocation(): boolean {\n    return true;\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  protected createResourceBody(props: any): any {\n    const typedProps = props as NetworkSecurityGroupProps;\n    return {\n      location: this.location,\n      tags: this.allTags(),\n      properties: {\n        securityRules: typedProps.securityRules,\n        flushConnection: typedProps.flushConnection || false,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR NETWORK SECURITY GROUP OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subscription ID from the Network Security Group ID\n   * Extracts the subscription ID from the Azure resource ID format\n   */\n  public get subscriptionId(): string {\n    const idParts = this.id.split(\"/\");\n    const subscriptionIndex = idParts.indexOf(\"subscriptions\");\n    if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {\n      return idParts[subscriptionIndex + 1];\n    }\n    throw new Error(\n      \"Unable to extract subscription ID from Network Security Group ID\",\n    );\n  }\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property to match original interface\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Get the security rules output value\n   * Returns the Terraform interpolation string for the security rules\n   */\n  public get securityRules(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.securityRules}`;\n  }\n\n  /**\n   * Add a tag to the Network Security Group\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the Network Security Group\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\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        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
@@ -0,0 +1 @@
1
+ export * from "./lib";
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./lib"), exports);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXp1cmUtcG9saWN5YXNzaWdubWVudC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsd0NBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vbGliXCI7XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from "./policy-assignment-schemas";
2
+ export * from "./policy-assignment";
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./policy-assignment-schemas"), exports);
18
+ __exportStar(require("./policy-assignment"), exports);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUtcG9saWN5YXNzaWdubWVudC9saWIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLDhEQUE0QztBQUM1QyxzREFBb0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9wb2xpY3ktYXNzaWdubWVudC1zY2hlbWFzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9wb2xpY3ktYXNzaWdubWVudFwiO1xuIl19
@@ -0,0 +1,25 @@
1
+ /**
2
+ * API schemas for Azure Policy Assignment across all supported versions
3
+ *
4
+ * This file defines the complete API schemas for Microsoft.Authorization/policyAssignments
5
+ * across all supported API versions. The schemas are used by the VersionedAzapiResource
6
+ * framework for validation, transformation, and version management.
7
+ */
8
+ import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
9
+ /**
10
+ * API Schema for Policy Assignment version 2022-06-01
11
+ * This is the latest stable API version for policy assignments
12
+ */
13
+ export declare const POLICY_ASSIGNMENT_SCHEMA_2022_06_01: ApiSchema;
14
+ /**
15
+ * Version configuration for Policy Assignment 2022-06-01
16
+ */
17
+ export declare const POLICY_ASSIGNMENT_VERSION_2022_06_01: VersionConfig;
18
+ /**
19
+ * All supported Policy Assignment versions for registration
20
+ */
21
+ export declare const ALL_POLICY_ASSIGNMENT_VERSIONS: VersionConfig[];
22
+ /**
23
+ * Resource type constant
24
+ */
25
+ export declare const POLICY_ASSIGNMENT_TYPE = "Microsoft.Authorization/policyAssignments";
@@ -0,0 +1,260 @@
1
+ "use strict";
2
+ /**
3
+ * API schemas for Azure Policy Assignment across all supported versions
4
+ *
5
+ * This file defines the complete API schemas for Microsoft.Authorization/policyAssignments
6
+ * across all supported API versions. The schemas are used by the VersionedAzapiResource
7
+ * framework for validation, transformation, and version management.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.POLICY_ASSIGNMENT_TYPE = exports.ALL_POLICY_ASSIGNMENT_VERSIONS = exports.POLICY_ASSIGNMENT_VERSION_2022_06_01 = exports.POLICY_ASSIGNMENT_SCHEMA_2022_06_01 = void 0;
11
+ const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
12
+ // =============================================================================
13
+ // COMMON PROPERTY DEFINITIONS
14
+ // =============================================================================
15
+ /**
16
+ * Common property definitions shared across all Policy Assignment versions
17
+ */
18
+ const COMMON_PROPERTIES = {
19
+ name: {
20
+ dataType: version_interfaces_1.PropertyType.STRING,
21
+ required: false,
22
+ description: "The name of the policy assignment. Must be unique within the scope",
23
+ validation: [
24
+ {
25
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
26
+ value: "^[a-zA-Z0-9_-]+$",
27
+ message: "Policy assignment name can only contain alphanumeric characters, underscores, and hyphens",
28
+ },
29
+ {
30
+ ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
31
+ value: { minLength: 1, maxLength: 64 },
32
+ message: "Policy assignment name must be between 1 and 64 characters",
33
+ },
34
+ ],
35
+ },
36
+ policyDefinitionId: {
37
+ dataType: version_interfaces_1.PropertyType.STRING,
38
+ required: true,
39
+ description: "The policy definition ID to assign. This can be a built-in or custom policy definition",
40
+ validation: [
41
+ {
42
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
43
+ message: "Policy definition ID is required for policy assignments",
44
+ },
45
+ {
46
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
47
+ value: version_interfaces_1.PropertyType.STRING,
48
+ message: "Policy definition ID must be a string",
49
+ },
50
+ ],
51
+ },
52
+ scope: {
53
+ dataType: version_interfaces_1.PropertyType.STRING,
54
+ required: true,
55
+ description: "The scope at which the policy assignment is applied (subscription, resource group, or resource)",
56
+ validation: [
57
+ {
58
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
59
+ message: "Scope is required for policy assignments",
60
+ },
61
+ {
62
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
63
+ value: version_interfaces_1.PropertyType.STRING,
64
+ message: "Scope must be a string",
65
+ },
66
+ ],
67
+ },
68
+ displayName: {
69
+ dataType: version_interfaces_1.PropertyType.STRING,
70
+ required: false,
71
+ description: "The display name of the policy assignment",
72
+ validation: [
73
+ {
74
+ ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
75
+ value: { minLength: 1, maxLength: 128 },
76
+ message: "Display name must be between 1 and 128 characters",
77
+ },
78
+ ],
79
+ },
80
+ description: {
81
+ dataType: version_interfaces_1.PropertyType.STRING,
82
+ required: false,
83
+ description: "The policy assignment description. Provides detailed information about the assignment",
84
+ validation: [
85
+ {
86
+ ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
87
+ value: { minLength: 0, maxLength: 512 },
88
+ message: "Description must not exceed 512 characters",
89
+ },
90
+ ],
91
+ },
92
+ enforcementMode: {
93
+ dataType: version_interfaces_1.PropertyType.STRING,
94
+ required: false,
95
+ defaultValue: "Default",
96
+ description: "The enforcement mode of the policy assignment. Valid values: Default, DoNotEnforce",
97
+ validation: [
98
+ {
99
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
100
+ value: "^(Default|DoNotEnforce)$",
101
+ message: "Enforcement mode must be either Default or DoNotEnforce",
102
+ },
103
+ ],
104
+ },
105
+ parameters: {
106
+ dataType: version_interfaces_1.PropertyType.OBJECT,
107
+ required: false,
108
+ description: "Parameters for the policy assignment. Provides values for parameters defined in the policy definition",
109
+ validation: [
110
+ {
111
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
112
+ value: version_interfaces_1.PropertyType.OBJECT,
113
+ message: "Parameters must be a valid JSON object",
114
+ },
115
+ ],
116
+ },
117
+ metadata: {
118
+ dataType: version_interfaces_1.PropertyType.OBJECT,
119
+ required: false,
120
+ description: "Metadata for the policy assignment. Used to store additional information like assignedBy, parameterScopes, etc.",
121
+ validation: [
122
+ {
123
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
124
+ value: version_interfaces_1.PropertyType.OBJECT,
125
+ message: "Metadata must be a valid JSON object",
126
+ },
127
+ ],
128
+ },
129
+ identity: {
130
+ dataType: version_interfaces_1.PropertyType.OBJECT,
131
+ required: false,
132
+ description: "The managed identity associated with the policy assignment. Required for policies with deployIfNotExists or modify effects",
133
+ validation: [
134
+ {
135
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
136
+ value: version_interfaces_1.PropertyType.OBJECT,
137
+ message: "Identity must be a valid JSON object",
138
+ },
139
+ ],
140
+ },
141
+ notScopes: {
142
+ dataType: version_interfaces_1.PropertyType.ARRAY,
143
+ required: false,
144
+ description: "The policy's excluded scopes. Resources within these scopes will not be evaluated by the policy",
145
+ validation: [
146
+ {
147
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
148
+ value: version_interfaces_1.PropertyType.ARRAY,
149
+ message: "NotScopes must be an array of strings",
150
+ },
151
+ ],
152
+ },
153
+ nonComplianceMessages: {
154
+ dataType: version_interfaces_1.PropertyType.ARRAY,
155
+ required: false,
156
+ description: "The non-compliance messages for the policy assignment. Provides custom messages when resources are non-compliant",
157
+ validation: [
158
+ {
159
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
160
+ value: version_interfaces_1.PropertyType.ARRAY,
161
+ message: "NonComplianceMessages must be an array of objects",
162
+ },
163
+ ],
164
+ },
165
+ ignoreChanges: {
166
+ dataType: version_interfaces_1.PropertyType.ARRAY,
167
+ required: false,
168
+ description: "Array of property names to ignore during updates",
169
+ validation: [
170
+ {
171
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
172
+ value: version_interfaces_1.PropertyType.ARRAY,
173
+ message: "IgnoreChanges must be an array of strings",
174
+ },
175
+ ],
176
+ },
177
+ };
178
+ // =============================================================================
179
+ // VERSION-SPECIFIC SCHEMAS
180
+ // =============================================================================
181
+ /**
182
+ * API Schema for Policy Assignment version 2022-06-01
183
+ * This is the latest stable API version for policy assignments
184
+ */
185
+ exports.POLICY_ASSIGNMENT_SCHEMA_2022_06_01 = {
186
+ resourceType: "Microsoft.Authorization/policyAssignments",
187
+ version: "2022-06-01",
188
+ properties: {
189
+ ...COMMON_PROPERTIES,
190
+ },
191
+ required: ["policyDefinitionId", "scope"],
192
+ optional: [
193
+ "name",
194
+ "displayName",
195
+ "description",
196
+ "enforcementMode",
197
+ "parameters",
198
+ "metadata",
199
+ "identity",
200
+ "notScopes",
201
+ "nonComplianceMessages",
202
+ "ignoreChanges",
203
+ ],
204
+ deprecated: [],
205
+ transformationRules: {},
206
+ validationRules: [
207
+ {
208
+ property: "policyDefinitionId",
209
+ rules: [
210
+ {
211
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
212
+ message: "Policy definition ID is required for policy assignments",
213
+ },
214
+ ],
215
+ },
216
+ {
217
+ property: "scope",
218
+ rules: [
219
+ {
220
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
221
+ message: "Scope is required for policy assignments",
222
+ },
223
+ ],
224
+ },
225
+ ],
226
+ };
227
+ // =============================================================================
228
+ // VERSION CONFIGURATIONS
229
+ // =============================================================================
230
+ /**
231
+ * Version configuration for Policy Assignment 2022-06-01
232
+ */
233
+ exports.POLICY_ASSIGNMENT_VERSION_2022_06_01 = {
234
+ version: "2022-06-01",
235
+ schema: exports.POLICY_ASSIGNMENT_SCHEMA_2022_06_01,
236
+ supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
237
+ releaseDate: "2022-06-01",
238
+ deprecationDate: undefined,
239
+ sunsetDate: undefined,
240
+ breakingChanges: [],
241
+ migrationGuide: "/docs/policy-assignment/migration-2022-06-01",
242
+ changeLog: [
243
+ {
244
+ changeType: "added",
245
+ description: "Stable release of Policy Assignment API with full support for enforcement modes, identity, and non-compliance messages",
246
+ breaking: false,
247
+ },
248
+ ],
249
+ };
250
+ /**
251
+ * All supported Policy Assignment versions for registration
252
+ */
253
+ exports.ALL_POLICY_ASSIGNMENT_VERSIONS = [
254
+ exports.POLICY_ASSIGNMENT_VERSION_2022_06_01,
255
+ ];
256
+ /**
257
+ * Resource type constant
258
+ */
259
+ exports.POLICY_ASSIGNMENT_TYPE = "Microsoft.Authorization/policyAssignments";
260
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-assignment-schemas.js","sourceRoot":"","sources":["../../../src/azure-policyassignment/lib/policy-assignment-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure Policy Assignment across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Authorization/policyAssignments\n * across all supported API versions. The schemas are used by the VersionedAzapiResource\n * framework for validation, transformation, and version management.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all Policy Assignment versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The name of the policy assignment. Must be unique within the scope\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9_-]+$\",\n        message:\n          \"Policy assignment name can only contain alphanumeric characters, underscores, and hyphens\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 64 },\n        message: \"Policy assignment name must be between 1 and 64 characters\",\n      },\n    ],\n  },\n  policyDefinitionId: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The policy definition ID to assign. This can be a built-in or custom policy definition\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Policy definition ID is required for policy assignments\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"Policy definition ID must be a string\",\n      },\n    ],\n  },\n  scope: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The scope at which the policy assignment is applied (subscription, resource group, or resource)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Scope is required for policy assignments\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"Scope must be a string\",\n      },\n    ],\n  },\n  displayName: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description: \"The display name of the policy assignment\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 128 },\n        message: \"Display name must be between 1 and 128 characters\",\n      },\n    ],\n  },\n  description: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The policy assignment description. Provides detailed information about the assignment\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 0, maxLength: 512 },\n        message: \"Description must not exceed 512 characters\",\n      },\n    ],\n  },\n  enforcementMode: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Default\",\n    description:\n      \"The enforcement mode of the policy assignment. Valid values: Default, DoNotEnforce\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^(Default|DoNotEnforce)$\",\n        message: \"Enforcement mode must be either Default or DoNotEnforce\",\n      },\n    ],\n  },\n  parameters: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    description:\n      \"Parameters for the policy assignment. Provides values for parameters defined in the policy definition\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Parameters must be a valid JSON object\",\n      },\n    ],\n  },\n  metadata: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    description:\n      \"Metadata for the policy assignment. Used to store additional information like assignedBy, parameterScopes, etc.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Metadata must be a valid JSON object\",\n      },\n    ],\n  },\n  identity: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    description:\n      \"The managed identity associated with the policy assignment. Required for policies with deployIfNotExists or modify effects\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Identity must be a valid JSON object\",\n      },\n    ],\n  },\n  notScopes: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"The policy's excluded scopes. Resources within these scopes will not be evaluated by the policy\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"NotScopes must be an array of strings\",\n      },\n    ],\n  },\n  nonComplianceMessages: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"The non-compliance messages for the policy assignment. Provides custom messages when resources are non-compliant\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"NonComplianceMessages must be an array of objects\",\n      },\n    ],\n  },\n  ignoreChanges: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description: \"Array of property names to ignore during updates\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"IgnoreChanges must be an array of strings\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Policy Assignment version 2022-06-01\n * This is the latest stable API version for policy assignments\n */\nexport const POLICY_ASSIGNMENT_SCHEMA_2022_06_01: ApiSchema = {\n  resourceType: \"Microsoft.Authorization/policyAssignments\",\n  version: \"2022-06-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"policyDefinitionId\", \"scope\"],\n  optional: [\n    \"name\",\n    \"displayName\",\n    \"description\",\n    \"enforcementMode\",\n    \"parameters\",\n    \"metadata\",\n    \"identity\",\n    \"notScopes\",\n    \"nonComplianceMessages\",\n    \"ignoreChanges\",\n  ],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"policyDefinitionId\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Policy definition ID is required for policy assignments\",\n        },\n      ],\n    },\n    {\n      property: \"scope\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Scope is required for policy assignments\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Policy Assignment 2022-06-01\n */\nexport const POLICY_ASSIGNMENT_VERSION_2022_06_01: VersionConfig = {\n  version: \"2022-06-01\",\n  schema: POLICY_ASSIGNMENT_SCHEMA_2022_06_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2022-06-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/policy-assignment/migration-2022-06-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of Policy Assignment API with full support for enforcement modes, identity, and non-compliance messages\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Policy Assignment versions for registration\n */\nexport const ALL_POLICY_ASSIGNMENT_VERSIONS: VersionConfig[] = [\n  POLICY_ASSIGNMENT_VERSION_2022_06_01,\n];\n\n/**\n * Resource type constant\n */\nexport const POLICY_ASSIGNMENT_TYPE =\n  \"Microsoft.Authorization/policyAssignments\";\n"]}