@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/.jsii +54846 -26661
  2. package/API.md +72091 -23784
  3. package/lib/azure-actiongroup/index.d.ts +0 -10
  4. package/lib/azure-actiongroup/index.js +1 -11
  5. package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
  6. package/lib/azure-actiongroup/lib/action-group.js +6 -32
  7. package/lib/azure-actiongroup/lib/index.d.ts +1 -4
  8. package/lib/azure-actiongroup/lib/index.js +2 -5
  9. package/lib/azure-activitylogalert/index.d.ts +0 -10
  10. package/lib/azure-activitylogalert/index.js +1 -11
  11. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
  12. package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
  13. package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
  14. package/lib/azure-activitylogalert/lib/index.js +2 -5
  15. package/lib/azure-aks/index.d.ts +0 -8
  16. package/lib/azure-aks/index.js +1 -11
  17. package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
  18. package/lib/azure-aks/lib/aks-cluster.js +13 -36
  19. package/lib/azure-aks/lib/index.d.ts +1 -10
  20. package/lib/azure-aks/lib/index.js +2 -21
  21. package/lib/azure-diagnosticsettings/index.d.ts +0 -6
  22. package/lib/azure-diagnosticsettings/index.js +1 -7
  23. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
  24. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
  25. package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
  26. package/lib/azure-diagnosticsettings/lib/index.js +2 -8
  27. package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
  28. package/lib/azure-dnsforwardingruleset/index.js +18 -0
  29. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
  30. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
  31. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
  32. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
  33. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
  34. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
  35. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
  36. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
  37. package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
  38. package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
  39. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
  40. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
  41. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
  42. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
  43. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
  44. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
  45. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
  46. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
  47. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
  48. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
  49. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
  50. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
  51. package/lib/azure-dnsresolver/index.d.ts +1 -0
  52. package/lib/azure-dnsresolver/index.js +18 -0
  53. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
  54. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
  55. package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
  56. package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
  57. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
  58. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
  59. package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
  60. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
  61. package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
  62. package/lib/azure-dnsresolver/lib/index.js +23 -0
  63. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
  64. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
  65. package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
  66. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
  67. package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
  68. package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
  69. package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
  70. package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
  71. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
  72. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
  73. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
  74. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
  75. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
  76. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
  77. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
  78. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
  79. package/lib/azure-dnszone/index.d.ts +1 -0
  80. package/lib/azure-dnszone/index.js +18 -0
  81. package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
  82. package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
  83. package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
  84. package/lib/azure-dnszone/lib/dns-zone.js +228 -0
  85. package/lib/azure-dnszone/lib/index.d.ts +2 -0
  86. package/lib/azure-dnszone/lib/index.js +19 -0
  87. package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
  88. package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
  89. package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
  90. package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
  91. package/lib/azure-metricalert/index.d.ts +0 -10
  92. package/lib/azure-metricalert/index.js +1 -11
  93. package/lib/azure-metricalert/lib/index.d.ts +1 -4
  94. package/lib/azure-metricalert/lib/index.js +2 -5
  95. package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
  96. package/lib/azure-metricalert/lib/metric-alert.js +6 -32
  97. package/lib/azure-networkinterface/index.d.ts +0 -3
  98. package/lib/azure-networkinterface/index.js +1 -4
  99. package/lib/azure-networkinterface/lib/index.d.ts +1 -5
  100. package/lib/azure-networkinterface/lib/index.js +2 -5
  101. package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
  102. package/lib/azure-networkinterface/lib/network-interface.js +14 -29
  103. package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
  104. package/lib/azure-networksecuritygroup/index.d.ts +0 -5
  105. package/lib/azure-networksecuritygroup/index.js +1 -6
  106. package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
  107. package/lib/azure-networksecuritygroup/lib/index.js +17 -14
  108. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
  109. package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
  110. package/lib/azure-policyassignment/index.d.ts +1 -0
  111. package/lib/azure-policyassignment/index.js +18 -0
  112. package/lib/azure-policyassignment/lib/index.d.ts +2 -0
  113. package/lib/azure-policyassignment/lib/index.js +19 -0
  114. package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
  115. package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
  116. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +342 -0
  117. package/lib/azure-policyassignment/lib/policy-assignment.js +228 -0
  118. package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
  119. package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
  120. package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
  121. package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
  122. package/lib/azure-policydefinition/index.d.ts +1 -0
  123. package/lib/azure-policydefinition/index.js +18 -0
  124. package/lib/azure-policydefinition/lib/index.d.ts +2 -0
  125. package/lib/azure-policydefinition/lib/index.js +19 -0
  126. package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
  127. package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
  128. package/lib/azure-policydefinition/lib/policy-definition.d.ts +260 -0
  129. package/lib/azure-policydefinition/lib/policy-definition.js +199 -0
  130. package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
  131. package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
  132. package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
  133. package/lib/azure-policydefinition/test/policy-definition.spec.js +596 -0
  134. package/lib/azure-privatednszone/index.d.ts +1 -0
  135. package/lib/azure-privatednszone/index.js +18 -0
  136. package/lib/azure-privatednszone/lib/index.d.ts +2 -0
  137. package/lib/azure-privatednszone/lib/index.js +19 -0
  138. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
  139. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
  140. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
  141. package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
  142. package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
  143. package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
  144. package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
  145. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
  146. package/lib/azure-privatednszonelink/index.d.ts +1 -0
  147. package/lib/azure-privatednszonelink/index.js +18 -0
  148. package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
  149. package/lib/azure-privatednszonelink/lib/index.js +19 -0
  150. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
  151. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
  152. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
  153. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
  154. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
  155. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
  156. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
  157. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
  158. package/lib/azure-publicipaddress/index.d.ts +0 -5
  159. package/lib/azure-publicipaddress/index.js +1 -6
  160. package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
  161. package/lib/azure-publicipaddress/lib/index.js +17 -17
  162. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
  163. package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
  164. package/lib/azure-resourcegroup/index.d.ts +0 -37
  165. package/lib/azure-resourcegroup/index.js +1 -39
  166. package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
  167. package/lib/azure-resourcegroup/lib/index.js +2 -43
  168. package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
  169. package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
  170. package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
  171. package/lib/azure-roleassignment/index.d.ts +1 -0
  172. package/lib/azure-roleassignment/index.js +18 -0
  173. package/lib/azure-roleassignment/lib/index.d.ts +2 -0
  174. package/lib/azure-roleassignment/lib/index.js +19 -0
  175. package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
  176. package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
  177. package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
  178. package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
  179. package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
  180. package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
  181. package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
  182. package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
  183. package/lib/azure-roledefinition/index.d.ts +1 -0
  184. package/lib/azure-roledefinition/index.js +18 -0
  185. package/lib/azure-roledefinition/lib/index.d.ts +2 -0
  186. package/lib/azure-roledefinition/lib/index.js +19 -0
  187. package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
  188. package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
  189. package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
  190. package/lib/azure-roledefinition/lib/role-definition.js +192 -0
  191. package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
  192. package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
  193. package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
  194. package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
  195. package/lib/azure-storageaccount/index.d.ts +0 -19
  196. package/lib/azure-storageaccount/index.js +1 -20
  197. package/lib/azure-storageaccount/lib/index.d.ts +1 -7
  198. package/lib/azure-storageaccount/lib/index.js +2 -8
  199. package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
  200. package/lib/azure-storageaccount/lib/storage-account.js +15 -29
  201. package/lib/azure-subnet/index.d.ts +0 -3
  202. package/lib/azure-subnet/index.js +1 -4
  203. package/lib/azure-subnet/lib/index.d.ts +1 -4
  204. package/lib/azure-subnet/lib/index.js +2 -5
  205. package/lib/azure-subnet/lib/subnet.d.ts +3 -14
  206. package/lib/azure-subnet/lib/subnet.js +28 -47
  207. package/lib/azure-subnet/test/subnet.integ.js +19 -7
  208. package/lib/azure-subnet/test/subnet.spec.js +1 -2
  209. package/lib/azure-virtualmachine/index.d.ts +0 -6
  210. package/lib/azure-virtualmachine/index.js +1 -7
  211. package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
  212. package/lib/azure-virtualmachine/lib/index.js +2 -21
  213. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
  214. package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
  215. package/lib/azure-virtualnetwork/index.d.ts +0 -9
  216. package/lib/azure-virtualnetwork/index.js +1 -11
  217. package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
  218. package/lib/azure-virtualnetwork/lib/index.js +17 -20
  219. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
  220. package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
  221. package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
  222. package/lib/azure-virtualnetworkmanager/index.js +18 -0
  223. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
  224. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
  225. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
  226. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
  227. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
  228. package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
  229. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
  230. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
  231. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
  232. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
  233. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
  234. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
  235. package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
  236. package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
  237. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
  238. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
  239. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
  240. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
  241. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
  242. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
  243. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
  244. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
  245. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
  246. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
  247. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
  248. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
  249. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
  250. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
  251. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
  252. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
  253. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
  254. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
  255. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
  256. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
  257. package/lib/azure-vmss/index.d.ts +0 -5
  258. package/lib/azure-vmss/index.js +1 -6
  259. package/lib/azure-vmss/lib/index.d.ts +0 -7
  260. package/lib/azure-vmss/lib/index.js +1 -21
  261. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
  262. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
  263. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
  264. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
  265. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +178 -26
  266. package/lib/core-azure/lib/azapi/azapi-resource.js +328 -90
  267. package/lib/core-azure/lib/azapi/azapi-resource.spec.js +2 -2
  268. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  269. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  270. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +5 -3
  271. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  272. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  273. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  274. package/lib/core-azure/lib/azapi/resource-schema-validator.d.ts +118 -0
  275. package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
  276. package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
  277. package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
  278. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
  279. package/lib/core-azure/lib/index.d.ts +2 -2
  280. package/lib/core-azure/lib/index.js +5 -5
  281. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  282. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  283. package/lib/index.d.ts +19 -0
  284. package/lib/index.js +21 -2
  285. package/lib/testing/index.js +2 -2
  286. package/lib/testing/lib/cleanup.d.ts +1 -0
  287. package/lib/testing/lib/cleanup.js +19 -12
  288. package/lib/testing/lib/metadata.js +19 -16
  289. package/package.json +1 -1
  290. package/scripts/cleanup-test-resources.ts +22 -4
  291. package/scripts/generate-index.js +25 -8
@@ -0,0 +1,204 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.SecurityAdminRule = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Azure Virtual Network Manager Security Admin Rule implementation using AzapiResource framework
8
+ *
9
+ * This class provides a unified implementation for individual security admin rules that define
10
+ * high-priority security policies. These rules are evaluated BEFORE traditional NSGs and can
11
+ * enforce organization-wide security requirements.
12
+ *
13
+ * Supported API Versions:
14
+ * - 2023-11-01 (Maintenance)
15
+ * - 2024-05-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
+ * - Three action types: Allow, Deny, AlwaysAllow
22
+ * - Full backward compatibility
23
+ * - JSII compliance for multi-language support
24
+ */
25
+ const cdktf = require("cdktf");
26
+ const security_admin_rule_schemas_1 = require("./security-admin-rule-schemas");
27
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
28
+ /**
29
+ * Azure Virtual Network Manager Security Admin Rule implementation
30
+ *
31
+ * Security admin rules define high-priority security policies that are evaluated BEFORE
32
+ * traditional Network Security Groups (NSGs). This enables centralized security enforcement
33
+ * that cannot be overridden by individual teams.
34
+ *
35
+ * Key concepts:
36
+ * - Priority: Lower numbers = higher priority (evaluated first)
37
+ * - Allow: Permits traffic, but NSG can still deny it
38
+ * - Deny: Blocks traffic immediately, no further evaluation
39
+ * - AlwaysAllow: Forces traffic to be allowed, overriding NSG denies
40
+ *
41
+ * @example
42
+ * // Block SSH from internet:
43
+ * const blockSSH = new SecurityAdminRule(this, "block-ssh", {
44
+ * name: "block-ssh-from-internet",
45
+ * ruleCollectionId: ruleCollection.id,
46
+ * description: "Block SSH access from internet",
47
+ * priority: 100,
48
+ * action: "Deny",
49
+ * direction: "Inbound",
50
+ * protocol: "Tcp",
51
+ * destinationPortRanges: ["22"],
52
+ * sources: [{ addressPrefix: "Internet", addressPrefixType: "ServiceTag" }],
53
+ * destinations: [{ addressPrefix: "*", addressPrefixType: "IPPrefix" }]
54
+ * });
55
+ *
56
+ * @example
57
+ * // Always allow monitoring traffic:
58
+ * const allowMonitoring = new SecurityAdminRule(this, "allow-monitoring", {
59
+ * name: "always-allow-monitoring",
60
+ * ruleCollectionId: ruleCollection.id,
61
+ * description: "Always allow traffic from monitoring systems",
62
+ * priority: 50,
63
+ * action: "AlwaysAllow",
64
+ * direction: "Inbound",
65
+ * protocol: "Any",
66
+ * sources: [{ addressPrefix: "10.0.0.0/24", addressPrefixType: "IPPrefix" }],
67
+ * destinations: [{ addressPrefix: "*", addressPrefixType: "IPPrefix" }]
68
+ * });
69
+ *
70
+ * @stability stable
71
+ */
72
+ class SecurityAdminRule extends azapi_resource_1.AzapiResource {
73
+ /**
74
+ * Creates a new Azure Virtual Network Manager Security Admin Rule using the AzapiResource framework
75
+ *
76
+ * @param scope - The scope in which to define this construct
77
+ * @param id - The unique identifier for this instance
78
+ * @param props - Configuration properties for the Security Admin Rule
79
+ */
80
+ constructor(scope, id, props) {
81
+ super(scope, id, props);
82
+ this.props = props;
83
+ // Extract properties from the AZAPI resource outputs using Terraform interpolation
84
+ this.resourceName = `\${${this.terraformResource.fqn}.name}`;
85
+ // Create Terraform outputs for easy access and referencing from other resources
86
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
87
+ value: this.id,
88
+ description: "The ID of the Security Admin Rule",
89
+ });
90
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
91
+ value: this.resourceName,
92
+ description: "The name of the Security Admin Rule",
93
+ });
94
+ this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioningState", {
95
+ value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
96
+ description: "The provisioning state of the Security Admin Rule",
97
+ });
98
+ // Override logical IDs to match naming convention
99
+ this.idOutput.overrideLogicalId("id");
100
+ this.nameOutput.overrideLogicalId("name");
101
+ this.provisioningStateOutput.overrideLogicalId("provisioningState");
102
+ // Apply ignore changes if specified
103
+ this._applyIgnoreChanges();
104
+ }
105
+ // =============================================================================
106
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
107
+ // =============================================================================
108
+ /**
109
+ * Resolves the parent resource ID for the Security Admin Rule
110
+ * Security Admin Rules are scoped to Rule Collections
111
+ */
112
+ resolveParentId(props) {
113
+ const typedProps = props;
114
+ return typedProps.ruleCollectionId;
115
+ }
116
+ /**
117
+ * Gets the default API version to use when no explicit version is specified
118
+ */
119
+ defaultVersion() {
120
+ return "2024-05-01";
121
+ }
122
+ /**
123
+ * Gets the Azure resource type for Security Admin Rules
124
+ */
125
+ resourceType() {
126
+ return security_admin_rule_schemas_1.SECURITY_ADMIN_RULE_TYPE;
127
+ }
128
+ /**
129
+ * Gets the API schema for the resolved version
130
+ */
131
+ apiSchema() {
132
+ return this.resolveSchema();
133
+ }
134
+ /**
135
+ * Creates the resource body for the Azure API call
136
+ */
137
+ createResourceBody(props) {
138
+ const typedProps = props;
139
+ // Convert "*" to "0-65535" for port ranges as Azure API doesn't accept "*"
140
+ const normalizePortRanges = (ranges) => {
141
+ const defaultRanges = ranges || ["*"];
142
+ return defaultRanges.map((range) => (range === "*" ? "0-65535" : range));
143
+ };
144
+ return {
145
+ kind: "Custom",
146
+ properties: {
147
+ description: typedProps.description,
148
+ priority: typedProps.priority,
149
+ access: typedProps.action, // Azure API uses 'access' not 'action'
150
+ direction: typedProps.direction,
151
+ protocol: typedProps.protocol,
152
+ sourcePortRanges: normalizePortRanges(typedProps.sourcePortRanges),
153
+ destinationPortRanges: normalizePortRanges(typedProps.destinationPortRanges),
154
+ sources: typedProps.sources || [
155
+ { addressPrefix: "*", addressPrefixType: "IPPrefix" },
156
+ ],
157
+ destinations: typedProps.destinations || [
158
+ { addressPrefix: "*", addressPrefixType: "IPPrefix" },
159
+ ],
160
+ },
161
+ };
162
+ }
163
+ // =============================================================================
164
+ // PUBLIC METHODS FOR SECURITY ADMIN RULE OPERATIONS
165
+ // =============================================================================
166
+ /**
167
+ * Get the provisioning state of the Security Admin Rule
168
+ */
169
+ get provisioningState() {
170
+ return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
171
+ }
172
+ /**
173
+ * Get the priority of the rule
174
+ */
175
+ get rulePriority() {
176
+ return this.props.priority;
177
+ }
178
+ /**
179
+ * Get the action of the rule
180
+ */
181
+ get ruleAction() {
182
+ return this.props.action;
183
+ }
184
+ // =============================================================================
185
+ // PRIVATE HELPER METHODS
186
+ // =============================================================================
187
+ /**
188
+ * Applies ignore changes lifecycle rules if specified in props
189
+ */
190
+ _applyIgnoreChanges() {
191
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
192
+ this.terraformResource.addOverride("lifecycle", {
193
+ ignore_changes: this.props.ignoreChanges,
194
+ });
195
+ }
196
+ }
197
+ }
198
+ exports.SecurityAdminRule = SecurityAdminRule;
199
+ _a = JSII_RTTI_SYMBOL_1;
200
+ SecurityAdminRule[_a] = { fqn: "@microsoft/terraform-cdk-constructs.SecurityAdminRule", version: "1.3.0" };
201
+ (() => {
202
+ azapi_resource_1.AzapiResource.registerSchemas(security_admin_rule_schemas_1.SECURITY_ADMIN_RULE_TYPE, security_admin_rule_schemas_1.ALL_SECURITY_ADMIN_RULE_VERSIONS);
203
+ })();
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"security-admin-rule.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/lib/security-admin-rule.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,+BAA+B;AAE/B,+EAIuC;AACvC,8EAGmD;AAkHnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2CG;AACH,MAAa,iBAAkB,SAAQ,8BAAa;IAqBlD;;;;;;OAMG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,mFAAmF;QACnF,IAAI,CAAC,YAAY,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ,CAAC;QAE7D,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,mCAAmC;SACjD,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,IAAI,CAAC,YAAY;YACxB,WAAW,EAAE,qCAAqC;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,GAAG,IAAI,KAAK,CAAC,eAAe,CACtD,IAAI,EACJ,mBAAmB,EACnB;YACE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,uCAAuC;YAC9E,WAAW,EAAE,mDAAmD;SACjE,CACF,CAAC;QAEF,kDAAkD;QAClD,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,mBAAmB,CAAC,CAAC;QAEpE,oCAAoC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gFAAgF;IAChF,+CAA+C;IAC/C,gFAAgF;IAEhF;;;OAGG;IACO,eAAe,CAAC,KAAU;QAClC,MAAM,UAAU,GAAG,KAA+B,CAAC;QACnD,OAAO,UAAU,CAAC,gBAAgB,CAAC;IACrC,CAAC;IAED;;OAEG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,sDAAwB,CAAC;IAClC,CAAC;IAED;;OAEG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACO,kBAAkB,CAAC,KAAU;QACrC,MAAM,UAAU,GAAG,KAA+B,CAAC;QAEnD,2EAA2E;QAC3E,MAAM,mBAAmB,GAAG,CAAC,MAA4B,EAAY,EAAE;YACrE,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,GAAG,CAAC,CAAC;YACtC,OAAO,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;QAC3E,CAAC,CAAC;QAEF,OAAO;YACL,IAAI,EAAE,QAAQ;YACd,UAAU,EAAE;gBACV,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,MAAM,EAAE,UAAU,CAAC,MAAM,EAAE,uCAAuC;gBAClE,SAAS,EAAE,UAAU,CAAC,SAAS;gBAC/B,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,gBAAgB,EAAE,mBAAmB,CAAC,UAAU,CAAC,gBAAgB,CAAC;gBAClE,qBAAqB,EAAE,mBAAmB,CACxC,UAAU,CAAC,qBAAqB,CACjC;gBACD,OAAO,EAAE,UAAU,CAAC,OAAO,IAAI;oBAC7B,EAAE,aAAa,EAAE,GAAG,EAAE,iBAAiB,EAAE,UAAU,EAAE;iBACtD;gBACD,YAAY,EAAE,UAAU,CAAC,YAAY,IAAI;oBACvC,EAAE,aAAa,EAAE,GAAG,EAAE,iBAAiB,EAAE,UAAU,EAAE;iBACtD;aACF;SACF,CAAC;IACJ,CAAC;IAED,gFAAgF;IAChF,oDAAoD;IACpD,gFAAgF;IAEhF;;OAEG;IACH,IAAW,iBAAiB;QAC1B,OAAO,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,uCAAuC,CAAC;IACjF,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;IAC3B,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;;AA3KH,8CA4KC;;;AA3KC;IACE,8BAAa,CAAC,eAAe,CAC3B,sDAAwB,EACxB,8DAAgC,CACjC,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Azure Virtual Network Manager Security Admin Rule implementation using AzapiResource framework\n *\n * This class provides a unified implementation for individual security admin rules that define\n * high-priority security policies. These rules are evaluated BEFORE traditional NSGs and can\n * enforce organization-wide security requirements.\n *\n * Supported API Versions:\n * - 2023-11-01 (Maintenance)\n * - 2024-05-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 * - Three action types: Allow, Deny, AlwaysAllow\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_SECURITY_ADMIN_RULE_VERSIONS,\n  SECURITY_ADMIN_RULE_TYPE,\n  AddressPrefixItem,\n} from \"./security-admin-rule-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Properties for the Azure Virtual Network Manager Security Admin Rule\n *\n * Extends AzapiResourceProps with Security Admin Rule specific properties\n */\nexport interface SecurityAdminRuleProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the parent Rule Collection\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/networkManagers/vnm/securityAdminConfigurations/config/ruleCollections/collection\"\n   */\n  readonly ruleCollectionId: string;\n\n  /**\n   * Optional description of the security admin rule\n   * @example \"Block SSH access from internet\"\n   */\n  readonly description?: string;\n\n  /**\n   * Priority of the rule (1-4096, lower number = higher priority)\n   * Rules with lower priority numbers are evaluated first\n   * @example 100\n   */\n  readonly priority: number;\n\n  /**\n   * Action to take when the rule matches\n   * - Allow: Allow traffic (NSG can still deny)\n   * - Deny: Deny traffic (stops evaluation)\n   * - AlwaysAllow: Force allow (overrides NSG denies)\n   * @example \"Deny\"\n   * @example \"AlwaysAllow\"\n   */\n  readonly action: \"Allow\" | \"Deny\" | \"AlwaysAllow\";\n\n  /**\n   * Direction of traffic this rule applies to\n   * @example \"Inbound\"\n   * @example \"Outbound\"\n   */\n  readonly direction: \"Inbound\" | \"Outbound\";\n\n  /**\n   * Protocol this rule applies to\n   * @example \"Tcp\"\n   * @example \"Any\"\n   */\n  readonly protocol: \"Tcp\" | \"Udp\" | \"Icmp\" | \"Esp\" | \"Ah\" | \"Any\";\n\n  /**\n   * Source port ranges\n   * Use [\"*\"] for all ports or specify ranges like [\"80\", \"443\", \"8000-8999\"]\n   * @default [\"*\"]\n   * @example [\"*\"]\n   * @example [\"80\", \"443\"]\n   */\n  readonly sourcePortRanges?: string[];\n\n  /**\n   * Destination port ranges\n   * Use [\"*\"] for all ports or specify ranges\n   * @default [\"*\"]\n   * @example [\"22\"]\n   * @example [\"3389\", \"5985-5986\"]\n   */\n  readonly destinationPortRanges?: string[];\n\n  /**\n   * Source addresses or network groups\n   * @example [{ addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" }]\n   * @example [{ addressPrefix: \"10.0.0.0/8\", addressPrefixType: \"IPPrefix\" }]\n   */\n  readonly sources?: AddressPrefixItem[];\n\n  /**\n   * Destination addresses or network groups\n   * @example [{ addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" }]\n   * @example [{ addressPrefix: \"Internet\", addressPrefixType: \"ServiceTag\" }]\n   */\n  readonly destinations?: AddressPrefixItem[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for Security Admin Rule body\n */\nexport interface SecurityAdminRuleProperties {\n  readonly description?: string;\n  readonly priority: number;\n  readonly action: string;\n  readonly direction: string;\n  readonly protocol: string;\n  readonly sourcePortRanges?: string[];\n  readonly destinationPortRanges?: string[];\n  readonly sources?: AddressPrefixItem[];\n  readonly destinations?: AddressPrefixItem[];\n}\n\n/**\n * The resource body interface for Azure Security Admin Rule API calls\n */\nexport interface SecurityAdminRuleBody {\n  readonly kind: \"Custom\";\n  readonly properties: SecurityAdminRuleProperties;\n}\n\n/**\n * Azure Virtual Network Manager Security Admin Rule implementation\n *\n * Security admin rules define high-priority security policies that are evaluated BEFORE\n * traditional Network Security Groups (NSGs). This enables centralized security enforcement\n * that cannot be overridden by individual teams.\n *\n * Key concepts:\n * - Priority: Lower numbers = higher priority (evaluated first)\n * - Allow: Permits traffic, but NSG can still deny it\n * - Deny: Blocks traffic immediately, no further evaluation\n * - AlwaysAllow: Forces traffic to be allowed, overriding NSG denies\n *\n * @example\n * // Block SSH from internet:\n * const blockSSH = new SecurityAdminRule(this, \"block-ssh\", {\n *   name: \"block-ssh-from-internet\",\n *   ruleCollectionId: ruleCollection.id,\n *   description: \"Block SSH access from internet\",\n *   priority: 100,\n *   action: \"Deny\",\n *   direction: \"Inbound\",\n *   protocol: \"Tcp\",\n *   destinationPortRanges: [\"22\"],\n *   sources: [{ addressPrefix: \"Internet\", addressPrefixType: \"ServiceTag\" }],\n *   destinations: [{ addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" }]\n * });\n *\n * @example\n * // Always allow monitoring traffic:\n * const allowMonitoring = new SecurityAdminRule(this, \"allow-monitoring\", {\n *   name: \"always-allow-monitoring\",\n *   ruleCollectionId: ruleCollection.id,\n *   description: \"Always allow traffic from monitoring systems\",\n *   priority: 50,\n *   action: \"AlwaysAllow\",\n *   direction: \"Inbound\",\n *   protocol: \"Any\",\n *   sources: [{ addressPrefix: \"10.0.0.0/24\", addressPrefixType: \"IPPrefix\" }],\n *   destinations: [{ addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" }]\n * });\n *\n * @stability stable\n */\nexport class SecurityAdminRule extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      SECURITY_ADMIN_RULE_TYPE,\n      ALL_SECURITY_ADMIN_RULE_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Security Admin Rule instance\n   */\n  public readonly props: SecurityAdminRuleProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly provisioningStateOutput: cdktf.TerraformOutput;\n\n  // Public properties\n  public readonly resourceName: string;\n\n  /**\n   * Creates a new Azure Virtual Network Manager Security Admin Rule using the AzapiResource framework\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 Security Admin Rule\n   */\n  constructor(scope: Construct, id: string, props: SecurityAdminRuleProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n    this.resourceName = `\\${${this.terraformResource.fqn}.name}`;\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 Security Admin Rule\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: this.resourceName,\n      description: \"The name of the Security Admin Rule\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioningState\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description: \"The provisioning state of the Security Admin Rule\",\n      },\n    );\n\n    // Override logical IDs to match naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.provisioningStateOutput.overrideLogicalId(\"provisioningState\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Resolves the parent resource ID for the Security Admin Rule\n   * Security Admin Rules are scoped to Rule Collections\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as SecurityAdminRuleProps;\n    return typedProps.ruleCollectionId;\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   */\n  protected defaultVersion(): string {\n    return \"2024-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Security Admin Rules\n   */\n  protected resourceType(): string {\n    return SECURITY_ADMIN_RULE_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as SecurityAdminRuleProps;\n\n    // Convert \"*\" to \"0-65535\" for port ranges as Azure API doesn't accept \"*\"\n    const normalizePortRanges = (ranges: string[] | undefined): string[] => {\n      const defaultRanges = ranges || [\"*\"];\n      return defaultRanges.map((range) => (range === \"*\" ? \"0-65535\" : range));\n    };\n\n    return {\n      kind: \"Custom\",\n      properties: {\n        description: typedProps.description,\n        priority: typedProps.priority,\n        access: typedProps.action, // Azure API uses 'access' not 'action'\n        direction: typedProps.direction,\n        protocol: typedProps.protocol,\n        sourcePortRanges: normalizePortRanges(typedProps.sourcePortRanges),\n        destinationPortRanges: normalizePortRanges(\n          typedProps.destinationPortRanges,\n        ),\n        sources: typedProps.sources || [\n          { addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" },\n        ],\n        destinations: typedProps.destinations || [\n          { addressPrefix: \"*\", addressPrefixType: \"IPPrefix\" },\n        ],\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR SECURITY ADMIN RULE OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the provisioning state of the Security Admin Rule\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Get the priority of the rule\n   */\n  public get rulePriority(): number {\n    return this.props.priority;\n  }\n\n  /**\n   * Get the action of the rule\n   */\n  public get ruleAction(): \"Allow\" | \"Deny\" | \"AlwaysAllow\" {\n    return this.props.action;\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,32 @@
1
+ /**
2
+ * API schemas for Azure Virtual Network Manager across all supported versions
3
+ *
4
+ * This file defines the complete API schemas for Microsoft.Network/networkManagers
5
+ * across all supported API versions. The schemas are used by the AzapiResource
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 Virtual Network Manager version 2024-05-01
11
+ */
12
+ export declare const VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_01: ApiSchema;
13
+ /**
14
+ * API Schema for Virtual Network Manager version 2023-11-01
15
+ */
16
+ export declare const VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01: ApiSchema;
17
+ /**
18
+ * Version configuration for Virtual Network Manager 2024-05-01
19
+ */
20
+ export declare const VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01: VersionConfig;
21
+ /**
22
+ * Version configuration for Virtual Network Manager 2023-11-01
23
+ */
24
+ export declare const VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01: VersionConfig;
25
+ /**
26
+ * All supported Virtual Network Manager versions for registration
27
+ */
28
+ export declare const ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS: VersionConfig[];
29
+ /**
30
+ * Resource type constant
31
+ */
32
+ export declare const VIRTUAL_NETWORK_MANAGER_TYPE = "Microsoft.Network/networkManagers";
@@ -0,0 +1,236 @@
1
+ "use strict";
2
+ /**
3
+ * API schemas for Azure Virtual Network Manager across all supported versions
4
+ *
5
+ * This file defines the complete API schemas for Microsoft.Network/networkManagers
6
+ * across all supported API versions. The schemas are used by the AzapiResource
7
+ * framework for validation, transformation, and version management.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.VIRTUAL_NETWORK_MANAGER_TYPE = exports.ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS = exports.VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01 = exports.VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01 = exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01 = exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_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 Virtual Network Manager versions
17
+ */
18
+ const COMMON_PROPERTIES = {
19
+ name: {
20
+ dataType: version_interfaces_1.PropertyType.STRING,
21
+ required: false,
22
+ description: "Name of the network manager",
23
+ validation: [
24
+ {
25
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
26
+ value: "^[a-zA-Z0-9][a-zA-Z0-9._-]{0,62}[a-zA-Z0-9_]$",
27
+ message: "Network Manager name must be 2-64 chars, alphanumeric, periods, underscores, hyphens",
28
+ },
29
+ ],
30
+ },
31
+ location: {
32
+ dataType: version_interfaces_1.PropertyType.STRING,
33
+ required: true,
34
+ description: "Azure region for the network manager",
35
+ validation: [
36
+ {
37
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
38
+ message: "Location is required",
39
+ },
40
+ {
41
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
42
+ value: "^[a-z0-9]+$",
43
+ message: "Location must contain only lowercase letters and numbers",
44
+ },
45
+ ],
46
+ },
47
+ tags: {
48
+ dataType: version_interfaces_1.PropertyType.OBJECT,
49
+ required: false,
50
+ defaultValue: {},
51
+ description: "Resource tags",
52
+ validation: [
53
+ {
54
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
55
+ value: version_interfaces_1.PropertyType.OBJECT,
56
+ message: "Tags must be an object with string key-value pairs",
57
+ },
58
+ ],
59
+ },
60
+ resourceGroupId: {
61
+ dataType: version_interfaces_1.PropertyType.STRING,
62
+ required: false,
63
+ description: "Resource ID of the resource group where the network manager will be created",
64
+ },
65
+ networkManagerScopes: {
66
+ dataType: version_interfaces_1.PropertyType.OBJECT,
67
+ required: true,
68
+ description: "Defines the scope of management (management groups and/or subscriptions)",
69
+ validation: [
70
+ {
71
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
72
+ message: "Network manager scopes are required",
73
+ },
74
+ ],
75
+ },
76
+ networkManagerScopeAccesses: {
77
+ dataType: version_interfaces_1.PropertyType.ARRAY,
78
+ required: true,
79
+ description: "Features enabled for the network manager (Connectivity, SecurityAdmin, Routing)",
80
+ validation: [
81
+ {
82
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
83
+ message: "Network manager scope accesses are required",
84
+ },
85
+ ],
86
+ },
87
+ description: {
88
+ dataType: version_interfaces_1.PropertyType.STRING,
89
+ required: false,
90
+ description: "Description of the network manager",
91
+ },
92
+ };
93
+ // =============================================================================
94
+ // VERSION-SPECIFIC SCHEMAS
95
+ // =============================================================================
96
+ /**
97
+ * API Schema for Virtual Network Manager version 2024-05-01
98
+ */
99
+ exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_01 = {
100
+ resourceType: "Microsoft.Network/networkManagers",
101
+ version: "2024-05-01",
102
+ properties: {
103
+ ...COMMON_PROPERTIES,
104
+ },
105
+ required: ["location", "networkManagerScopes", "networkManagerScopeAccesses"],
106
+ optional: ["name", "tags", "description", "resourceGroupId"],
107
+ deprecated: [],
108
+ transformationRules: {},
109
+ validationRules: [
110
+ {
111
+ property: "location",
112
+ rules: [
113
+ {
114
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
115
+ message: "Location is required for Network Managers",
116
+ },
117
+ ],
118
+ },
119
+ {
120
+ property: "networkManagerScopes",
121
+ rules: [
122
+ {
123
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
124
+ message: "Network manager scopes are required",
125
+ },
126
+ ],
127
+ },
128
+ {
129
+ property: "networkManagerScopeAccesses",
130
+ rules: [
131
+ {
132
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
133
+ message: "Network manager scope accesses are required",
134
+ },
135
+ ],
136
+ },
137
+ ],
138
+ };
139
+ /**
140
+ * API Schema for Virtual Network Manager version 2023-11-01
141
+ */
142
+ exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01 = {
143
+ resourceType: "Microsoft.Network/networkManagers",
144
+ version: "2023-11-01",
145
+ properties: {
146
+ ...COMMON_PROPERTIES,
147
+ },
148
+ required: ["location", "networkManagerScopes", "networkManagerScopeAccesses"],
149
+ optional: ["name", "tags", "description", "resourceGroupId"],
150
+ deprecated: [],
151
+ transformationRules: {},
152
+ validationRules: [
153
+ {
154
+ property: "location",
155
+ rules: [
156
+ {
157
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
158
+ message: "Location is required for Network Managers",
159
+ },
160
+ ],
161
+ },
162
+ {
163
+ property: "networkManagerScopes",
164
+ rules: [
165
+ {
166
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
167
+ message: "Network manager scopes are required",
168
+ },
169
+ ],
170
+ },
171
+ {
172
+ property: "networkManagerScopeAccesses",
173
+ rules: [
174
+ {
175
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
176
+ message: "Network manager scope accesses are required",
177
+ },
178
+ ],
179
+ },
180
+ ],
181
+ };
182
+ // =============================================================================
183
+ // VERSION CONFIGURATIONS
184
+ // =============================================================================
185
+ /**
186
+ * Version configuration for Virtual Network Manager 2024-05-01
187
+ */
188
+ exports.VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01 = {
189
+ version: "2024-05-01",
190
+ schema: exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_01,
191
+ supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
192
+ releaseDate: "2024-05-01",
193
+ deprecationDate: undefined,
194
+ sunsetDate: undefined,
195
+ breakingChanges: [],
196
+ migrationGuide: "/docs/virtual-network-manager/migration-2024-05-01",
197
+ changeLog: [
198
+ {
199
+ changeType: "added",
200
+ description: "Latest stable release with full support for routing configurations, security admin configurations, and connectivity configurations",
201
+ breaking: false,
202
+ },
203
+ ],
204
+ };
205
+ /**
206
+ * Version configuration for Virtual Network Manager 2023-11-01
207
+ */
208
+ exports.VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01 = {
209
+ version: "2023-11-01",
210
+ schema: exports.VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01,
211
+ supportLevel: version_interfaces_1.VersionSupportLevel.MAINTENANCE,
212
+ releaseDate: "2023-11-01",
213
+ deprecationDate: undefined,
214
+ sunsetDate: undefined,
215
+ breakingChanges: [],
216
+ migrationGuide: "/docs/virtual-network-manager/migration-2023-11-01",
217
+ changeLog: [
218
+ {
219
+ changeType: "added",
220
+ description: "Stable release with core Network Manager features",
221
+ breaking: false,
222
+ },
223
+ ],
224
+ };
225
+ /**
226
+ * All supported Virtual Network Manager versions for registration
227
+ */
228
+ exports.ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS = [
229
+ exports.VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01,
230
+ exports.VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01,
231
+ ];
232
+ /**
233
+ * Resource type constant
234
+ */
235
+ exports.VIRTUAL_NETWORK_MANAGER_TYPE = "Microsoft.Network/networkManagers";
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-manager-schemas.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure Virtual Network Manager across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/networkManagers\n * across all supported API versions. The schemas are used by the AzapiResource\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 Virtual Network Manager versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description: \"Name of the network manager\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9][a-zA-Z0-9._-]{0,62}[a-zA-Z0-9_]$\",\n        message:\n          \"Network Manager name must be 2-64 chars, alphanumeric, periods, underscores, hyphens\",\n      },\n    ],\n  },\n  location: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description: \"Azure region for the network manager\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Location is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-z0-9]+$\",\n        message: \"Location must contain only lowercase letters and numbers\",\n      },\n    ],\n  },\n  tags: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description: \"Resource tags\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Tags must be an object with string key-value pairs\",\n      },\n    ],\n  },\n  resourceGroupId: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"Resource ID of the resource group where the network manager will be created\",\n  },\n  networkManagerScopes: {\n    dataType: PropertyType.OBJECT,\n    required: true,\n    description:\n      \"Defines the scope of management (management groups and/or subscriptions)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Network manager scopes are required\",\n      },\n    ],\n  },\n  networkManagerScopeAccesses: {\n    dataType: PropertyType.ARRAY,\n    required: true,\n    description:\n      \"Features enabled for the network manager (Connectivity, SecurityAdmin, Routing)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Network manager scope accesses are required\",\n      },\n    ],\n  },\n  description: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description: \"Description of the network manager\",\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Virtual Network Manager version 2024-05-01\n */\nexport const VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/networkManagers\",\n  version: \"2024-05-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"location\", \"networkManagerScopes\", \"networkManagerScopeAccesses\"],\n  optional: [\"name\", \"tags\", \"description\", \"resourceGroupId\"],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"location\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Location is required for Network Managers\",\n        },\n      ],\n    },\n    {\n      property: \"networkManagerScopes\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Network manager scopes are required\",\n        },\n      ],\n    },\n    {\n      property: \"networkManagerScopeAccesses\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Network manager scope accesses are required\",\n        },\n      ],\n    },\n  ],\n};\n\n/**\n * API Schema for Virtual Network Manager version 2023-11-01\n */\nexport const VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/networkManagers\",\n  version: \"2023-11-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"location\", \"networkManagerScopes\", \"networkManagerScopeAccesses\"],\n  optional: [\"name\", \"tags\", \"description\", \"resourceGroupId\"],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"location\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Location is required for Network Managers\",\n        },\n      ],\n    },\n    {\n      property: \"networkManagerScopes\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Network manager scopes are required\",\n        },\n      ],\n    },\n    {\n      property: \"networkManagerScopeAccesses\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Network manager scope accesses are required\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Virtual Network Manager 2024-05-01\n */\nexport const VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01: VersionConfig = {\n  version: \"2024-05-01\",\n  schema: VIRTUAL_NETWORK_MANAGER_SCHEMA_2024_05_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2024-05-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/virtual-network-manager/migration-2024-05-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Latest stable release with full support for routing configurations, security admin configurations, and connectivity configurations\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * Version configuration for Virtual Network Manager 2023-11-01\n */\nexport const VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01: VersionConfig = {\n  version: \"2023-11-01\",\n  schema: VIRTUAL_NETWORK_MANAGER_SCHEMA_2023_11_01,\n  supportLevel: VersionSupportLevel.MAINTENANCE,\n  releaseDate: \"2023-11-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/virtual-network-manager/migration-2023-11-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description: \"Stable release with core Network Manager features\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Virtual Network Manager versions for registration\n */\nexport const ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS: VersionConfig[] = [\n  VIRTUAL_NETWORK_MANAGER_VERSION_2024_05_01,\n  VIRTUAL_NETWORK_MANAGER_VERSION_2023_11_01,\n];\n\n/**\n * Resource type constant\n */\nexport const VIRTUAL_NETWORK_MANAGER_TYPE = \"Microsoft.Network/networkManagers\";\n"]}