@microsoft/terraform-cdk-constructs 1.0.0 → 1.2.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 (385) hide show
  1. package/.jsii +60999 -15780
  2. package/API.md +54947 -10610
  3. package/README.md +72 -36
  4. package/docs/monitoring-guide.md +206 -0
  5. package/docs/testing.md +84 -1
  6. package/lib/azure-actiongroup/index.d.ts +11 -0
  7. package/lib/azure-actiongroup/index.js +28 -0
  8. package/lib/azure-actiongroup/lib/action-group-schemas.d.ts +24 -0
  9. package/lib/azure-actiongroup/lib/action-group-schemas.js +201 -0
  10. package/lib/azure-actiongroup/lib/action-group.d.ts +312 -0
  11. package/lib/azure-actiongroup/lib/action-group.js +201 -0
  12. package/lib/azure-actiongroup/lib/index.d.ts +5 -0
  13. package/lib/azure-actiongroup/lib/index.js +22 -0
  14. package/lib/azure-actiongroup/test/action-group.integ.d.ts +9 -0
  15. package/lib/azure-actiongroup/test/action-group.integ.js +79 -0
  16. package/lib/azure-actiongroup/test/action-group.spec.d.ts +8 -0
  17. package/lib/azure-actiongroup/test/action-group.spec.js +602 -0
  18. package/lib/azure-activitylogalert/index.d.ts +11 -0
  19. package/lib/azure-activitylogalert/index.js +28 -0
  20. package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.d.ts +24 -0
  21. package/lib/azure-activitylogalert/lib/activity-log-alert-schemas.js +182 -0
  22. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +236 -0
  23. package/lib/azure-activitylogalert/lib/activity-log-alert.js +212 -0
  24. package/lib/azure-activitylogalert/lib/index.d.ts +5 -0
  25. package/lib/azure-activitylogalert/lib/index.js +22 -0
  26. package/lib/azure-activitylogalert/test/activity-log-alert.integ.d.ts +9 -0
  27. package/lib/azure-activitylogalert/test/activity-log-alert.integ.js +98 -0
  28. package/lib/azure-activitylogalert/test/activity-log-alert.spec.d.ts +9 -0
  29. package/lib/azure-activitylogalert/test/activity-log-alert.spec.js +1101 -0
  30. package/lib/azure-aks/index.d.ts +9 -0
  31. package/lib/azure-aks/index.js +28 -0
  32. package/lib/azure-aks/lib/aks-cluster-schemas.d.ts +505 -0
  33. package/lib/azure-aks/lib/aks-cluster-schemas.js +572 -0
  34. package/lib/azure-aks/lib/aks-cluster.d.ts +395 -0
  35. package/lib/azure-aks/lib/aks-cluster.js +489 -0
  36. package/lib/azure-aks/lib/index.d.ts +11 -0
  37. package/lib/azure-aks/lib/index.js +38 -0
  38. package/lib/azure-aks/test/aks-cluster.integ.d.ts +9 -0
  39. package/lib/azure-aks/test/aks-cluster.integ.js +260 -0
  40. package/lib/azure-aks/test/aks-cluster.spec.d.ts +8 -0
  41. package/lib/azure-aks/test/aks-cluster.spec.js +1396 -0
  42. package/lib/azure-diagnosticsettings/index.d.ts +7 -0
  43. package/lib/azure-diagnosticsettings/index.js +24 -0
  44. package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.d.ts +50 -0
  45. package/lib/azure-diagnosticsettings/lib/diagnostic-settings-schemas.js +207 -0
  46. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +193 -0
  47. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +200 -0
  48. package/lib/azure-diagnosticsettings/lib/index.d.ts +8 -0
  49. package/lib/azure-diagnosticsettings/lib/index.js +25 -0
  50. package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.d.ts +8 -0
  51. package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.js +432 -0
  52. package/lib/azure-metricalert/index.d.ts +11 -0
  53. package/lib/azure-metricalert/index.js +28 -0
  54. package/lib/azure-metricalert/lib/index.d.ts +5 -0
  55. package/lib/azure-metricalert/lib/index.js +22 -0
  56. package/lib/azure-metricalert/lib/metric-alert-schemas.d.ts +24 -0
  57. package/lib/azure-metricalert/lib/metric-alert-schemas.js +242 -0
  58. package/lib/azure-metricalert/lib/metric-alert.d.ts +344 -0
  59. package/lib/azure-metricalert/lib/metric-alert.js +252 -0
  60. package/lib/azure-metricalert/test/metric-alert.integ.d.ts +9 -0
  61. package/lib/azure-metricalert/test/metric-alert.integ.js +123 -0
  62. package/lib/azure-metricalert/test/metric-alert.spec.d.ts +9 -0
  63. package/lib/azure-metricalert/test/metric-alert.spec.js +1266 -0
  64. package/lib/azure-networkinterface/index.d.ts +4 -0
  65. package/lib/azure-networkinterface/index.js +21 -0
  66. package/lib/azure-networkinterface/lib/index.d.ts +6 -0
  67. package/lib/azure-networkinterface/lib/index.js +22 -0
  68. package/lib/azure-networkinterface/lib/network-interface-schemas.d.ts +32 -0
  69. package/lib/azure-networkinterface/lib/network-interface-schemas.js +222 -0
  70. package/lib/azure-networkinterface/lib/network-interface.d.ts +265 -0
  71. package/lib/azure-networkinterface/lib/network-interface.js +228 -0
  72. package/lib/azure-networkinterface/test/network-interface.integ.d.ts +9 -0
  73. package/lib/azure-networkinterface/test/network-interface.integ.js +102 -0
  74. package/lib/azure-networkinterface/test/network-interface.spec.d.ts +8 -0
  75. package/lib/azure-networkinterface/test/network-interface.spec.js +655 -0
  76. package/lib/azure-networksecuritygroup/index.d.ts +6 -0
  77. package/lib/azure-networksecuritygroup/index.js +23 -0
  78. package/lib/azure-networksecuritygroup/lib/index.d.ts +5 -0
  79. package/lib/azure-networksecuritygroup/lib/index.js +16 -0
  80. package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.d.ts +32 -0
  81. package/lib/azure-networksecuritygroup/lib/network-security-group-schemas.js +198 -0
  82. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +268 -0
  83. package/lib/azure-networksecuritygroup/lib/network-security-group.js +248 -0
  84. package/lib/azure-networksecuritygroup/test/network-security-group.integ.d.ts +9 -0
  85. package/lib/azure-networksecuritygroup/test/network-security-group.integ.js +151 -0
  86. package/lib/azure-networksecuritygroup/test/network-security-group.spec.d.ts +8 -0
  87. package/lib/azure-networksecuritygroup/test/network-security-group.spec.js +652 -0
  88. package/lib/azure-publicipaddress/index.d.ts +6 -0
  89. package/lib/azure-publicipaddress/index.js +23 -0
  90. package/lib/azure-publicipaddress/lib/index.d.ts +9 -0
  91. package/lib/azure-publicipaddress/lib/index.js +19 -0
  92. package/lib/azure-publicipaddress/lib/public-ip-address-schemas.d.ts +32 -0
  93. package/lib/azure-publicipaddress/lib/public-ip-address-schemas.js +227 -0
  94. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +256 -0
  95. package/lib/azure-publicipaddress/lib/public-ip-address.js +267 -0
  96. package/lib/azure-publicipaddress/test/public-ip-address.integ.d.ts +9 -0
  97. package/lib/azure-publicipaddress/test/public-ip-address.integ.js +75 -0
  98. package/lib/azure-publicipaddress/test/public-ip-address.spec.d.ts +15 -0
  99. package/lib/azure-publicipaddress/test/public-ip-address.spec.js +498 -0
  100. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  101. package/lib/azure-resourcegroup/test/resource-group.integ.js +23 -11
  102. package/lib/azure-storageaccount/lib/storage-account-schemas.d.ts +98 -0
  103. package/lib/azure-storageaccount/lib/storage-account-schemas.js +1 -1
  104. package/lib/azure-storageaccount/lib/storage-account.d.ts +38 -1
  105. package/lib/azure-storageaccount/lib/storage-account.js +138 -2
  106. package/lib/azure-storageaccount/test/storage-account.integ.js +91 -12
  107. package/lib/azure-subnet/index.d.ts +4 -0
  108. package/lib/azure-subnet/index.js +21 -0
  109. package/lib/azure-subnet/lib/index.d.ts +5 -0
  110. package/lib/azure-subnet/lib/index.js +22 -0
  111. package/lib/azure-subnet/lib/subnet-schemas.d.ts +32 -0
  112. package/lib/azure-subnet/lib/subnet-schemas.js +237 -0
  113. package/lib/azure-subnet/lib/subnet.d.ts +285 -0
  114. package/lib/azure-subnet/lib/subnet.js +254 -0
  115. package/lib/azure-subnet/test/subnet.integ.d.ts +11 -0
  116. package/lib/azure-subnet/test/subnet.integ.js +80 -0
  117. package/lib/azure-subnet/test/subnet.spec.d.ts +8 -0
  118. package/lib/azure-subnet/test/subnet.spec.js +396 -0
  119. package/lib/azure-virtualmachine/index.d.ts +7 -0
  120. package/lib/azure-virtualmachine/index.js +24 -0
  121. package/lib/azure-virtualmachine/lib/index.d.ts +11 -0
  122. package/lib/azure-virtualmachine/lib/index.js +38 -0
  123. package/lib/azure-virtualmachine/lib/virtual-machine-schemas.d.ts +327 -0
  124. package/lib/azure-virtualmachine/lib/virtual-machine-schemas.js +544 -0
  125. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +377 -0
  126. package/lib/azure-virtualmachine/lib/virtual-machine.js +462 -0
  127. package/lib/azure-virtualmachine/test/virtual-machine.integ.d.ts +9 -0
  128. package/lib/azure-virtualmachine/test/virtual-machine.integ.js +220 -0
  129. package/lib/azure-virtualmachine/test/virtual-machine.spec.d.ts +9 -0
  130. package/lib/azure-virtualmachine/test/virtual-machine.spec.js +1032 -0
  131. package/lib/azure-virtualnetwork/index.d.ts +10 -0
  132. package/lib/azure-virtualnetwork/index.js +28 -0
  133. package/lib/azure-virtualnetwork/lib/index.d.ts +9 -0
  134. package/lib/azure-virtualnetwork/lib/index.js +22 -0
  135. package/lib/azure-virtualnetwork/lib/virtual-network-schemas.d.ts +32 -0
  136. package/lib/azure-virtualnetwork/lib/virtual-network-schemas.js +236 -0
  137. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +213 -0
  138. package/lib/azure-virtualnetwork/lib/virtual-network.js +245 -0
  139. package/lib/azure-virtualnetwork/test/virtual-network.integ.d.ts +9 -0
  140. package/lib/azure-virtualnetwork/test/virtual-network.integ.js +91 -0
  141. package/lib/azure-virtualnetwork/test/virtual-network.spec.d.ts +8 -0
  142. package/lib/azure-virtualnetwork/test/virtual-network.spec.js +398 -0
  143. package/lib/azure-vmss/index.d.ts +6 -0
  144. package/lib/azure-vmss/index.js +23 -0
  145. package/lib/azure-vmss/lib/index.d.ts +9 -0
  146. package/lib/azure-vmss/lib/index.js +39 -0
  147. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +258 -0
  148. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +503 -0
  149. package/lib/azure-vmss/lib/vmss-schemas.d.ts +472 -0
  150. package/lib/azure-vmss/lib/vmss-schemas.js +444 -0
  151. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.d.ts +15 -0
  152. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.js +261 -0
  153. package/lib/azure-vmss/test/virtual-machine-scale-set.spec.d.ts +8 -0
  154. package/lib/azure-vmss/test/virtual-machine-scale-set.spec.js +997 -0
  155. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +95 -27
  156. package/lib/core-azure/lib/azapi/azapi-resource.js +95 -58
  157. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.d.ts +33 -21
  158. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +69 -27
  159. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.d.ts +134 -120
  160. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +209 -59
  161. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.d.ts +141 -128
  162. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.js +183 -36
  163. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.d.ts +55 -43
  164. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.js +94 -26
  165. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.d.ts +129 -116
  166. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.js +155 -32
  167. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.d.ts +187 -174
  168. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.js +267 -48
  169. package/lib/core-azure/lib/azapi/providers-azapi/index.d.ts +10 -10
  170. package/lib/core-azure/lib/azapi/providers-azapi/index.js +1 -1
  171. package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.d.ts +0 -0
  172. package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.js +13 -0
  173. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.d.ts +174 -162
  174. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +274 -14
  175. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.d.ts +239 -225
  176. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +360 -76
  177. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.d.ts +163 -150
  178. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +221 -46
  179. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.d.ts +162 -149
  180. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +249 -50
  181. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +4 -2
  182. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  183. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  184. package/lib/index.d.ts +37 -0
  185. package/lib/index.js +40 -2
  186. package/lib/testing/index.d.ts +92 -2
  187. package/lib/testing/index.js +258 -18
  188. package/lib/testing/lib/cleanup.d.ts +229 -0
  189. package/lib/testing/lib/cleanup.js +331 -0
  190. package/lib/testing/lib/metadata.d.ts +151 -0
  191. package/lib/testing/lib/metadata.js +180 -0
  192. package/lib/testing/lib/naming.d.ts +96 -0
  193. package/lib/testing/lib/naming.js +336 -0
  194. package/node_modules/uuid/LICENSE.md +9 -0
  195. package/node_modules/uuid/README.md +510 -0
  196. package/node_modules/uuid/dist/cjs/index.d.ts +15 -0
  197. package/node_modules/uuid/dist/cjs/index.js +31 -0
  198. package/node_modules/uuid/dist/cjs/max.d.ts +2 -0
  199. package/node_modules/uuid/dist/cjs/max.js +3 -0
  200. package/node_modules/uuid/dist/cjs/md5.d.ts +4 -0
  201. package/node_modules/uuid/dist/cjs/md5.js +13 -0
  202. package/node_modules/uuid/dist/cjs/native.d.ts +6 -0
  203. package/node_modules/uuid/dist/cjs/native.js +4 -0
  204. package/node_modules/uuid/dist/cjs/nil.d.ts +2 -0
  205. package/node_modules/uuid/dist/cjs/nil.js +3 -0
  206. package/node_modules/uuid/dist/cjs/package.json +1 -0
  207. package/node_modules/uuid/dist/cjs/parse.d.ts +2 -0
  208. package/node_modules/uuid/dist/cjs/parse.js +11 -0
  209. package/node_modules/uuid/dist/cjs/regex.d.ts +2 -0
  210. package/node_modules/uuid/dist/cjs/regex.js +3 -0
  211. package/node_modules/uuid/dist/cjs/rng.d.ts +1 -0
  212. package/node_modules/uuid/dist/cjs/rng.js +13 -0
  213. package/node_modules/uuid/dist/cjs/sha1.d.ts +4 -0
  214. package/node_modules/uuid/dist/cjs/sha1.js +13 -0
  215. package/node_modules/uuid/dist/cjs/stringify.d.ts +3 -0
  216. package/node_modules/uuid/dist/cjs/stringify.js +39 -0
  217. package/node_modules/uuid/dist/cjs/types.d.ts +21 -0
  218. package/node_modules/uuid/dist/cjs/types.js +2 -0
  219. package/node_modules/uuid/dist/cjs/uuid-bin.d.ts +1 -0
  220. package/node_modules/uuid/dist/cjs/uuid-bin.js +72 -0
  221. package/node_modules/uuid/dist/cjs/v1.d.ts +11 -0
  222. package/node_modules/uuid/dist/cjs/v1.js +87 -0
  223. package/node_modules/uuid/dist/cjs/v1ToV6.d.ts +2 -0
  224. package/node_modules/uuid/dist/cjs/v1ToV6.js +13 -0
  225. package/node_modules/uuid/dist/cjs/v3.d.ts +9 -0
  226. package/node_modules/uuid/dist/cjs/v3.js +14 -0
  227. package/node_modules/uuid/dist/cjs/v35.d.ts +7 -0
  228. package/node_modules/uuid/dist/cjs/v35.js +41 -0
  229. package/node_modules/uuid/dist/cjs/v4.d.ts +4 -0
  230. package/node_modules/uuid/dist/cjs/v4.js +29 -0
  231. package/node_modules/uuid/dist/cjs/v5.d.ts +9 -0
  232. package/node_modules/uuid/dist/cjs/v5.js +14 -0
  233. package/node_modules/uuid/dist/cjs/v6.d.ts +4 -0
  234. package/node_modules/uuid/dist/cjs/v6.js +19 -0
  235. package/node_modules/uuid/dist/cjs/v6ToV1.d.ts +2 -0
  236. package/node_modules/uuid/dist/cjs/v6ToV1.js +13 -0
  237. package/node_modules/uuid/dist/cjs/v7.d.ts +9 -0
  238. package/node_modules/uuid/dist/cjs/v7.js +69 -0
  239. package/node_modules/uuid/dist/cjs/validate.d.ts +2 -0
  240. package/node_modules/uuid/dist/cjs/validate.js +7 -0
  241. package/node_modules/uuid/dist/cjs/version.d.ts +2 -0
  242. package/node_modules/uuid/dist/cjs/version.js +10 -0
  243. package/node_modules/uuid/dist/cjs-browser/index.d.ts +15 -0
  244. package/node_modules/uuid/dist/cjs-browser/index.js +31 -0
  245. package/node_modules/uuid/dist/cjs-browser/max.d.ts +2 -0
  246. package/node_modules/uuid/dist/cjs-browser/max.js +3 -0
  247. package/node_modules/uuid/dist/cjs-browser/md5.d.ts +2 -0
  248. package/node_modules/uuid/dist/cjs-browser/md5.js +137 -0
  249. package/node_modules/uuid/dist/cjs-browser/native.d.ts +4 -0
  250. package/node_modules/uuid/dist/cjs-browser/native.js +4 -0
  251. package/node_modules/uuid/dist/cjs-browser/nil.d.ts +2 -0
  252. package/node_modules/uuid/dist/cjs-browser/nil.js +3 -0
  253. package/node_modules/uuid/dist/cjs-browser/package.json +1 -0
  254. package/node_modules/uuid/dist/cjs-browser/parse.d.ts +2 -0
  255. package/node_modules/uuid/dist/cjs-browser/parse.js +11 -0
  256. package/node_modules/uuid/dist/cjs-browser/regex.d.ts +2 -0
  257. package/node_modules/uuid/dist/cjs-browser/regex.js +3 -0
  258. package/node_modules/uuid/dist/cjs-browser/rng.d.ts +1 -0
  259. package/node_modules/uuid/dist/cjs-browser/rng.js +14 -0
  260. package/node_modules/uuid/dist/cjs-browser/sha1.d.ts +2 -0
  261. package/node_modules/uuid/dist/cjs-browser/sha1.js +72 -0
  262. package/node_modules/uuid/dist/cjs-browser/stringify.d.ts +3 -0
  263. package/node_modules/uuid/dist/cjs-browser/stringify.js +39 -0
  264. package/node_modules/uuid/dist/cjs-browser/types.d.ts +21 -0
  265. package/node_modules/uuid/dist/cjs-browser/types.js +2 -0
  266. package/node_modules/uuid/dist/cjs-browser/uuid-bin.d.ts +1 -0
  267. package/node_modules/uuid/dist/cjs-browser/uuid-bin.js +72 -0
  268. package/node_modules/uuid/dist/cjs-browser/v1.d.ts +11 -0
  269. package/node_modules/uuid/dist/cjs-browser/v1.js +87 -0
  270. package/node_modules/uuid/dist/cjs-browser/v1ToV6.d.ts +2 -0
  271. package/node_modules/uuid/dist/cjs-browser/v1ToV6.js +13 -0
  272. package/node_modules/uuid/dist/cjs-browser/v3.d.ts +9 -0
  273. package/node_modules/uuid/dist/cjs-browser/v3.js +14 -0
  274. package/node_modules/uuid/dist/cjs-browser/v35.d.ts +7 -0
  275. package/node_modules/uuid/dist/cjs-browser/v35.js +41 -0
  276. package/node_modules/uuid/dist/cjs-browser/v4.d.ts +4 -0
  277. package/node_modules/uuid/dist/cjs-browser/v4.js +29 -0
  278. package/node_modules/uuid/dist/cjs-browser/v5.d.ts +9 -0
  279. package/node_modules/uuid/dist/cjs-browser/v5.js +14 -0
  280. package/node_modules/uuid/dist/cjs-browser/v6.d.ts +4 -0
  281. package/node_modules/uuid/dist/cjs-browser/v6.js +19 -0
  282. package/node_modules/uuid/dist/cjs-browser/v6ToV1.d.ts +2 -0
  283. package/node_modules/uuid/dist/cjs-browser/v6ToV1.js +13 -0
  284. package/node_modules/uuid/dist/cjs-browser/v7.d.ts +9 -0
  285. package/node_modules/uuid/dist/cjs-browser/v7.js +69 -0
  286. package/node_modules/uuid/dist/cjs-browser/validate.d.ts +2 -0
  287. package/node_modules/uuid/dist/cjs-browser/validate.js +7 -0
  288. package/node_modules/uuid/dist/cjs-browser/version.d.ts +2 -0
  289. package/node_modules/uuid/dist/cjs-browser/version.js +10 -0
  290. package/node_modules/uuid/dist/esm/bin/uuid +2 -0
  291. package/node_modules/uuid/dist/esm/index.d.ts +15 -0
  292. package/node_modules/uuid/dist/esm/index.js +14 -0
  293. package/node_modules/uuid/dist/esm/max.d.ts +2 -0
  294. package/node_modules/uuid/dist/esm/max.js +1 -0
  295. package/node_modules/uuid/dist/esm/md5.d.ts +4 -0
  296. package/node_modules/uuid/dist/esm/md5.js +11 -0
  297. package/node_modules/uuid/dist/esm/native.d.ts +6 -0
  298. package/node_modules/uuid/dist/esm/native.js +2 -0
  299. package/node_modules/uuid/dist/esm/nil.d.ts +2 -0
  300. package/node_modules/uuid/dist/esm/nil.js +1 -0
  301. package/node_modules/uuid/dist/esm/parse.d.ts +2 -0
  302. package/node_modules/uuid/dist/esm/parse.js +9 -0
  303. package/node_modules/uuid/dist/esm/regex.d.ts +2 -0
  304. package/node_modules/uuid/dist/esm/regex.js +1 -0
  305. package/node_modules/uuid/dist/esm/rng.d.ts +1 -0
  306. package/node_modules/uuid/dist/esm/rng.js +10 -0
  307. package/node_modules/uuid/dist/esm/sha1.d.ts +4 -0
  308. package/node_modules/uuid/dist/esm/sha1.js +11 -0
  309. package/node_modules/uuid/dist/esm/stringify.d.ts +3 -0
  310. package/node_modules/uuid/dist/esm/stringify.js +35 -0
  311. package/node_modules/uuid/dist/esm/types.d.ts +21 -0
  312. package/node_modules/uuid/dist/esm/types.js +1 -0
  313. package/node_modules/uuid/dist/esm/uuid-bin.d.ts +1 -0
  314. package/node_modules/uuid/dist/esm/uuid-bin.js +70 -0
  315. package/node_modules/uuid/dist/esm/v1.d.ts +11 -0
  316. package/node_modules/uuid/dist/esm/v1.js +83 -0
  317. package/node_modules/uuid/dist/esm/v1ToV6.d.ts +2 -0
  318. package/node_modules/uuid/dist/esm/v1ToV6.js +10 -0
  319. package/node_modules/uuid/dist/esm/v3.d.ts +9 -0
  320. package/node_modules/uuid/dist/esm/v3.js +9 -0
  321. package/node_modules/uuid/dist/esm/v35.d.ts +7 -0
  322. package/node_modules/uuid/dist/esm/v35.js +36 -0
  323. package/node_modules/uuid/dist/esm/v4.d.ts +4 -0
  324. package/node_modules/uuid/dist/esm/v4.js +27 -0
  325. package/node_modules/uuid/dist/esm/v5.d.ts +9 -0
  326. package/node_modules/uuid/dist/esm/v5.js +9 -0
  327. package/node_modules/uuid/dist/esm/v6.d.ts +4 -0
  328. package/node_modules/uuid/dist/esm/v6.js +17 -0
  329. package/node_modules/uuid/dist/esm/v6ToV1.d.ts +2 -0
  330. package/node_modules/uuid/dist/esm/v6ToV1.js +10 -0
  331. package/node_modules/uuid/dist/esm/v7.d.ts +9 -0
  332. package/node_modules/uuid/dist/esm/v7.js +65 -0
  333. package/node_modules/uuid/dist/esm/validate.d.ts +2 -0
  334. package/node_modules/uuid/dist/esm/validate.js +5 -0
  335. package/node_modules/uuid/dist/esm/version.d.ts +2 -0
  336. package/node_modules/uuid/dist/esm/version.js +8 -0
  337. package/node_modules/uuid/dist/esm-browser/index.d.ts +15 -0
  338. package/node_modules/uuid/dist/esm-browser/index.js +14 -0
  339. package/node_modules/uuid/dist/esm-browser/max.d.ts +2 -0
  340. package/node_modules/uuid/dist/esm-browser/max.js +1 -0
  341. package/node_modules/uuid/dist/esm-browser/md5.d.ts +2 -0
  342. package/node_modules/uuid/dist/esm-browser/md5.js +135 -0
  343. package/node_modules/uuid/dist/esm-browser/native.d.ts +4 -0
  344. package/node_modules/uuid/dist/esm-browser/native.js +2 -0
  345. package/node_modules/uuid/dist/esm-browser/nil.d.ts +2 -0
  346. package/node_modules/uuid/dist/esm-browser/nil.js +1 -0
  347. package/node_modules/uuid/dist/esm-browser/parse.d.ts +2 -0
  348. package/node_modules/uuid/dist/esm-browser/parse.js +9 -0
  349. package/node_modules/uuid/dist/esm-browser/regex.d.ts +2 -0
  350. package/node_modules/uuid/dist/esm-browser/regex.js +1 -0
  351. package/node_modules/uuid/dist/esm-browser/rng.d.ts +1 -0
  352. package/node_modules/uuid/dist/esm-browser/rng.js +11 -0
  353. package/node_modules/uuid/dist/esm-browser/sha1.d.ts +2 -0
  354. package/node_modules/uuid/dist/esm-browser/sha1.js +70 -0
  355. package/node_modules/uuid/dist/esm-browser/stringify.d.ts +3 -0
  356. package/node_modules/uuid/dist/esm-browser/stringify.js +35 -0
  357. package/node_modules/uuid/dist/esm-browser/types.d.ts +21 -0
  358. package/node_modules/uuid/dist/esm-browser/types.js +1 -0
  359. package/node_modules/uuid/dist/esm-browser/uuid-bin.d.ts +1 -0
  360. package/node_modules/uuid/dist/esm-browser/uuid-bin.js +70 -0
  361. package/node_modules/uuid/dist/esm-browser/v1.d.ts +11 -0
  362. package/node_modules/uuid/dist/esm-browser/v1.js +83 -0
  363. package/node_modules/uuid/dist/esm-browser/v1ToV6.d.ts +2 -0
  364. package/node_modules/uuid/dist/esm-browser/v1ToV6.js +10 -0
  365. package/node_modules/uuid/dist/esm-browser/v3.d.ts +9 -0
  366. package/node_modules/uuid/dist/esm-browser/v3.js +9 -0
  367. package/node_modules/uuid/dist/esm-browser/v35.d.ts +7 -0
  368. package/node_modules/uuid/dist/esm-browser/v35.js +36 -0
  369. package/node_modules/uuid/dist/esm-browser/v4.d.ts +4 -0
  370. package/node_modules/uuid/dist/esm-browser/v4.js +27 -0
  371. package/node_modules/uuid/dist/esm-browser/v5.d.ts +9 -0
  372. package/node_modules/uuid/dist/esm-browser/v5.js +9 -0
  373. package/node_modules/uuid/dist/esm-browser/v6.d.ts +4 -0
  374. package/node_modules/uuid/dist/esm-browser/v6.js +17 -0
  375. package/node_modules/uuid/dist/esm-browser/v6ToV1.d.ts +2 -0
  376. package/node_modules/uuid/dist/esm-browser/v6ToV1.js +10 -0
  377. package/node_modules/uuid/dist/esm-browser/v7.d.ts +9 -0
  378. package/node_modules/uuid/dist/esm-browser/v7.js +65 -0
  379. package/node_modules/uuid/dist/esm-browser/validate.d.ts +2 -0
  380. package/node_modules/uuid/dist/esm-browser/validate.js +5 -0
  381. package/node_modules/uuid/dist/esm-browser/version.d.ts +2 -0
  382. package/node_modules/uuid/dist/esm-browser/version.js +8 -0
  383. package/node_modules/uuid/package.json +132 -0
  384. package/package.json +17 -12
  385. package/scripts/cleanup-test-resources.ts +369 -0
@@ -20,6 +20,10 @@
20
20
  */
21
21
  import * as cdktf from "cdktf";
22
22
  import { Construct } from "constructs";
23
+ import type { ActionGroupProps } from "../../../azure-actiongroup/lib/action-group";
24
+ import type { ActivityLogAlertProps } from "../../../azure-activitylogalert/lib/activity-log-alert";
25
+ import type { DiagnosticSettingsProps } from "../../../azure-diagnosticsettings/lib/diagnostic-settings";
26
+ import type { MetricAlertProps } from "../../../azure-metricalert/lib/metric-alert";
23
27
  import { ApiSchema, VersionConfig, ValidationResult, MigrationAnalysis } from "../version-manager/interfaces/version-interfaces";
24
28
  /**
25
29
  * Retention policy configuration
@@ -41,10 +45,47 @@ export interface DiagnosticLogConfig {
41
45
  * Metric configuration for diagnostic settings
42
46
  */
43
47
  export interface DiagnosticMetricConfig {
44
- readonly category: string;
48
+ /** Metric category name (used in newer API versions) */
49
+ readonly category?: string;
50
+ /** Time grain for metrics in ISO 8601 duration format (used in API version 2016-09-01, e.g., "PT1M") */
51
+ readonly timeGrain?: string;
45
52
  readonly enabled: boolean;
46
53
  readonly retentionPolicy?: RetentionPolicyConfig;
47
54
  }
55
+ /**
56
+ * Monitoring configuration for Azure resources
57
+ *
58
+ * Provides integrated monitoring capabilities including diagnostic settings,
59
+ * metric alerts, and activity log alerts. All monitoring is optional and
60
+ * disabled by default.
61
+ */
62
+ export interface MonitoringConfig {
63
+ /**
64
+ * Whether monitoring is enabled
65
+ * @defaultValue true
66
+ */
67
+ readonly enabled?: boolean;
68
+ /**
69
+ * Diagnostic settings configuration
70
+ * Uses the full DiagnosticSettings construct for consistency
71
+ */
72
+ readonly diagnosticSettings?: DiagnosticSettingsProps;
73
+ /**
74
+ * Action groups to create for this resource
75
+ * Creates new ActionGroup instances as child constructs
76
+ */
77
+ readonly actionGroups?: ActionGroupProps[];
78
+ /**
79
+ * Metric alerts configuration
80
+ * Creates MetricAlert instances scoped to this resource
81
+ */
82
+ readonly metricAlerts?: MetricAlertProps[];
83
+ /**
84
+ * Activity log alerts configuration
85
+ * Creates ActivityLogAlert instances for this resource's operations
86
+ */
87
+ readonly activityLogAlerts?: ActivityLogAlertProps[];
88
+ }
48
89
  /**
49
90
  * Properties for versioned Azure resources
50
91
  *
@@ -101,6 +142,30 @@ export interface AzapiResourceProps {
101
142
  * @defaultValue true
102
143
  */
103
144
  readonly enableTransformation?: boolean;
145
+ /**
146
+ * Monitoring configuration for this resource
147
+ *
148
+ * Enables integrated monitoring with diagnostic settings, metric alerts,
149
+ * and activity log alerts. All monitoring is optional and disabled by default.
150
+ *
151
+ * @example
152
+ * monitoring: {
153
+ * enabled: true,
154
+ * diagnosticSettings: {
155
+ * workspaceId: logAnalytics.id,
156
+ * metrics: ['AllMetrics'],
157
+ * logs: ['AuditLogs']
158
+ * },
159
+ * metricAlerts: [{
160
+ * name: 'high-cpu-alert',
161
+ * severity: 2,
162
+ * scopes: [], // Automatically set to this resource
163
+ * criteria: { ... },
164
+ * actions: [{ actionGroupId: actionGroup.id }]
165
+ * }]
166
+ * }
167
+ */
168
+ readonly monitoring?: MonitoringConfig;
104
169
  }
105
170
  /**
106
171
  * Abstract base class for version-aware Azure resource management
@@ -212,6 +277,9 @@ export declare abstract class AzapiResource extends Construct {
212
277
  readonly migrationAnalysis?: MigrationAnalysis;
213
278
  private readonly _apiVersionManager;
214
279
  private readonly _schemaMapper;
280
+ protected readonly monitoringActionGroups: Construct[];
281
+ protected readonly monitoringMetricAlerts: Construct[];
282
+ protected readonly monitoringActivityLogAlerts: Construct[];
215
283
  /**
216
284
  * Creates a new AzapiResource instance
217
285
  *
@@ -324,13 +392,38 @@ export declare abstract class AzapiResource extends Construct {
324
392
  */
325
393
  private _createAzureResource;
326
394
  /**
327
- * Determines the parent ID for the resource
395
+ * Resolves the parent resource ID for this resource.
396
+ *
397
+ * Override this method in child resource classes (like Subnet) that need
398
+ * custom parent ID resolution logic. By default, this delegates to the
399
+ * private _determineParentId method which handles standard resource types.
400
+ *
401
+ * @param props - The resource properties
402
+ * @returns The parent resource ID
403
+ */
404
+ protected resolveParentId(props: any): string;
405
+ /**
406
+ * Determines the parent ID for the resource (internal implementation)
407
+ *
408
+ * This method provides the default parent ID resolution logic for most resources.
409
+ * Child resources should override resolveParentId() instead of this method.
328
410
  */
329
411
  private _determineParentId;
330
412
  /**
331
413
  * Logs framework messages including warnings and migration guidance
332
414
  */
333
415
  private _logFrameworkMessages;
416
+ /**
417
+ * Creates monitoring resources based on the monitoring configuration
418
+ *
419
+ * This method is called automatically during construction if monitoring is configured.
420
+ * It creates action groups, metric alerts, and activity log alerts as child constructs.
421
+ *
422
+ * Protected to allow subclasses to override or extend monitoring behavior.
423
+ *
424
+ * @param config - The monitoring configuration from props
425
+ */
426
+ protected createMonitoringResources(config: MonitoringConfig): Promise<void>;
334
427
  /**
335
428
  * Creates the underlying AZAPI Terraform resource using the generated provider classes
336
429
  *
@@ -371,12 +464,6 @@ export declare abstract class AzapiResource extends Construct {
371
464
  * @param roleDefinitionName - The name of the Azure RBAC role to be assigned
372
465
  */
373
466
  addAccess(objectId: string, roleDefinitionName: string): void;
374
- /**
375
- * Adds diagnostic settings to this resource using AZAPI
376
- *
377
- * @param props - The diagnostic settings configuration
378
- */
379
- addDiagnosticSettings(props: AzapiDiagnosticSettingsProps): AzapiDiagnosticSettings;
380
467
  }
381
468
  /**
382
469
  * Properties for AZAPI role assignment
@@ -392,22 +479,3 @@ export interface AzapiRoleAssignmentProps {
392
479
  export declare class AzapiRoleAssignment extends Construct {
393
480
  constructor(scope: Construct, id: string, props: AzapiRoleAssignmentProps);
394
481
  }
395
- /**
396
- * Properties for AZAPI diagnostic settings
397
- */
398
- export interface AzapiDiagnosticSettingsProps {
399
- readonly name?: string;
400
- readonly logAnalyticsWorkspaceId?: string;
401
- readonly eventhubAuthorizationRuleId?: string;
402
- readonly eventhubName?: string;
403
- readonly storageAccountId?: string;
404
- readonly targetResourceId?: string;
405
- readonly logs?: DiagnosticLogConfig[];
406
- readonly metrics?: DiagnosticMetricConfig[];
407
- }
408
- /**
409
- * AZAPI-based diagnostic settings construct
410
- */
411
- export declare class AzapiDiagnosticSettings extends Construct {
412
- constructor(scope: Construct, id: string, props: AzapiDiagnosticSettingsProps);
413
- }
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
- var _a, _b, _c;
2
+ var _a, _b;
3
3
  Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.AzapiDiagnosticSettings = exports.AzapiRoleAssignment = exports.AzapiResource = void 0;
4
+ exports.AzapiRoleAssignment = exports.AzapiResource = void 0;
5
5
  const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  /**
7
7
  * AzapiResource - A unified framework for version-aware Azure resource management
@@ -91,6 +91,10 @@ class AzapiResource extends constructs_1.Construct {
91
91
  constructor(scope, id, props = {}) {
92
92
  // Initialize the base Construct
93
93
  super(scope, id);
94
+ // Monitoring resources (protected for subclass access)
95
+ this.monitoringActionGroups = [];
96
+ this.monitoringMetricAlerts = [];
97
+ this.monitoringActivityLogAlerts = [];
94
98
  // Initialize basic properties
95
99
  this.name = props.name || this.node.id;
96
100
  this.location = props.location || "eastus";
@@ -127,7 +131,12 @@ class AzapiResource extends constructs_1.Construct {
127
131
  }
128
132
  // Step 8: Create the Azure resource
129
133
  this._createAzureResource(processedProps);
130
- // Step 9: Log warnings and migration guidance
134
+ // Step 9: Create monitoring resources if configured
135
+ // Note: Monitoring resources are created lazily to avoid circular dependencies
136
+ if (props.monitoring) {
137
+ void this.createMonitoringResources(props.monitoring);
138
+ }
139
+ // Step 10: Log warnings and migration guidance
131
140
  this._logFrameworkMessages();
132
141
  }
133
142
  /**
@@ -252,13 +261,29 @@ class AzapiResource extends constructs_1.Construct {
252
261
  _createAzureResource(props) {
253
262
  // Create the resource body using the subclass implementation
254
263
  const resourceBody = this.createResourceBody(props);
255
- // Determine the parent ID (this would be resource-type specific)
256
- const parentId = this._determineParentId(props);
264
+ // Determine the parent ID using the overrideable method
265
+ const parentId = this.resolveParentId(props);
257
266
  // Create the AZAPI resource using the base class method
258
267
  this.terraformResource = this.createAzapiResource(resourceBody, parentId, this.name, this.location);
259
268
  }
260
269
  /**
261
- * Determines the parent ID for the resource
270
+ * Resolves the parent resource ID for this resource.
271
+ *
272
+ * Override this method in child resource classes (like Subnet) that need
273
+ * custom parent ID resolution logic. By default, this delegates to the
274
+ * private _determineParentId method which handles standard resource types.
275
+ *
276
+ * @param props - The resource properties
277
+ * @returns The parent resource ID
278
+ */
279
+ resolveParentId(props) {
280
+ return this._determineParentId(props);
281
+ }
282
+ /**
283
+ * Determines the parent ID for the resource (internal implementation)
284
+ *
285
+ * This method provides the default parent ID resolution logic for most resources.
286
+ * Child resources should override resolveParentId() instead of this method.
262
287
  */
263
288
  _determineParentId(props) {
264
289
  // This is a simplified implementation - real implementation would be
@@ -309,6 +334,67 @@ class AzapiResource extends constructs_1.Construct {
309
334
  }
310
335
  }
311
336
  // =============================================================================
337
+ // MONITORING INTEGRATION METHODS
338
+ // =============================================================================
339
+ /**
340
+ * Creates monitoring resources based on the monitoring configuration
341
+ *
342
+ * This method is called automatically during construction if monitoring is configured.
343
+ * It creates action groups, metric alerts, and activity log alerts as child constructs.
344
+ *
345
+ * Protected to allow subclasses to override or extend monitoring behavior.
346
+ *
347
+ * @param config - The monitoring configuration from props
348
+ */
349
+ async createMonitoringResources(config) {
350
+ // Skip if monitoring is explicitly disabled
351
+ if (config.enabled === false) {
352
+ return;
353
+ }
354
+ // Create diagnostic settings using dynamic import to avoid circular dependency
355
+ if (config.diagnosticSettings) {
356
+ const { DiagnosticSettings } = await Promise.resolve().then(() => require("../../../azure-diagnosticsettings/lib/diagnostic-settings"));
357
+ new DiagnosticSettings(this, "monitoring-diagnostic-settings", {
358
+ ...config.diagnosticSettings,
359
+ targetResourceId: this.resourceId,
360
+ });
361
+ }
362
+ // Create action groups using dynamic import
363
+ if (config.actionGroups && config.actionGroups.length > 0) {
364
+ const { ActionGroup } = await Promise.resolve().then(() => require("../../../azure-actiongroup/lib/action-group"));
365
+ config.actionGroups.forEach((actionGroupProps, index) => {
366
+ const actionGroup = new ActionGroup(this, `monitoring-action-group-${index}`, actionGroupProps);
367
+ this.monitoringActionGroups.push(actionGroup);
368
+ });
369
+ }
370
+ // Create metric alerts using dynamic import
371
+ if (config.metricAlerts && config.metricAlerts.length > 0) {
372
+ const { MetricAlert } = await Promise.resolve().then(() => require("../../../azure-metricalert/lib/metric-alert"));
373
+ config.metricAlerts.forEach((metricAlertProps, index) => {
374
+ // If scopes not provided, default to this resource
375
+ const propsWithScope = {
376
+ ...metricAlertProps,
377
+ scopes: metricAlertProps.scopes || [this.resourceId],
378
+ };
379
+ const metricAlert = new MetricAlert(this, `monitoring-metric-alert-${index}`, propsWithScope);
380
+ this.monitoringMetricAlerts.push(metricAlert);
381
+ });
382
+ }
383
+ // Create activity log alerts using dynamic import
384
+ if (config.activityLogAlerts && config.activityLogAlerts.length > 0) {
385
+ const { ActivityLogAlert } = await Promise.resolve().then(() => require("../../../azure-activitylogalert/lib/activity-log-alert"));
386
+ config.activityLogAlerts.forEach((activityLogAlertProps, index) => {
387
+ // If scopes not provided, default to this resource
388
+ const propsWithScope = {
389
+ ...activityLogAlertProps,
390
+ scopes: activityLogAlertProps.scopes || [this.resourceId],
391
+ };
392
+ const activityLogAlert = new ActivityLogAlert(this, `monitoring-activity-log-alert-${index}`, propsWithScope);
393
+ this.monitoringActivityLogAlerts.push(activityLogAlert);
394
+ });
395
+ }
396
+ }
397
+ // =============================================================================
312
398
  // RESOURCE MANAGEMENT METHODS (from AzapiResource)
313
399
  // =============================================================================
314
400
  /**
@@ -389,21 +475,10 @@ class AzapiResource extends constructs_1.Construct {
389
475
  scope: this.resourceId,
390
476
  });
391
477
  }
392
- /**
393
- * Adds diagnostic settings to this resource using AZAPI
394
- *
395
- * @param props - The diagnostic settings configuration
396
- */
397
- addDiagnosticSettings(props) {
398
- return new AzapiDiagnosticSettings(this, "diagnostics", {
399
- ...props,
400
- targetResourceId: this.resourceId,
401
- });
402
- }
403
478
  }
404
479
  exports.AzapiResource = AzapiResource;
405
480
  _a = JSII_RTTI_SYMBOL_1;
406
- AzapiResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiResource", version: "1.0.0" };
481
+ AzapiResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiResource", version: "1.2.0" };
407
482
  /**
408
483
  * AZAPI-based role assignment construct
409
484
  */
@@ -426,43 +501,5 @@ class AzapiRoleAssignment extends constructs_1.Construct {
426
501
  }
427
502
  exports.AzapiRoleAssignment = AzapiRoleAssignment;
428
503
  _b = JSII_RTTI_SYMBOL_1;
429
- AzapiRoleAssignment[_b] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiRoleAssignment", version: "1.0.0" };
430
- /**
431
- * AZAPI-based diagnostic settings construct
432
- */
433
- class AzapiDiagnosticSettings extends constructs_1.Construct {
434
- constructor(scope, id, props) {
435
- super(scope, id);
436
- const properties = {};
437
- if (props.logAnalyticsWorkspaceId) {
438
- properties.workspaceId = props.logAnalyticsWorkspaceId;
439
- }
440
- if (props.eventhubAuthorizationRuleId) {
441
- properties.eventHubAuthorizationRuleId =
442
- props.eventhubAuthorizationRuleId;
443
- }
444
- if (props.eventhubName) {
445
- properties.eventHubName = props.eventhubName;
446
- }
447
- if (props.storageAccountId) {
448
- properties.storageAccountId = props.storageAccountId;
449
- }
450
- if (props.logs) {
451
- properties.logs = props.logs;
452
- }
453
- if (props.metrics) {
454
- properties.metrics = props.metrics;
455
- }
456
- const config = {
457
- type: "Microsoft.Insights/diagnosticSettings",
458
- name: props.name || "diagnostics",
459
- parentId: props.targetResourceId || "",
460
- body: properties,
461
- };
462
- new resource_1.Resource(this, "diagnostic-settings", config);
463
- }
464
- }
465
- exports.AzapiDiagnosticSettings = AzapiDiagnosticSettings;
466
- _c = JSII_RTTI_SYMBOL_1;
467
- AzapiDiagnosticSettings[_c] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiDiagnosticSettings", version: "1.0.0" };
468
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azapi-resource.js","sourceRoot":"","sources":["../../../../src/core-azure/lib/azapi/azapi-resource.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * AzapiResource - A unified framework for version-aware Azure resource management\n *\n * This abstract base class provides a self-contained unified framework approach\n * for Azure resource management with automatic version management, schema-driven\n * property transformation, and migration analysis capabilities.\n *\n * Key Features:\n * - Automatic latest version resolution when no version is specified\n * - Support for explicit version pinning for stability\n * - Schema-driven property transformation between versions\n * - Migration analysis and deprecation warnings\n * - Built-in role assignment and diagnostic settings support\n * - JSII-compliant design for multi-language support\n *\n * This class replaces the previous dual-class approach (AzapiResource + AzapiResource)\n * with a single, self-contained implementation that handles all resource management needs.\n *\n * @packageDocumentation\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { DataAzapiClientConfig } from \"./providers-azapi/data-azapi-client-config\";\nimport { Resource, ResourceConfig } from \"./providers-azapi/resource\";\nimport { SchemaMapper } from \"./schema-mapper/schema-mapper\";\nimport { ApiVersionManager } from \"../version-manager/api-version-manager\";\nimport {\n  ApiSchema,\n  VersionConfig,\n  ValidationResult,\n  MigrationAnalysis,\n  VersionSupportLevel,\n} from \"../version-manager/interfaces/version-interfaces\";\n\n/**\n * Retention policy configuration\n */\nexport interface RetentionPolicyConfig {\n  readonly enabled: boolean;\n  readonly days: number;\n}\n\n/**\n * Log configuration for diagnostic settings\n */\nexport interface DiagnosticLogConfig {\n  readonly category?: string;\n  readonly categoryGroup?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Metric configuration for diagnostic settings\n */\nexport interface DiagnosticMetricConfig {\n  readonly category: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Properties for versioned Azure resources\n *\n * Combines base resource properties with version management capabilities\n * and advanced configuration options for the unified framework.\n */\nexport interface AzapiResourceProps {\n  /**\n   * The name of the resource\n   */\n  readonly name?: string;\n\n  /**\n   * The location where the resource should be created\n   */\n  readonly location?: string;\n\n  /**\n   * Tags to apply to the resource\n   */\n  readonly tags?: Record<string, string>;\n  /**\n   * Explicit API version to use for this resource\n   *\n   * If not specified, the latest active version will be automatically resolved.\n   * Use this for version pinning when stability is required over latest features.\n   *\n   * @example \"2024-11-01\"\n   * @defaultValue Latest active version from ApiVersionManager\n   */\n  readonly apiVersion?: string;\n\n  /**\n   * Whether to enable migration analysis warnings\n   *\n   * When true, the framework will analyze the current version for deprecation\n   * status and provide migration recommendations in the deployment output.\n   *\n   * @defaultValue true\n   */\n  readonly enableMigrationAnalysis?: boolean;\n\n  /**\n   * Whether to validate properties against the schema\n   *\n   * When true, all properties will be validated against the API schema before\n   * resource creation. Validation errors will cause deployment failures.\n   *\n   * @defaultValue true\n   */\n  readonly enableValidation?: boolean;\n\n  /**\n   * Whether to apply property transformations automatically\n   *\n   * When true, properties will be automatically transformed according to the\n   * target schema's transformation rules. This enables backward compatibility.\n   *\n   * @defaultValue true\n   */\n  readonly enableTransformation?: boolean;\n}\n\n/**\n * Abstract base class for version-aware Azure resource management\n *\n * AzapiResource provides a unified framework for creating Azure resources\n * with automatic version management, schema validation, property transformation,\n * and migration analysis. It extends the existing AzapiResource class while\n * maintaining full backward compatibility.\n *\n * This class implements the core framework that enables:\n * - Automatic resolution of the latest API version when none is specified\n * - Explicit version pinning for environments requiring stability\n * - Schema-driven property validation and transformation\n * - Migration analysis with breaking change detection\n * - Deprecation warnings and upgrade recommendations\n *\n * Subclasses must implement the abstract methods to provide resource-specific\n * configuration while the framework handles all version management complexity.\n *\n * @example Basic usage with automatic version resolution:\n * class MyResource extends AzapiResource {\n *   protected getDefaultVersion(): string {\n *     return \"2024-11-01\"; // fallback if no versions registered\n *   }\n *\n *   protected getResourceType(): string {\n *     return \"Microsoft.Resources/resourceGroups\";\n *   }\n *\n *   protected getApiSchema(): ApiSchema {\n *     return this.resolveSchema();\n *   }\n *\n *   protected createResourceBody(props: any): any {\n *     return { location: props.location, tags: props.tags || {} };\n *   }\n * }\n *\n * @example Usage with explicit version pinning:\n * new MyResource(this, \"resource\", {\n *   name: \"my-resource\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-01-01\" // Pin to specific version\n * });\n *\n * @stability stable\n */\nexport abstract class AzapiResource extends Construct {\n  /**\n   * The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   * @internal\n   */\n  protected readonly _resourceType: string;\n\n  /**\n   * The API version to use for this resource\n   */\n  protected readonly apiVersion: string;\n\n  /**\n   * The underlying AZAPI Terraform resource\n   */\n  protected terraformResource!: cdktf.TerraformResource;\n\n  /**\n   * The name of the resource\n   */\n  public readonly name: string;\n\n  /**\n   * The location of the resource\n   */\n  public readonly location: string;\n\n  /**\n   * The resource ID (abstract - must be implemented by subclasses)\n   */\n  public abstract readonly id: string;\n\n  /**\n   * The resolved API version being used for this resource instance\n   *\n   * This is the actual version that will be used for the Azure API call,\n   * either explicitly specified in props or automatically resolved to\n   * the latest active version.\n   */\n  public readonly resolvedApiVersion: string;\n\n  /**\n   * The API schema for the resolved version\n   *\n   * Contains the complete schema definition including properties, validation\n   * rules, and transformation mappings for the resolved API version.\n   */\n  public readonly schema: ApiSchema;\n\n  /**\n   * The version configuration for the resolved version\n   *\n   * Contains lifecycle information, breaking changes, and migration metadata\n   * for the resolved API version.\n   */\n  public readonly versionConfig: VersionConfig;\n\n  /**\n   * Validation results for the resource properties\n   *\n   * Available after construction if validation is enabled. Contains detailed\n   * information about any validation errors or warnings.\n   */\n  public readonly validationResult?: ValidationResult;\n\n  /**\n   * Migration analysis results\n   *\n   * Available after construction if migration analysis is enabled and a\n   * previous version can be determined for comparison.\n   */\n  public readonly migrationAnalysis?: MigrationAnalysis;\n\n  // Framework components\n  private readonly _apiVersionManager: ApiVersionManager;\n  private readonly _schemaMapper: SchemaMapper;\n\n  /**\n   * Creates a new AzapiResource instance\n   *\n   * The constructor handles all framework initialization including version resolution,\n   * schema loading, property validation, transformation, and migration analysis.\n   * It maintains full backward compatibility with the AzapiResource constructor.\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 resource\n   */\n  constructor(scope: Construct, id: string, props: AzapiResourceProps = {}) {\n    // Initialize the base Construct\n    super(scope, id);\n\n    // Initialize basic properties\n    this.name = props.name || this.node.id;\n    this.location = props.location || \"eastus\";\n\n    // Initialize the API version manager\n    this._apiVersionManager = ApiVersionManager.instance();\n\n    // Step 1: Resolve the API version to use\n    this.resolvedApiVersion = this._resolveApiVersion(props.apiVersion);\n\n    // Step 2: Set required abstract properties for AzapiResource\n    this._resourceType = this.resourceType();\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 3: Load the schema and version configuration\n    this.schema = this.apiSchema();\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this._resourceType,\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Version configuration not found for ${this.resourceType()}@${this.resolvedApiVersion}. ` +\n          `Please ensure the version is registered with the ApiVersionManager.`,\n      );\n    }\n    this.versionConfig = versionConfig;\n\n    // Step 4: Initialize the schema mapper\n    this._schemaMapper = SchemaMapper.create(this.schema);\n\n    // Step 5: Process properties through the framework pipeline\n    const processedProps = this._processProperties(props);\n\n    // Step 6: Perform validation if enabled\n    if (props.enableValidation !== false) {\n      this.validationResult = this._validateProperties(processedProps);\n      if (!this.validationResult.valid) {\n        throw new Error(\n          `Property validation failed for ${this.resourceType}:\\n` +\n            this.validationResult.errors.join(\"\\n\"),\n        );\n      }\n    }\n\n    // Step 7: Perform migration analysis if enabled\n    if (props.enableMigrationAnalysis !== false) {\n      this.migrationAnalysis = this._performMigrationAnalysis();\n    }\n\n    // Step 8: Create the Azure resource\n    this._createAzureResource(processedProps);\n\n    // Step 9: Log warnings and migration guidance\n    this._logFrameworkMessages();\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   *\n   * This method should return a sensible default version that can be used\n   * as a fallback if the ApiVersionManager doesn't have any versions registered\n   * for this resource type.\n   *\n   * @returns The default API version string (e.g., \"2024-11-01\")\n   */\n  protected abstract defaultVersion(): string;\n\n  /**\n   * Gets the Azure resource type for this resource\n   *\n   * This method should return the full Azure resource type identifier that\n   * will be used for API calls and version management.\n   *\n   * @returns The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   */\n  protected abstract resourceType(): string;\n\n  /**\n   * Gets the API schema for the resolved version\n   *\n   * This method should return the complete API schema for the resolved version,\n   * including all property definitions, validation rules, and transformation\n   * mappings. Use the resolveSchema() helper method for standard schema resolution.\n   *\n   * @returns The API schema for the resolved version\n   */\n  protected abstract apiSchema(): ApiSchema;\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * This method should transform the input properties into the JSON body format\n   * expected by the Azure REST API for the resolved version. The framework will\n   * have already applied any necessary property transformations and validation.\n   *\n   * @param props - The processed and validated properties for the resource\n   * @returns The resource body object to send to Azure API\n   */\n  protected abstract createResourceBody(props: any): any;\n\n  /**\n   * Helper method for standard schema resolution\n   *\n   * Subclasses can use this method to resolve the schema for the current version\n   * from the ApiVersionManager. This provides a standard implementation that\n   * most resources can use without custom logic.\n   *\n   * @returns The API schema for the resolved version\n   * @throws Error if the schema cannot be resolved\n   */\n  protected resolveSchema(): ApiSchema {\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this.resourceType(),\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Cannot resolve schema: version configuration not found for ` +\n          `${this.resourceType()}@${this.resolvedApiVersion}`,\n      );\n    }\n\n    return versionConfig.schema;\n  }\n\n  /**\n   * Gets the latest available version for this resource type\n   *\n   * This method provides access to the latest version resolution logic\n   * for use in subclasses or external tooling.\n   *\n   * @returns The latest available version, or undefined if none found\n   */\n  public latestVersion(): string | undefined {\n    return this._apiVersionManager.latestVersion(this.resourceType());\n  }\n\n  /**\n   * Gets all supported versions for this resource type\n   *\n   * This method provides access to the version registry for use in\n   * subclasses or external tooling.\n   *\n   * @returns Array of supported version strings, sorted by release date\n   */\n  public supportedVersions(): string[] {\n    return this._apiVersionManager.supportedVersions(this.resourceType());\n  }\n\n  /**\n   * Analyzes migration from current version to a target version\n   *\n   * This method enables external tools to analyze migration requirements\n   * between versions for planning and automation purposes.\n   *\n   * @param targetVersion - The target version to analyze migration to\n   * @returns Detailed migration analysis results\n   */\n  public analyzeMigrationTo(targetVersion: string): MigrationAnalysis {\n    return this._apiVersionManager.analyzeMigration(\n      this.resourceType(),\n      this.resolvedApiVersion,\n      targetVersion,\n    );\n  }\n\n  // =============================================================================\n  // PRIVATE IMPLEMENTATION METHODS\n  // =============================================================================\n\n  /**\n   * Resolves the API version to use for this resource instance\n   */\n  private _resolveApiVersion(explicitVersion?: string): string {\n    if (explicitVersion) {\n      // Validate that the explicit version is supported\n      if (\n        !this._apiVersionManager.validateVersionSupport(\n          this.resourceType(),\n          explicitVersion,\n        )\n      ) {\n        const supportedVersions = this._apiVersionManager.supportedVersions(\n          this.resourceType(),\n        );\n        throw new Error(\n          `Unsupported API version '${explicitVersion}' for resource type '${this.resourceType()}'. ` +\n            `Supported versions: ${supportedVersions.join(\", \")}`,\n        );\n      }\n      return explicitVersion;\n    }\n\n    // Try to get the latest version from the manager\n    const latestVersion = this._apiVersionManager.latestVersion(\n      this.resourceType(),\n    );\n    if (latestVersion) {\n      return latestVersion;\n    }\n\n    // Fall back to the default version\n    const defaultVersion = this.defaultVersion();\n\n    // Warn that we're using the default version\n    console.warn(\n      `No versions registered for ${this.resourceType()}. ` +\n        `Using default version: ${defaultVersion}. ` +\n        `Consider registering versions with ApiVersionManager for better version management.`,\n    );\n\n    return defaultVersion;\n  }\n\n  /**\n   * Processes properties through the framework pipeline\n   */\n  private _processProperties(props: AzapiResourceProps): any {\n    let processedProps = { ...props };\n\n    // Apply default values from the schema\n    processedProps = this._schemaMapper.applyDefaults(processedProps);\n\n    // Apply property transformations if enabled\n    if (props.enableTransformation !== false) {\n      // For transformation, we would need a source schema, but since we're not\n      // migrating from a different version in this context, we'll skip transformation\n      // This would be used when upgrading from one version to another\n    }\n\n    return processedProps;\n  }\n\n  /**\n   * Validates properties against the schema\n   */\n  private _validateProperties(props: any): ValidationResult {\n    return this._schemaMapper.validateProperties(props);\n  }\n\n  /**\n   * Performs migration analysis for the current version\n   */\n  private _performMigrationAnalysis(): MigrationAnalysis | undefined {\n    // Check if the current version is deprecated\n    if (\n      this.versionConfig.supportLevel === VersionSupportLevel.DEPRECATED ||\n      this.versionConfig.supportLevel === VersionSupportLevel.SUNSET\n    ) {\n      const latestVersion = this.latestVersion();\n      if (latestVersion && latestVersion !== this.resolvedApiVersion) {\n        return this._apiVersionManager.analyzeMigration(\n          this.resourceType(),\n          this.resolvedApiVersion,\n          latestVersion,\n        );\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Creates the underlying Azure resource\n   */\n  private _createAzureResource(props: any): void {\n    // Create the resource body using the subclass implementation\n    const resourceBody = this.createResourceBody(props);\n\n    // Determine the parent ID (this would be resource-type specific)\n    const parentId = this._determineParentId(props);\n\n    // Create the AZAPI resource using the base class method\n    this.terraformResource = this.createAzapiResource(\n      resourceBody,\n      parentId,\n      this.name,\n      this.location,\n    );\n  }\n\n  /**\n   * Determines the parent ID for the resource\n   */\n  private _determineParentId(props: any): string {\n    // This is a simplified implementation - real implementation would be\n    // resource-type specific and could be made abstract or configurable\n\n    // For resource groups, parent is subscription\n    if (this.resourceType() === \"Microsoft.Resources/resourceGroups\") {\n      // Use AZAPI client config to get subscription ID\n      const clientConfig = new DataAzapiClientConfig(this, \"client_config\", {});\n      return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n    }\n\n    // For other resources, parent might be resource group\n    if (props.resourceGroupId) {\n      return props.resourceGroupId;\n    }\n\n    // Default to subscription\n    const clientConfig = new DataAzapiClientConfig(\n      this,\n      \"client_config_default\",\n      {},\n    );\n    return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n  }\n\n  /**\n   * Logs framework messages including warnings and migration guidance\n   */\n  private _logFrameworkMessages(): void {\n    // ANSI color codes for terminal output\n    const RED = \"\\x1b[31m\";\n    const YELLOW = \"\\x1b[33m\";\n    const RESET = \"\\x1b[0m\";\n    const BOLD = \"\\x1b[1m\";\n\n    // Log deprecation warnings\n    if (this.versionConfig.supportLevel === VersionSupportLevel.DEPRECATED) {\n      console.warn(\n        `${YELLOW}⚠️  API version ${this.resolvedApiVersion} for ${this.resourceType()} is deprecated. ` +\n          `Consider upgrading to the latest version: ${this.latestVersion()}${RESET}`,\n      );\n    }\n\n    if (this.versionConfig.supportLevel === VersionSupportLevel.SUNSET) {\n      console.error(\n        `${RED}${BOLD}🚨 API version ${this.resolvedApiVersion} for ${this.resourceType()} has reached sunset. ` +\n          `Immediate migration to ${this.latestVersion()} is required.${RESET}`,\n      );\n    }\n\n    // Log migration analysis results\n    if (this.migrationAnalysis && !this.migrationAnalysis.compatible) {\n      console.warn(\n        `${YELLOW}Migration from ${this.migrationAnalysis.fromVersion} to ${this.migrationAnalysis.toVersion} ` +\n          `has ${this.migrationAnalysis.breakingChanges.length} breaking changes. ` +\n          `Estimated effort: ${this.migrationAnalysis.estimatedEffort}${RESET}`,\n      );\n    }\n\n    // Log validation warnings\n    if (this.validationResult?.warnings.length) {\n      this.validationResult.warnings.forEach((warning) => {\n        console.warn(\n          `${YELLOW}Property validation warning: ${warning}${RESET}`,\n        );\n      });\n    }\n  }\n\n  // =============================================================================\n  // RESOURCE MANAGEMENT METHODS (from AzapiResource)\n  // =============================================================================\n\n  /**\n   * Creates the underlying AZAPI Terraform resource using the generated provider classes\n   *\n   * @param properties - The properties object to send to the Azure API\n   * @param parentId - The parent resource ID (e.g., subscription or resource group)\n   * @param name - The name of the resource\n   * @param location - The location of the resource (optional, can be in properties)\n   * @returns The created AZAPI resource\n   */\n  protected createAzapiResource(\n    properties: Record<string, any>,\n    parentId: string,\n    name: string,\n    location?: string,\n  ): cdktf.TerraformResource {\n    // Build the configuration object for the generated AZAPI Resource class\n    const config: ResourceConfig = {\n      type: `${this._resourceType}@${this.apiVersion}`,\n      name: name,\n      parentId: parentId,\n      body: properties,\n      // Add location conditionally if provided and not already in properties\n      ...(location && !properties.location && { location: location }),\n    };\n\n    // Create and return the AZAPI resource using the generated provider class\n    return new Resource(this, \"resource\", config);\n  }\n\n  /**\n   * Creates an AZAPI data source for reading existing resources\n   *\n   * @param resourceId - The full resource ID\n   * @returns The created Terraform data source\n   */\n  protected createAzapiDataSource(\n    resourceId: string,\n  ): cdktf.TerraformDataSource {\n    const dataSource = new cdktf.TerraformDataSource(this, \"data\", {\n      terraformResourceType: \"azapi_resource\",\n      terraformGeneratorMetadata: {\n        providerName: \"azapi\",\n      },\n    });\n\n    dataSource.addOverride(\"type\", this._resourceType);\n    dataSource.addOverride(\"resource_id\", resourceId);\n\n    return dataSource;\n  }\n\n  /**\n   * Updates the resource with new properties\n   *\n   * @param properties - The new properties to apply\n   */\n  protected updateAzapiResource(properties: Record<string, any>): void {\n    if (this.terraformResource) {\n      this.terraformResource.addOverride(\"body\", properties);\n    }\n  }\n\n  /**\n   * Gets the full resource ID\n   */\n  public get resourceId(): string {\n    return this.terraformResource?.fqn || this.id;\n  }\n\n  /**\n   * Gets the resource as a Terraform output value\n   */\n  public get output(): cdktf.TerraformOutput {\n    return new cdktf.TerraformOutput(this, \"output\", {\n      value: this.terraformResource?.fqn,\n    });\n  }\n\n  /**\n   * Adds an access role assignment for a specified Azure AD object\n   *\n   * Note: This method creates role assignments using AZAPI instead of AzureRM provider.\n   *\n   * @param objectId - The unique identifier of the Azure AD object\n   * @param roleDefinitionName - The name of the Azure RBAC role to be assigned\n   */\n  public addAccess(objectId: string, roleDefinitionName: string): void {\n    new AzapiRoleAssignment(this, `rbac-${objectId}-${roleDefinitionName}`, {\n      objectId: objectId,\n      roleDefinitionName: roleDefinitionName,\n      scope: this.resourceId,\n    });\n  }\n\n  /**\n   * Adds diagnostic settings to this resource using AZAPI\n   *\n   * @param props - The diagnostic settings configuration\n   */\n  public addDiagnosticSettings(\n    props: AzapiDiagnosticSettingsProps,\n  ): AzapiDiagnosticSettings {\n    return new AzapiDiagnosticSettings(this, \"diagnostics\", {\n      ...props,\n      targetResourceId: this.resourceId,\n    });\n  }\n}\n\n// =============================================================================\n// HELPER CLASSES AND INTERFACES\n// =============================================================================\n\n/**\n * Properties for AZAPI role assignment\n */\nexport interface AzapiRoleAssignmentProps {\n  readonly objectId: string;\n  readonly roleDefinitionName: string;\n  readonly scope: string;\n}\n\n/**\n * AZAPI-based role assignment construct\n */\nexport class AzapiRoleAssignment extends Construct {\n  constructor(scope: Construct, id: string, props: AzapiRoleAssignmentProps) {\n    super(scope, id);\n\n    const properties = {\n      principalId: props.objectId,\n      roleDefinitionId: `[subscriptionResourceId('Microsoft.Authorization/roleDefinitions', roleDefinitionId('${props.roleDefinitionName}'))]`,\n      scope: props.scope,\n    };\n\n    const config: ResourceConfig = {\n      type: \"Microsoft.Authorization/roleAssignments\",\n      name: \"[guid()]\",\n      parentId: props.scope,\n      body: properties,\n    };\n\n    new Resource(this, \"role-assignment\", config);\n  }\n}\n\n/**\n * Properties for AZAPI diagnostic settings\n */\nexport interface AzapiDiagnosticSettingsProps {\n  readonly name?: string;\n  readonly logAnalyticsWorkspaceId?: string;\n  readonly eventhubAuthorizationRuleId?: string;\n  readonly eventhubName?: string;\n  readonly storageAccountId?: string;\n  readonly targetResourceId?: string;\n  readonly logs?: DiagnosticLogConfig[];\n  readonly metrics?: DiagnosticMetricConfig[];\n}\n\n/**\n * AZAPI-based diagnostic settings construct\n */\nexport class AzapiDiagnosticSettings extends Construct {\n  constructor(\n    scope: Construct,\n    id: string,\n    props: AzapiDiagnosticSettingsProps,\n  ) {\n    super(scope, id);\n\n    const properties: Record<string, any> = {};\n\n    if (props.logAnalyticsWorkspaceId) {\n      properties.workspaceId = props.logAnalyticsWorkspaceId;\n    }\n\n    if (props.eventhubAuthorizationRuleId) {\n      properties.eventHubAuthorizationRuleId =\n        props.eventhubAuthorizationRuleId;\n    }\n\n    if (props.eventhubName) {\n      properties.eventHubName = props.eventhubName;\n    }\n\n    if (props.storageAccountId) {\n      properties.storageAccountId = props.storageAccountId;\n    }\n\n    if (props.logs) {\n      properties.logs = props.logs;\n    }\n\n    if (props.metrics) {\n      properties.metrics = props.metrics;\n    }\n\n    const config: ResourceConfig = {\n      type: \"Microsoft.Insights/diagnosticSettings\",\n      name: props.name || \"diagnostics\",\n      parentId: props.targetResourceId || \"\",\n      body: properties,\n    };\n\n    new Resource(this, \"diagnostic-settings\", config);\n  }\n}\n"]}
504
+ AzapiRoleAssignment[_b] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiRoleAssignment", version: "1.2.0" };
505
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azapi-resource.js","sourceRoot":"","sources":["../../../../src/core-azure/lib/azapi/azapi-resource.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * AzapiResource - A unified framework for version-aware Azure resource management\n *\n * This abstract base class provides a self-contained unified framework approach\n * for Azure resource management with automatic version management, schema-driven\n * property transformation, and migration analysis capabilities.\n *\n * Key Features:\n * - Automatic latest version resolution when no version is specified\n * - Support for explicit version pinning for stability\n * - Schema-driven property transformation between versions\n * - Migration analysis and deprecation warnings\n * - Built-in role assignment and diagnostic settings support\n * - JSII-compliant design for multi-language support\n *\n * This class replaces the previous dual-class approach (AzapiResource + AzapiResource)\n * with a single, self-contained implementation that handles all resource management needs.\n *\n * @packageDocumentation\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { DataAzapiClientConfig } from \"./providers-azapi/data-azapi-client-config\";\nimport { Resource, ResourceConfig } from \"./providers-azapi/resource\";\nimport { SchemaMapper } from \"./schema-mapper/schema-mapper\";\n\n// Type-only imports to avoid circular dependencies\nimport type { ActionGroupProps } from \"../../../azure-actiongroup/lib/action-group\";\nimport type { ActivityLogAlertProps } from \"../../../azure-activitylogalert/lib/activity-log-alert\";\nimport type { DiagnosticSettingsProps } from \"../../../azure-diagnosticsettings/lib/diagnostic-settings\";\nimport type { MetricAlertProps } from \"../../../azure-metricalert/lib/metric-alert\";\nimport { ApiVersionManager } from \"../version-manager/api-version-manager\";\nimport {\n  ApiSchema,\n  VersionConfig,\n  ValidationResult,\n  MigrationAnalysis,\n  VersionSupportLevel,\n} from \"../version-manager/interfaces/version-interfaces\";\n\n/**\n * Retention policy configuration\n */\nexport interface RetentionPolicyConfig {\n  readonly enabled: boolean;\n  readonly days: number;\n}\n\n/**\n * Log configuration for diagnostic settings\n */\nexport interface DiagnosticLogConfig {\n  readonly category?: string;\n  readonly categoryGroup?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Metric configuration for diagnostic settings\n */\nexport interface DiagnosticMetricConfig {\n  /** Metric category name (used in newer API versions) */\n  readonly category?: string;\n  /** Time grain for metrics in ISO 8601 duration format (used in API version 2016-09-01, e.g., \"PT1M\") */\n  readonly timeGrain?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Monitoring configuration for Azure resources\n *\n * Provides integrated monitoring capabilities including diagnostic settings,\n * metric alerts, and activity log alerts. All monitoring is optional and\n * disabled by default.\n */\nexport interface MonitoringConfig {\n  /**\n   * Whether monitoring is enabled\n   * @defaultValue true\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * Diagnostic settings configuration\n   * Uses the full DiagnosticSettings construct for consistency\n   */\n  readonly diagnosticSettings?: DiagnosticSettingsProps;\n\n  /**\n   * Action groups to create for this resource\n   * Creates new ActionGroup instances as child constructs\n   */\n  readonly actionGroups?: ActionGroupProps[];\n\n  /**\n   * Metric alerts configuration\n   * Creates MetricAlert instances scoped to this resource\n   */\n  readonly metricAlerts?: MetricAlertProps[];\n\n  /**\n   * Activity log alerts configuration\n   * Creates ActivityLogAlert instances for this resource's operations\n   */\n  readonly activityLogAlerts?: ActivityLogAlertProps[];\n}\n\n/**\n * Properties for versioned Azure resources\n *\n * Combines base resource properties with version management capabilities\n * and advanced configuration options for the unified framework.\n */\nexport interface AzapiResourceProps {\n  /**\n   * The name of the resource\n   */\n  readonly name?: string;\n\n  /**\n   * The location where the resource should be created\n   */\n  readonly location?: string;\n\n  /**\n   * Tags to apply to the resource\n   */\n  readonly tags?: Record<string, string>;\n  /**\n   * Explicit API version to use for this resource\n   *\n   * If not specified, the latest active version will be automatically resolved.\n   * Use this for version pinning when stability is required over latest features.\n   *\n   * @example \"2024-11-01\"\n   * @defaultValue Latest active version from ApiVersionManager\n   */\n  readonly apiVersion?: string;\n\n  /**\n   * Whether to enable migration analysis warnings\n   *\n   * When true, the framework will analyze the current version for deprecation\n   * status and provide migration recommendations in the deployment output.\n   *\n   * @defaultValue true\n   */\n  readonly enableMigrationAnalysis?: boolean;\n\n  /**\n   * Whether to validate properties against the schema\n   *\n   * When true, all properties will be validated against the API schema before\n   * resource creation. Validation errors will cause deployment failures.\n   *\n   * @defaultValue true\n   */\n  readonly enableValidation?: boolean;\n\n  /**\n   * Whether to apply property transformations automatically\n   *\n   * When true, properties will be automatically transformed according to the\n   * target schema's transformation rules. This enables backward compatibility.\n   *\n   * @defaultValue true\n   */\n  readonly enableTransformation?: boolean;\n\n  /**\n   * Monitoring configuration for this resource\n   *\n   * Enables integrated monitoring with diagnostic settings, metric alerts,\n   * and activity log alerts. All monitoring is optional and disabled by default.\n   *\n   * @example\n   * monitoring: {\n   *   enabled: true,\n   *   diagnosticSettings: {\n   *     workspaceId: logAnalytics.id,\n   *     metrics: ['AllMetrics'],\n   *     logs: ['AuditLogs']\n   *   },\n   *   metricAlerts: [{\n   *     name: 'high-cpu-alert',\n   *     severity: 2,\n   *     scopes: [], // Automatically set to this resource\n   *     criteria: { ... },\n   *     actions: [{ actionGroupId: actionGroup.id }]\n   *   }]\n   * }\n   */\n  readonly monitoring?: MonitoringConfig;\n}\n\n/**\n * Abstract base class for version-aware Azure resource management\n *\n * AzapiResource provides a unified framework for creating Azure resources\n * with automatic version management, schema validation, property transformation,\n * and migration analysis. It extends the existing AzapiResource class while\n * maintaining full backward compatibility.\n *\n * This class implements the core framework that enables:\n * - Automatic resolution of the latest API version when none is specified\n * - Explicit version pinning for environments requiring stability\n * - Schema-driven property validation and transformation\n * - Migration analysis with breaking change detection\n * - Deprecation warnings and upgrade recommendations\n *\n * Subclasses must implement the abstract methods to provide resource-specific\n * configuration while the framework handles all version management complexity.\n *\n * @example Basic usage with automatic version resolution:\n * class MyResource extends AzapiResource {\n *   protected getDefaultVersion(): string {\n *     return \"2024-11-01\"; // fallback if no versions registered\n *   }\n *\n *   protected getResourceType(): string {\n *     return \"Microsoft.Resources/resourceGroups\";\n *   }\n *\n *   protected getApiSchema(): ApiSchema {\n *     return this.resolveSchema();\n *   }\n *\n *   protected createResourceBody(props: any): any {\n *     return { location: props.location, tags: props.tags || {} };\n *   }\n * }\n *\n * @example Usage with explicit version pinning:\n * new MyResource(this, \"resource\", {\n *   name: \"my-resource\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-01-01\" // Pin to specific version\n * });\n *\n * @stability stable\n */\nexport abstract class AzapiResource extends Construct {\n  /**\n   * The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   * @internal\n   */\n  protected readonly _resourceType: string;\n\n  /**\n   * The API version to use for this resource\n   */\n  protected readonly apiVersion: string;\n\n  /**\n   * The underlying AZAPI Terraform resource\n   */\n  protected terraformResource!: cdktf.TerraformResource;\n\n  /**\n   * The name of the resource\n   */\n  public readonly name: string;\n\n  /**\n   * The location of the resource\n   */\n  public readonly location: string;\n\n  /**\n   * The resource ID (abstract - must be implemented by subclasses)\n   */\n  public abstract readonly id: string;\n\n  /**\n   * The resolved API version being used for this resource instance\n   *\n   * This is the actual version that will be used for the Azure API call,\n   * either explicitly specified in props or automatically resolved to\n   * the latest active version.\n   */\n  public readonly resolvedApiVersion: string;\n\n  /**\n   * The API schema for the resolved version\n   *\n   * Contains the complete schema definition including properties, validation\n   * rules, and transformation mappings for the resolved API version.\n   */\n  public readonly schema: ApiSchema;\n\n  /**\n   * The version configuration for the resolved version\n   *\n   * Contains lifecycle information, breaking changes, and migration metadata\n   * for the resolved API version.\n   */\n  public readonly versionConfig: VersionConfig;\n\n  /**\n   * Validation results for the resource properties\n   *\n   * Available after construction if validation is enabled. Contains detailed\n   * information about any validation errors or warnings.\n   */\n  public readonly validationResult?: ValidationResult;\n\n  /**\n   * Migration analysis results\n   *\n   * Available after construction if migration analysis is enabled and a\n   * previous version can be determined for comparison.\n   */\n  public readonly migrationAnalysis?: MigrationAnalysis;\n\n  // Framework components\n  private readonly _apiVersionManager: ApiVersionManager;\n  private readonly _schemaMapper: SchemaMapper;\n\n  // Monitoring resources (protected for subclass access)\n  protected readonly monitoringActionGroups: Construct[] = [];\n  protected readonly monitoringMetricAlerts: Construct[] = [];\n  protected readonly monitoringActivityLogAlerts: Construct[] = [];\n\n  /**\n   * Creates a new AzapiResource instance\n   *\n   * The constructor handles all framework initialization including version resolution,\n   * schema loading, property validation, transformation, and migration analysis.\n   * It maintains full backward compatibility with the AzapiResource constructor.\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 resource\n   */\n  constructor(scope: Construct, id: string, props: AzapiResourceProps = {}) {\n    // Initialize the base Construct\n    super(scope, id);\n\n    // Initialize basic properties\n    this.name = props.name || this.node.id;\n    this.location = props.location || \"eastus\";\n\n    // Initialize the API version manager\n    this._apiVersionManager = ApiVersionManager.instance();\n\n    // Step 1: Resolve the API version to use\n    this.resolvedApiVersion = this._resolveApiVersion(props.apiVersion);\n\n    // Step 2: Set required abstract properties for AzapiResource\n    this._resourceType = this.resourceType();\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 3: Load the schema and version configuration\n    this.schema = this.apiSchema();\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this._resourceType,\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Version configuration not found for ${this.resourceType()}@${this.resolvedApiVersion}. ` +\n          `Please ensure the version is registered with the ApiVersionManager.`,\n      );\n    }\n    this.versionConfig = versionConfig;\n\n    // Step 4: Initialize the schema mapper\n    this._schemaMapper = SchemaMapper.create(this.schema);\n\n    // Step 5: Process properties through the framework pipeline\n    const processedProps = this._processProperties(props);\n\n    // Step 6: Perform validation if enabled\n    if (props.enableValidation !== false) {\n      this.validationResult = this._validateProperties(processedProps);\n      if (!this.validationResult.valid) {\n        throw new Error(\n          `Property validation failed for ${this.resourceType}:\\n` +\n            this.validationResult.errors.join(\"\\n\"),\n        );\n      }\n    }\n\n    // Step 7: Perform migration analysis if enabled\n    if (props.enableMigrationAnalysis !== false) {\n      this.migrationAnalysis = this._performMigrationAnalysis();\n    }\n\n    // Step 8: Create the Azure resource\n    this._createAzureResource(processedProps);\n\n    // Step 9: Create monitoring resources if configured\n    // Note: Monitoring resources are created lazily to avoid circular dependencies\n    if (props.monitoring) {\n      void this.createMonitoringResources(props.monitoring);\n    }\n\n    // Step 10: Log warnings and migration guidance\n    this._logFrameworkMessages();\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   *\n   * This method should return a sensible default version that can be used\n   * as a fallback if the ApiVersionManager doesn't have any versions registered\n   * for this resource type.\n   *\n   * @returns The default API version string (e.g., \"2024-11-01\")\n   */\n  protected abstract defaultVersion(): string;\n\n  /**\n   * Gets the Azure resource type for this resource\n   *\n   * This method should return the full Azure resource type identifier that\n   * will be used for API calls and version management.\n   *\n   * @returns The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   */\n  protected abstract resourceType(): string;\n\n  /**\n   * Gets the API schema for the resolved version\n   *\n   * This method should return the complete API schema for the resolved version,\n   * including all property definitions, validation rules, and transformation\n   * mappings. Use the resolveSchema() helper method for standard schema resolution.\n   *\n   * @returns The API schema for the resolved version\n   */\n  protected abstract apiSchema(): ApiSchema;\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * This method should transform the input properties into the JSON body format\n   * expected by the Azure REST API for the resolved version. The framework will\n   * have already applied any necessary property transformations and validation.\n   *\n   * @param props - The processed and validated properties for the resource\n   * @returns The resource body object to send to Azure API\n   */\n  protected abstract createResourceBody(props: any): any;\n\n  /**\n   * Helper method for standard schema resolution\n   *\n   * Subclasses can use this method to resolve the schema for the current version\n   * from the ApiVersionManager. This provides a standard implementation that\n   * most resources can use without custom logic.\n   *\n   * @returns The API schema for the resolved version\n   * @throws Error if the schema cannot be resolved\n   */\n  protected resolveSchema(): ApiSchema {\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this.resourceType(),\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Cannot resolve schema: version configuration not found for ` +\n          `${this.resourceType()}@${this.resolvedApiVersion}`,\n      );\n    }\n\n    return versionConfig.schema;\n  }\n\n  /**\n   * Gets the latest available version for this resource type\n   *\n   * This method provides access to the latest version resolution logic\n   * for use in subclasses or external tooling.\n   *\n   * @returns The latest available version, or undefined if none found\n   */\n  public latestVersion(): string | undefined {\n    return this._apiVersionManager.latestVersion(this.resourceType());\n  }\n\n  /**\n   * Gets all supported versions for this resource type\n   *\n   * This method provides access to the version registry for use in\n   * subclasses or external tooling.\n   *\n   * @returns Array of supported version strings, sorted by release date\n   */\n  public supportedVersions(): string[] {\n    return this._apiVersionManager.supportedVersions(this.resourceType());\n  }\n\n  /**\n   * Analyzes migration from current version to a target version\n   *\n   * This method enables external tools to analyze migration requirements\n   * between versions for planning and automation purposes.\n   *\n   * @param targetVersion - The target version to analyze migration to\n   * @returns Detailed migration analysis results\n   */\n  public analyzeMigrationTo(targetVersion: string): MigrationAnalysis {\n    return this._apiVersionManager.analyzeMigration(\n      this.resourceType(),\n      this.resolvedApiVersion,\n      targetVersion,\n    );\n  }\n\n  // =============================================================================\n  // PRIVATE IMPLEMENTATION METHODS\n  // =============================================================================\n\n  /**\n   * Resolves the API version to use for this resource instance\n   */\n  private _resolveApiVersion(explicitVersion?: string): string {\n    if (explicitVersion) {\n      // Validate that the explicit version is supported\n      if (\n        !this._apiVersionManager.validateVersionSupport(\n          this.resourceType(),\n          explicitVersion,\n        )\n      ) {\n        const supportedVersions = this._apiVersionManager.supportedVersions(\n          this.resourceType(),\n        );\n        throw new Error(\n          `Unsupported API version '${explicitVersion}' for resource type '${this.resourceType()}'. ` +\n            `Supported versions: ${supportedVersions.join(\", \")}`,\n        );\n      }\n      return explicitVersion;\n    }\n\n    // Try to get the latest version from the manager\n    const latestVersion = this._apiVersionManager.latestVersion(\n      this.resourceType(),\n    );\n    if (latestVersion) {\n      return latestVersion;\n    }\n\n    // Fall back to the default version\n    const defaultVersion = this.defaultVersion();\n\n    // Warn that we're using the default version\n    console.warn(\n      `No versions registered for ${this.resourceType()}. ` +\n        `Using default version: ${defaultVersion}. ` +\n        `Consider registering versions with ApiVersionManager for better version management.`,\n    );\n\n    return defaultVersion;\n  }\n\n  /**\n   * Processes properties through the framework pipeline\n   */\n  private _processProperties(props: AzapiResourceProps): any {\n    let processedProps = { ...props };\n\n    // Apply default values from the schema\n    processedProps = this._schemaMapper.applyDefaults(processedProps);\n\n    // Apply property transformations if enabled\n    if (props.enableTransformation !== false) {\n      // For transformation, we would need a source schema, but since we're not\n      // migrating from a different version in this context, we'll skip transformation\n      // This would be used when upgrading from one version to another\n    }\n\n    return processedProps;\n  }\n\n  /**\n   * Validates properties against the schema\n   */\n  private _validateProperties(props: any): ValidationResult {\n    return this._schemaMapper.validateProperties(props);\n  }\n\n  /**\n   * Performs migration analysis for the current version\n   */\n  private _performMigrationAnalysis(): MigrationAnalysis | undefined {\n    // Check if the current version is deprecated\n    if (\n      this.versionConfig.supportLevel === VersionSupportLevel.DEPRECATED ||\n      this.versionConfig.supportLevel === VersionSupportLevel.SUNSET\n    ) {\n      const latestVersion = this.latestVersion();\n      if (latestVersion && latestVersion !== this.resolvedApiVersion) {\n        return this._apiVersionManager.analyzeMigration(\n          this.resourceType(),\n          this.resolvedApiVersion,\n          latestVersion,\n        );\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Creates the underlying Azure resource\n   */\n  private _createAzureResource(props: any): void {\n    // Create the resource body using the subclass implementation\n    const resourceBody = this.createResourceBody(props);\n\n    // Determine the parent ID using the overrideable method\n    const parentId = this.resolveParentId(props);\n\n    // Create the AZAPI resource using the base class method\n    this.terraformResource = this.createAzapiResource(\n      resourceBody,\n      parentId,\n      this.name,\n      this.location,\n    );\n  }\n\n  /**\n   * Resolves the parent resource ID for this resource.\n   *\n   * Override this method in child resource classes (like Subnet) that need\n   * custom parent ID resolution logic. By default, this delegates to the\n   * private _determineParentId method which handles standard resource types.\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID\n   */\n  protected resolveParentId(props: any): string {\n    return this._determineParentId(props);\n  }\n\n  /**\n   * Determines the parent ID for the resource (internal implementation)\n   *\n   * This method provides the default parent ID resolution logic for most resources.\n   * Child resources should override resolveParentId() instead of this method.\n   */\n  private _determineParentId(props: any): string {\n    // This is a simplified implementation - real implementation would be\n    // resource-type specific and could be made abstract or configurable\n\n    // For resource groups, parent is subscription\n    if (this.resourceType() === \"Microsoft.Resources/resourceGroups\") {\n      // Use AZAPI client config to get subscription ID\n      const clientConfig = new DataAzapiClientConfig(this, \"client_config\", {});\n      return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n    }\n\n    // For other resources, parent might be resource group\n    if (props.resourceGroupId) {\n      return props.resourceGroupId;\n    }\n\n    // Default to subscription\n    const clientConfig = new DataAzapiClientConfig(\n      this,\n      \"client_config_default\",\n      {},\n    );\n    return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n  }\n\n  /**\n   * Logs framework messages including warnings and migration guidance\n   */\n  private _logFrameworkMessages(): void {\n    // ANSI color codes for terminal output\n    const RED = \"\\x1b[31m\";\n    const YELLOW = \"\\x1b[33m\";\n    const RESET = \"\\x1b[0m\";\n    const BOLD = \"\\x1b[1m\";\n\n    // Log deprecation warnings\n    if (this.versionConfig.supportLevel === VersionSupportLevel.DEPRECATED) {\n      console.warn(\n        `${YELLOW}⚠️  API version ${this.resolvedApiVersion} for ${this.resourceType()} is deprecated. ` +\n          `Consider upgrading to the latest version: ${this.latestVersion()}${RESET}`,\n      );\n    }\n\n    if (this.versionConfig.supportLevel === VersionSupportLevel.SUNSET) {\n      console.error(\n        `${RED}${BOLD}🚨 API version ${this.resolvedApiVersion} for ${this.resourceType()} has reached sunset. ` +\n          `Immediate migration to ${this.latestVersion()} is required.${RESET}`,\n      );\n    }\n\n    // Log migration analysis results\n    if (this.migrationAnalysis && !this.migrationAnalysis.compatible) {\n      console.warn(\n        `${YELLOW}Migration from ${this.migrationAnalysis.fromVersion} to ${this.migrationAnalysis.toVersion} ` +\n          `has ${this.migrationAnalysis.breakingChanges.length} breaking changes. ` +\n          `Estimated effort: ${this.migrationAnalysis.estimatedEffort}${RESET}`,\n      );\n    }\n\n    // Log validation warnings\n    if (this.validationResult?.warnings.length) {\n      this.validationResult.warnings.forEach((warning) => {\n        console.warn(\n          `${YELLOW}Property validation warning: ${warning}${RESET}`,\n        );\n      });\n    }\n  }\n\n  // =============================================================================\n  // MONITORING INTEGRATION METHODS\n  // =============================================================================\n\n  /**\n   * Creates monitoring resources based on the monitoring configuration\n   *\n   * This method is called automatically during construction if monitoring is configured.\n   * It creates action groups, metric alerts, and activity log alerts as child constructs.\n   *\n   * Protected to allow subclasses to override or extend monitoring behavior.\n   *\n   * @param config - The monitoring configuration from props\n   */\n  protected async createMonitoringResources(\n    config: MonitoringConfig,\n  ): Promise<void> {\n    // Skip if monitoring is explicitly disabled\n    if (config.enabled === false) {\n      return;\n    }\n\n    // Create diagnostic settings using dynamic import to avoid circular dependency\n    if (config.diagnosticSettings) {\n      const { DiagnosticSettings } = await import(\n        \"../../../azure-diagnosticsettings/lib/diagnostic-settings\"\n      );\n      new DiagnosticSettings(this, \"monitoring-diagnostic-settings\", {\n        ...config.diagnosticSettings,\n        targetResourceId: this.resourceId,\n      });\n    }\n\n    // Create action groups using dynamic import\n    if (config.actionGroups && config.actionGroups.length > 0) {\n      const { ActionGroup } = await import(\n        \"../../../azure-actiongroup/lib/action-group\"\n      );\n      config.actionGroups.forEach((actionGroupProps, index) => {\n        const actionGroup = new ActionGroup(\n          this,\n          `monitoring-action-group-${index}`,\n          actionGroupProps,\n        );\n        this.monitoringActionGroups.push(actionGroup);\n      });\n    }\n\n    // Create metric alerts using dynamic import\n    if (config.metricAlerts && config.metricAlerts.length > 0) {\n      const { MetricAlert } = await import(\n        \"../../../azure-metricalert/lib/metric-alert\"\n      );\n      config.metricAlerts.forEach((metricAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: MetricAlertProps = {\n          ...metricAlertProps,\n          scopes: metricAlertProps.scopes || [this.resourceId],\n        };\n\n        const metricAlert = new MetricAlert(\n          this,\n          `monitoring-metric-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringMetricAlerts.push(metricAlert);\n      });\n    }\n\n    // Create activity log alerts using dynamic import\n    if (config.activityLogAlerts && config.activityLogAlerts.length > 0) {\n      const { ActivityLogAlert } = await import(\n        \"../../../azure-activitylogalert/lib/activity-log-alert\"\n      );\n      config.activityLogAlerts.forEach((activityLogAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: ActivityLogAlertProps = {\n          ...activityLogAlertProps,\n          scopes: activityLogAlertProps.scopes || [this.resourceId],\n        };\n\n        const activityLogAlert = new ActivityLogAlert(\n          this,\n          `monitoring-activity-log-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringActivityLogAlerts.push(activityLogAlert);\n      });\n    }\n  }\n\n  // =============================================================================\n  // RESOURCE MANAGEMENT METHODS (from AzapiResource)\n  // =============================================================================\n\n  /**\n   * Creates the underlying AZAPI Terraform resource using the generated provider classes\n   *\n   * @param properties - The properties object to send to the Azure API\n   * @param parentId - The parent resource ID (e.g., subscription or resource group)\n   * @param name - The name of the resource\n   * @param location - The location of the resource (optional, can be in properties)\n   * @returns The created AZAPI resource\n   */\n  protected createAzapiResource(\n    properties: Record<string, any>,\n    parentId: string,\n    name: string,\n    location?: string,\n  ): cdktf.TerraformResource {\n    // Build the configuration object for the generated AZAPI Resource class\n    const config: ResourceConfig = {\n      type: `${this._resourceType}@${this.apiVersion}`,\n      name: name,\n      parentId: parentId,\n      body: properties,\n      // Add location conditionally if provided and not already in properties\n      ...(location && !properties.location && { location: location }),\n    };\n\n    // Create and return the AZAPI resource using the generated provider class\n    return new Resource(this, \"resource\", config);\n  }\n\n  /**\n   * Creates an AZAPI data source for reading existing resources\n   *\n   * @param resourceId - The full resource ID\n   * @returns The created Terraform data source\n   */\n  protected createAzapiDataSource(\n    resourceId: string,\n  ): cdktf.TerraformDataSource {\n    const dataSource = new cdktf.TerraformDataSource(this, \"data\", {\n      terraformResourceType: \"azapi_resource\",\n      terraformGeneratorMetadata: {\n        providerName: \"azapi\",\n      },\n    });\n\n    dataSource.addOverride(\"type\", this._resourceType);\n    dataSource.addOverride(\"resource_id\", resourceId);\n\n    return dataSource;\n  }\n\n  /**\n   * Updates the resource with new properties\n   *\n   * @param properties - The new properties to apply\n   */\n  protected updateAzapiResource(properties: Record<string, any>): void {\n    if (this.terraformResource) {\n      this.terraformResource.addOverride(\"body\", properties);\n    }\n  }\n\n  /**\n   * Gets the full resource ID\n   */\n  public get resourceId(): string {\n    return this.terraformResource?.fqn || this.id;\n  }\n\n  /**\n   * Gets the resource as a Terraform output value\n   */\n  public get output(): cdktf.TerraformOutput {\n    return new cdktf.TerraformOutput(this, \"output\", {\n      value: this.terraformResource?.fqn,\n    });\n  }\n\n  /**\n   * Adds an access role assignment for a specified Azure AD object\n   *\n   * Note: This method creates role assignments using AZAPI instead of AzureRM provider.\n   *\n   * @param objectId - The unique identifier of the Azure AD object\n   * @param roleDefinitionName - The name of the Azure RBAC role to be assigned\n   */\n  public addAccess(objectId: string, roleDefinitionName: string): void {\n    new AzapiRoleAssignment(this, `rbac-${objectId}-${roleDefinitionName}`, {\n      objectId: objectId,\n      roleDefinitionName: roleDefinitionName,\n      scope: this.resourceId,\n    });\n  }\n}\n\n// =============================================================================\n// HELPER CLASSES AND INTERFACES\n// =============================================================================\n\n/**\n * Properties for AZAPI role assignment\n */\nexport interface AzapiRoleAssignmentProps {\n  readonly objectId: string;\n  readonly roleDefinitionName: string;\n  readonly scope: string;\n}\n\n/**\n * AZAPI-based role assignment construct\n */\nexport class AzapiRoleAssignment extends Construct {\n  constructor(scope: Construct, id: string, props: AzapiRoleAssignmentProps) {\n    super(scope, id);\n\n    const properties = {\n      principalId: props.objectId,\n      roleDefinitionId: `[subscriptionResourceId('Microsoft.Authorization/roleDefinitions', roleDefinitionId('${props.roleDefinitionName}'))]`,\n      scope: props.scope,\n    };\n\n    const config: ResourceConfig = {\n      type: \"Microsoft.Authorization/roleAssignments\",\n      name: \"[guid()]\",\n      parentId: props.scope,\n      body: properties,\n    };\n    new Resource(this, \"role-assignment\", config);\n  }\n}\n"]}