@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
@@ -0,0 +1,462 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.VirtualMachine = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure Virtual Machine implementation using VersionedAzapiResource framework
8
+ *
9
+ * This class provides a single, version-aware implementation for Azure Virtual Machines
10
+ * that automatically handles version management, schema validation, and property transformation
11
+ * across all supported API versions.
12
+ *
13
+ * Supported API Versions:
14
+ * - 2024-07-01 (Active)
15
+ * - 2024-11-01 (Active)
16
+ * - 2025-04-01 (Active, Latest)
17
+ *
18
+ * Features:
19
+ * - Automatic latest version resolution when no version is specified
20
+ * - Explicit version pinning for stability requirements
21
+ * - Schema-driven validation and transformation
22
+ * - Full JSII compliance for multi-language support
23
+ * - Comprehensive support for VM features (networking, storage, identity, etc.)
24
+ */
25
+ const cdktf = require("cdktf");
26
+ const virtual_machine_schemas_1 = require("./virtual-machine-schemas");
27
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
28
+ const api_version_manager_1 = require("../../core-azure/lib/version-manager/api-version-manager");
29
+ /**
30
+ * Unified Azure Virtual Machine implementation
31
+ *
32
+ * This class provides a single, version-aware implementation that automatically handles version
33
+ * resolution, schema validation, and property transformation while maintaining full JSII compliance.
34
+ *
35
+ * The class uses the VersionedAzapiResource framework to provide:
36
+ * - Automatic latest version resolution (2025-04-01 as of this implementation)
37
+ * - Support for explicit version pinning when stability is required
38
+ * - Schema-driven property validation and transformation
39
+ * - Migration analysis and deprecation warnings
40
+ * - Full JSII compliance for multi-language support
41
+ *
42
+ * @example
43
+ * // Basic Linux VM with SSH authentication:
44
+ * const vm = new VirtualMachine(this, "vm", {
45
+ * name: "my-linux-vm",
46
+ * location: "eastus",
47
+ * resourceGroupId: resourceGroup.id,
48
+ * hardwareProfile: {
49
+ * vmSize: "Standard_D2s_v3"
50
+ * },
51
+ * storageProfile: {
52
+ * imageReference: {
53
+ * publisher: "Canonical",
54
+ * offer: "0001-com-ubuntu-server-jammy",
55
+ * sku: "22_04-lts-gen2",
56
+ * version: "latest"
57
+ * },
58
+ * osDisk: {
59
+ * createOption: "FromImage",
60
+ * managedDisk: {
61
+ * storageAccountType: "Premium_LRS"
62
+ * }
63
+ * }
64
+ * },
65
+ * osProfile: {
66
+ * computerName: "myvm",
67
+ * adminUsername: "azureuser",
68
+ * linuxConfiguration: {
69
+ * disablePasswordAuthentication: true,
70
+ * ssh: {
71
+ * publicKeys: [{
72
+ * path: "/home/azureuser/.ssh/authorized_keys",
73
+ * keyData: "ssh-rsa AAAA..."
74
+ * }]
75
+ * }
76
+ * }
77
+ * },
78
+ * networkProfile: {
79
+ * networkInterfaces: [{
80
+ * id: networkInterface.id
81
+ * }]
82
+ * },
83
+ * identity: {
84
+ * type: "SystemAssigned"
85
+ * }
86
+ * });
87
+ *
88
+ * @example
89
+ * // Windows VM with password authentication:
90
+ * const windowsVm = new VirtualMachine(this, "windows-vm", {
91
+ * name: "my-windows-vm",
92
+ * location: "eastus",
93
+ * resourceGroupId: resourceGroup.id,
94
+ * hardwareProfile: {
95
+ * vmSize: "Standard_D2s_v3"
96
+ * },
97
+ * storageProfile: {
98
+ * imageReference: {
99
+ * publisher: "MicrosoftWindowsServer",
100
+ * offer: "WindowsServer",
101
+ * sku: "2022-datacenter-azure-edition",
102
+ * version: "latest"
103
+ * },
104
+ * osDisk: {
105
+ * createOption: "FromImage",
106
+ * managedDisk: {
107
+ * storageAccountType: "Premium_LRS"
108
+ * }
109
+ * }
110
+ * },
111
+ * osProfile: {
112
+ * computerName: "mywinvm",
113
+ * adminUsername: "azureuser",
114
+ * adminPassword: "P@ssw0rd1234!",
115
+ * windowsConfiguration: {
116
+ * provisionVMAgent: true,
117
+ * enableAutomaticUpdates: true
118
+ * }
119
+ * },
120
+ * networkProfile: {
121
+ * networkInterfaces: [{
122
+ * id: networkInterface.id
123
+ * }]
124
+ * },
125
+ * licenseType: "Windows_Server"
126
+ * });
127
+ *
128
+ * @stability stable
129
+ */
130
+ class VirtualMachine extends azapi_resource_1.AzapiResource {
131
+ /**
132
+ * Returns a production-ready monitoring configuration for Virtual Machines
133
+ *
134
+ * This static factory method provides a complete MonitoringConfig with sensible defaults
135
+ * for VM monitoring including CPU, memory, disk queue alerts, and deletion tracking.
136
+ *
137
+ * @param actionGroupId - The resource ID of the action group for alert notifications
138
+ * @param workspaceId - Optional Log Analytics workspace ID for diagnostic settings
139
+ * @param options - Optional configuration to customize thresholds and enable/disable specific alerts
140
+ * @returns A complete MonitoringConfig object ready to use in VirtualMachine props
141
+ *
142
+ * @example
143
+ * // Basic usage with all defaults
144
+ * const vm = new VirtualMachine(this, "vm", {
145
+ * // ... other properties ...
146
+ * monitoring: VirtualMachine.defaultMonitoring(actionGroup.id, workspace.id)
147
+ * });
148
+ *
149
+ * @example
150
+ * // Custom thresholds
151
+ * const vm = new VirtualMachine(this, "vm", {
152
+ * // ... other properties ...
153
+ * monitoring: VirtualMachine.defaultMonitoring(
154
+ * actionGroup.id,
155
+ * workspace.id,
156
+ * {
157
+ * cpuThreshold: 90,
158
+ * memoryThreshold: 536870912, // 512MB
159
+ * enableDiskQueueAlert: false
160
+ * }
161
+ * )
162
+ * });
163
+ */
164
+ static defaultMonitoring(actionGroupId, workspaceId, options) {
165
+ const metricAlerts = [];
166
+ // High CPU Alert
167
+ if (options?.enableCpuAlert !== false) {
168
+ metricAlerts.push({
169
+ name: "high-cpu-alert",
170
+ description: "Alert when CPU usage exceeds threshold",
171
+ severity: (options?.cpuAlertSeverity ?? 2),
172
+ scopes: [], // Will be set automatically by base class
173
+ evaluationFrequency: "PT5M",
174
+ windowSize: "PT15M",
175
+ criteria: {
176
+ type: "StaticThreshold",
177
+ metricName: "Percentage CPU",
178
+ metricNamespace: "Microsoft.Compute/virtualMachines",
179
+ operator: "GreaterThan",
180
+ threshold: options?.cpuThreshold ?? 80,
181
+ timeAggregation: "Average",
182
+ },
183
+ actions: [{ actionGroupId }],
184
+ });
185
+ }
186
+ // Low Memory Alert
187
+ if (options?.enableMemoryAlert !== false) {
188
+ metricAlerts.push({
189
+ name: "low-memory-alert",
190
+ description: "Alert when available memory falls below threshold",
191
+ severity: (options?.memoryAlertSeverity ?? 2),
192
+ scopes: [], // Will be set automatically by base class
193
+ evaluationFrequency: "PT5M",
194
+ windowSize: "PT15M",
195
+ criteria: {
196
+ type: "StaticThreshold",
197
+ metricName: "Available Memory Bytes",
198
+ metricNamespace: "Microsoft.Compute/virtualMachines",
199
+ operator: "LessThan",
200
+ threshold: options?.memoryThreshold ?? 1073741824,
201
+ timeAggregation: "Average",
202
+ },
203
+ actions: [{ actionGroupId }],
204
+ });
205
+ }
206
+ // High Disk Queue Alert
207
+ if (options?.enableDiskQueueAlert !== false) {
208
+ metricAlerts.push({
209
+ name: "high-disk-queue-alert",
210
+ description: "Alert when disk queue depth exceeds threshold",
211
+ severity: (options?.diskQueueAlertSeverity ?? 2),
212
+ scopes: [], // Will be set automatically by base class
213
+ evaluationFrequency: "PT5M",
214
+ windowSize: "PT15M",
215
+ criteria: {
216
+ type: "StaticThreshold",
217
+ metricName: "OS Disk Queue Depth",
218
+ metricNamespace: "Microsoft.Compute/virtualMachines",
219
+ operator: "GreaterThan",
220
+ threshold: options?.diskQueueThreshold ?? 32,
221
+ timeAggregation: "Average",
222
+ },
223
+ actions: [{ actionGroupId }],
224
+ });
225
+ }
226
+ // Build diagnostic settings if workspace ID is provided
227
+ const diagnosticSettings = workspaceId
228
+ ? {
229
+ name: "vm-diagnostics",
230
+ targetResourceId: "", // Will be set automatically by base class
231
+ workspaceId: workspaceId,
232
+ logs: [{ categoryGroup: "allLogs", enabled: true }],
233
+ metrics: [{ category: "AllMetrics", enabled: true }],
234
+ }
235
+ : undefined;
236
+ // Build activity log alerts
237
+ const activityLogAlerts = options?.enableDeletionAlert !== false
238
+ ? [
239
+ {
240
+ name: "vm-deletion-alert",
241
+ description: "Alert when virtual machine is deleted",
242
+ scopes: [], // Will be set automatically by base class
243
+ condition: {
244
+ allOf: [
245
+ {
246
+ field: "operationName",
247
+ equalsValue: "Microsoft.Compute/virtualMachines/delete",
248
+ },
249
+ ],
250
+ },
251
+ actions: {
252
+ actionGroups: [{ actionGroupId }],
253
+ },
254
+ },
255
+ ]
256
+ : undefined;
257
+ // Return complete config object
258
+ return {
259
+ enabled: true,
260
+ diagnosticSettings: diagnosticSettings,
261
+ metricAlerts: metricAlerts,
262
+ activityLogAlerts: activityLogAlerts,
263
+ };
264
+ }
265
+ /**
266
+ * Ensures that Virtual Machine schemas are registered with the ApiVersionManager
267
+ * This is called once during the first VirtualMachine instantiation
268
+ */
269
+ static ensureSchemasRegistered() {
270
+ if (VirtualMachine.schemasRegistered) {
271
+ return;
272
+ }
273
+ const apiVersionManager = api_version_manager_1.ApiVersionManager.instance();
274
+ try {
275
+ // Register all Virtual Machine versions
276
+ apiVersionManager.registerResourceType(virtual_machine_schemas_1.VIRTUAL_MACHINE_TYPE, virtual_machine_schemas_1.ALL_VIRTUAL_MACHINE_VERSIONS);
277
+ VirtualMachine.schemasRegistered = true;
278
+ console.log(`Registered ${virtual_machine_schemas_1.ALL_VIRTUAL_MACHINE_VERSIONS.length} API versions for ${virtual_machine_schemas_1.VIRTUAL_MACHINE_TYPE}`);
279
+ }
280
+ catch (error) {
281
+ console.warn(`Failed to register Virtual Machine schemas: ${error}. ` +
282
+ `This may indicate the schemas are already registered or there's a configuration issue.`);
283
+ // Don't throw here as the schemas might already be registered
284
+ VirtualMachine.schemasRegistered = true;
285
+ }
286
+ }
287
+ /**
288
+ * Creates a new Azure Virtual Machine using the VersionedAzapiResource framework
289
+ *
290
+ * The constructor automatically handles version resolution, schema registration,
291
+ * validation, and resource creation.
292
+ *
293
+ * @param scope - The scope in which to define this construct
294
+ * @param id - The unique identifier for this instance
295
+ * @param props - Configuration properties for the Virtual Machine
296
+ */
297
+ constructor(scope, id, props) {
298
+ // Ensure schemas are registered before calling super
299
+ VirtualMachine.ensureSchemasRegistered();
300
+ // Call the parent constructor with the props
301
+ super(scope, id, props);
302
+ this.props = props;
303
+ // Extract properties from the AZAPI resource outputs using Terraform interpolation
304
+ this.id = `\${${this.terraformResource.fqn}.id}`;
305
+ this.tags = props.tags || {};
306
+ // Create Terraform outputs for easy access and referencing from other resources
307
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
308
+ value: this.id,
309
+ description: "The ID of the Virtual Machine",
310
+ });
311
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
312
+ value: `\${${this.terraformResource.fqn}.location}`,
313
+ description: "The location of the Virtual Machine",
314
+ });
315
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
316
+ value: `\${${this.terraformResource.fqn}.name}`,
317
+ description: "The name of the Virtual Machine",
318
+ });
319
+ this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
320
+ value: `\${${this.terraformResource.fqn}.tags}`,
321
+ description: "The tags assigned to the Virtual Machine",
322
+ });
323
+ this.vmIdOutput = new cdktf.TerraformOutput(this, "vmId", {
324
+ value: `\${${this.terraformResource.fqn}.output.properties.vmId}`,
325
+ description: "The unique identifier of the Virtual Machine",
326
+ });
327
+ // Override logical IDs to match naming convention
328
+ this.idOutput.overrideLogicalId("id");
329
+ this.locationOutput.overrideLogicalId("location");
330
+ this.nameOutput.overrideLogicalId("name");
331
+ this.tagsOutput.overrideLogicalId("tags");
332
+ this.vmIdOutput.overrideLogicalId("vmId");
333
+ // Apply ignore changes if specified
334
+ this._applyIgnoreChanges();
335
+ }
336
+ // =============================================================================
337
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
338
+ // =============================================================================
339
+ /**
340
+ * Gets the default API version to use when no explicit version is specified
341
+ * Returns the most recent stable version as the default
342
+ */
343
+ defaultVersion() {
344
+ return "2025-04-01";
345
+ }
346
+ /**
347
+ * Gets the Azure resource type for Virtual Machines
348
+ */
349
+ resourceType() {
350
+ return virtual_machine_schemas_1.VIRTUAL_MACHINE_TYPE;
351
+ }
352
+ /**
353
+ * Gets the API schema for the resolved version
354
+ * Uses the framework's schema resolution to get the appropriate schema
355
+ */
356
+ apiSchema() {
357
+ return this.resolveSchema();
358
+ }
359
+ /**
360
+ * Creates the resource body for the Azure API call
361
+ * Transforms the input properties into the JSON format expected by Azure REST API
362
+ */
363
+ createResourceBody(props) {
364
+ const typedProps = props;
365
+ return {
366
+ location: typedProps.location || "eastus",
367
+ tags: typedProps.tags || {},
368
+ identity: typedProps.identity,
369
+ zones: typedProps.zones,
370
+ plan: typedProps.plan,
371
+ properties: {
372
+ hardwareProfile: typedProps.hardwareProfile,
373
+ storageProfile: typedProps.storageProfile,
374
+ osProfile: typedProps.osProfile,
375
+ networkProfile: typedProps.networkProfile,
376
+ diagnosticsProfile: typedProps.diagnosticsProfile,
377
+ availabilitySet: typedProps.availabilitySet,
378
+ virtualMachineScaleSet: typedProps.virtualMachineScaleSet,
379
+ proximityPlacementGroup: typedProps.proximityPlacementGroup,
380
+ priority: typedProps.priority,
381
+ evictionPolicy: typedProps.evictionPolicy,
382
+ billingProfile: typedProps.billingProfile,
383
+ host: typedProps.host,
384
+ licenseType: typedProps.licenseType,
385
+ additionalCapabilities: typedProps.additionalCapabilities,
386
+ securityProfile: typedProps.securityProfile,
387
+ },
388
+ };
389
+ }
390
+ // =============================================================================
391
+ // PUBLIC METHODS FOR VIRTUAL MACHINE OPERATIONS
392
+ // =============================================================================
393
+ /**
394
+ * Get the VM ID (unique identifier assigned by Azure)
395
+ */
396
+ get vmId() {
397
+ return `\${${this.terraformResource.fqn}.output.properties.vmId}`;
398
+ }
399
+ /**
400
+ * Get the provisioning state of the Virtual Machine
401
+ */
402
+ get provisioningState() {
403
+ return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
404
+ }
405
+ /**
406
+ * Get the OS profile computer name
407
+ */
408
+ get computerName() {
409
+ return this.props.osProfile?.computerName;
410
+ }
411
+ /**
412
+ * Get the VM size
413
+ */
414
+ get vmSize() {
415
+ return this.props.hardwareProfile.vmSize;
416
+ }
417
+ /**
418
+ * Add a tag to the Virtual Machine
419
+ * Note: This modifies the construct props but requires a new deployment to take effect
420
+ */
421
+ addTag(key, value) {
422
+ if (!this.props.tags) {
423
+ this.props.tags = {};
424
+ }
425
+ this.props.tags[key] = value;
426
+ }
427
+ /**
428
+ * Remove a tag from the Virtual Machine
429
+ * Note: This modifies the construct props but requires a new deployment to take effect
430
+ */
431
+ removeTag(key) {
432
+ if (this.props.tags && this.props.tags[key]) {
433
+ delete this.props.tags[key];
434
+ }
435
+ }
436
+ // =============================================================================
437
+ // PRIVATE HELPER METHODS
438
+ // =============================================================================
439
+ /**
440
+ * Applies ignore changes lifecycle rules if specified in props
441
+ */
442
+ _applyIgnoreChanges() {
443
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
444
+ // Common properties that are safe to ignore for Virtual Machines
445
+ // adminPassword should often be ignored to prevent drift
446
+ const validIgnoreChanges = this.props.ignoreChanges.filter((change) => change !== "name");
447
+ if (validIgnoreChanges.length > 0) {
448
+ this.terraformResource.addOverride("lifecycle", {
449
+ ignore_changes: validIgnoreChanges,
450
+ });
451
+ }
452
+ }
453
+ }
454
+ }
455
+ exports.VirtualMachine = VirtualMachine;
456
+ _a = JSII_RTTI_SYMBOL_1;
457
+ VirtualMachine[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualMachine", version: "1.2.0" };
458
+ /**
459
+ * Static initialization flag to ensure schemas are registered only once
460
+ */
461
+ VirtualMachine.schemasRegistered = false;
462
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-machine.js","sourceRoot":"","sources":["../../../src/azure-virtualmachine/lib/virtual-machine.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Virtual Machine implementation using VersionedAzapiResource framework\n *\n * This class provides a single, version-aware implementation for Azure Virtual Machines\n * that automatically handles version management, schema validation, and property transformation\n * across all supported API versions.\n *\n * Supported API Versions:\n * - 2024-07-01 (Active)\n * - 2024-11-01 (Active)\n * - 2025-04-01 (Active, Latest)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full JSII compliance for multi-language support\n * - Comprehensive support for VM features (networking, storage, identity, etc.)\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_VIRTUAL_MACHINE_VERSIONS,\n  VIRTUAL_MACHINE_TYPE,\n  VirtualMachineHardwareProfile,\n  VirtualMachineStorageProfile,\n  VirtualMachineNetworkProfile,\n  VirtualMachineOSProfile,\n  VirtualMachineIdentity,\n  VirtualMachinePlan,\n  VirtualMachineAdditionalCapabilities,\n  VirtualMachineDiagnosticsProfile,\n  VirtualMachineSecurityProfile,\n  VirtualMachineLicenseType,\n  VirtualMachineAvailabilitySetReference,\n  VirtualMachineScaleSetReference,\n  VirtualMachineProximityPlacementGroupReference,\n  VirtualMachineHostReference,\n  VirtualMachineBillingProfile,\n  VirtualMachineMonitoringOptions,\n} from \"./virtual-machine-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n  MonitoringConfig,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiVersionManager } from \"../../core-azure/lib/version-manager/api-version-manager\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Properties for the unified Azure Virtual Machine\n *\n * Extends AzapiResourceProps with Virtual Machine specific properties\n */\nexport interface VirtualMachineProps extends AzapiResourceProps {\n  /**\n   * The hardware profile for the Virtual Machine (VM size)\n   * @example { vmSize: \"Standard_D2s_v3\" }\n   */\n  readonly hardwareProfile: VirtualMachineHardwareProfile;\n\n  /**\n   * The storage profile for the Virtual Machine\n   * Defines the OS disk, data disks, and image reference\n   */\n  readonly storageProfile: VirtualMachineStorageProfile;\n\n  /**\n   * The network profile for the Virtual Machine\n   * Defines network interfaces attached to the VM\n   */\n  readonly networkProfile: VirtualMachineNetworkProfile;\n\n  /**\n   * The OS profile for the Virtual Machine\n   * Defines computer name, admin credentials, and OS-specific configuration\n   */\n  readonly osProfile?: VirtualMachineOSProfile;\n\n  /**\n   * The identity configuration for the Virtual Machine\n   * @example { type: \"SystemAssigned\" }\n   * @example { type: \"UserAssigned\", userAssignedIdentities: { \"/subscriptions/.../resourceGroups/.../providers/Microsoft.ManagedIdentity/userAssignedIdentities/myIdentity\": {} } }\n   */\n  readonly identity?: VirtualMachineIdentity;\n\n  /**\n   * Availability zones for the Virtual Machine\n   * @example [\"1\", \"2\"]\n   */\n  readonly zones?: string[];\n\n  /**\n   * Plan information for marketplace images\n   */\n  readonly plan?: VirtualMachinePlan;\n\n  /**\n   * License type for Windows VMs\n   * @example \"Windows_Server\"\n   * @example \"Windows_Client\"\n   */\n  readonly licenseType?: VirtualMachineLicenseType;\n\n  /**\n   * The priority of the Virtual Machine\n   * @default \"Regular\"\n   * @example \"Regular\", \"Low\", \"Spot\"\n   */\n  readonly priority?: string;\n\n  /**\n   * The eviction policy for Spot VMs\n   * @example \"Deallocate\", \"Delete\"\n   */\n  readonly evictionPolicy?: string;\n\n  /**\n   * The billing profile for Spot VMs\n   */\n  readonly billingProfile?: VirtualMachineBillingProfile;\n\n  /**\n   * The diagnostics profile for boot diagnostics\n   */\n  readonly diagnosticsProfile?: VirtualMachineDiagnosticsProfile;\n\n  /**\n   * Reference to an availability set\n   */\n  readonly availabilitySet?: VirtualMachineAvailabilitySetReference;\n\n  /**\n   * Reference to a virtual machine scale set\n   */\n  readonly virtualMachineScaleSet?: VirtualMachineScaleSetReference;\n\n  /**\n   * Reference to a proximity placement group\n   */\n  readonly proximityPlacementGroup?: VirtualMachineProximityPlacementGroupReference;\n\n  /**\n   * Reference to a dedicated host\n   */\n  readonly host?: VirtualMachineHostReference;\n\n  /**\n   * Additional capabilities like Ultra SSD\n   */\n  readonly additionalCapabilities?: VirtualMachineAdditionalCapabilities;\n\n  /**\n   * Security settings for the Virtual Machine\n   */\n  readonly securityProfile?: VirtualMachineSecurityProfile;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed or should not trigger updates\n   * @example [\"osProfile.adminPassword\"]\n   */\n  readonly ignoreChanges?: string[];\n\n  /**\n   * Resource group ID where the Virtual Machine will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * Virtual Machine properties for the request body\n */\nexport interface VirtualMachineBodyProperties {\n  readonly hardwareProfile: VirtualMachineHardwareProfile;\n  readonly storageProfile: VirtualMachineStorageProfile;\n  readonly osProfile?: VirtualMachineOSProfile;\n  readonly networkProfile: VirtualMachineNetworkProfile;\n  readonly diagnosticsProfile?: VirtualMachineDiagnosticsProfile;\n  readonly availabilitySet?: VirtualMachineAvailabilitySetReference;\n  readonly virtualMachineScaleSet?: VirtualMachineScaleSetReference;\n  readonly proximityPlacementGroup?: VirtualMachineProximityPlacementGroupReference;\n  readonly priority?: string;\n  readonly evictionPolicy?: string;\n  readonly billingProfile?: VirtualMachineBillingProfile;\n  readonly host?: VirtualMachineHostReference;\n  readonly licenseType?: VirtualMachineLicenseType;\n  readonly additionalCapabilities?: VirtualMachineAdditionalCapabilities;\n  readonly securityProfile?: VirtualMachineSecurityProfile;\n}\n\n/**\n * The resource body interface for Azure Virtual Machine API calls\n */\nexport interface VirtualMachineBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly identity?: VirtualMachineIdentity;\n  readonly zones?: string[];\n  readonly plan?: VirtualMachinePlan;\n  readonly properties: VirtualMachineBodyProperties;\n}\n\n/**\n * Unified Azure Virtual Machine implementation\n *\n * This class provides a single, version-aware implementation that automatically handles version\n * resolution, schema validation, and property transformation while maintaining full JSII compliance.\n *\n * The class uses the VersionedAzapiResource framework to provide:\n * - Automatic latest version resolution (2025-04-01 as of this implementation)\n * - Support for explicit version pinning when stability is required\n * - Schema-driven property validation and transformation\n * - Migration analysis and deprecation warnings\n * - Full JSII compliance for multi-language support\n *\n * @example\n * // Basic Linux VM with SSH authentication:\n * const vm = new VirtualMachine(this, \"vm\", {\n *   name: \"my-linux-vm\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   hardwareProfile: {\n *     vmSize: \"Standard_D2s_v3\"\n *   },\n *   storageProfile: {\n *     imageReference: {\n *       publisher: \"Canonical\",\n *       offer: \"0001-com-ubuntu-server-jammy\",\n *       sku: \"22_04-lts-gen2\",\n *       version: \"latest\"\n *     },\n *     osDisk: {\n *       createOption: \"FromImage\",\n *       managedDisk: {\n *         storageAccountType: \"Premium_LRS\"\n *       }\n *     }\n *   },\n *   osProfile: {\n *     computerName: \"myvm\",\n *     adminUsername: \"azureuser\",\n *     linuxConfiguration: {\n *       disablePasswordAuthentication: true,\n *       ssh: {\n *         publicKeys: [{\n *           path: \"/home/azureuser/.ssh/authorized_keys\",\n *           keyData: \"ssh-rsa AAAA...\"\n *         }]\n *       }\n *     }\n *   },\n *   networkProfile: {\n *     networkInterfaces: [{\n *       id: networkInterface.id\n *     }]\n *   },\n *   identity: {\n *     type: \"SystemAssigned\"\n *   }\n * });\n *\n * @example\n * // Windows VM with password authentication:\n * const windowsVm = new VirtualMachine(this, \"windows-vm\", {\n *   name: \"my-windows-vm\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   hardwareProfile: {\n *     vmSize: \"Standard_D2s_v3\"\n *   },\n *   storageProfile: {\n *     imageReference: {\n *       publisher: \"MicrosoftWindowsServer\",\n *       offer: \"WindowsServer\",\n *       sku: \"2022-datacenter-azure-edition\",\n *       version: \"latest\"\n *     },\n *     osDisk: {\n *       createOption: \"FromImage\",\n *       managedDisk: {\n *         storageAccountType: \"Premium_LRS\"\n *       }\n *     }\n *   },\n *   osProfile: {\n *     computerName: \"mywinvm\",\n *     adminUsername: \"azureuser\",\n *     adminPassword: \"P@ssw0rd1234!\",\n *     windowsConfiguration: {\n *       provisionVMAgent: true,\n *       enableAutomaticUpdates: true\n *     }\n *   },\n *   networkProfile: {\n *     networkInterfaces: [{\n *       id: networkInterface.id\n *     }]\n *   },\n *   licenseType: \"Windows_Server\"\n * });\n *\n * @stability stable\n */\nexport class VirtualMachine extends AzapiResource {\n  /**\n   * Returns a production-ready monitoring configuration for Virtual Machines\n   *\n   * This static factory method provides a complete MonitoringConfig with sensible defaults\n   * for VM monitoring including CPU, memory, disk queue alerts, and deletion tracking.\n   *\n   * @param actionGroupId - The resource ID of the action group for alert notifications\n   * @param workspaceId - Optional Log Analytics workspace ID for diagnostic settings\n   * @param options - Optional configuration to customize thresholds and enable/disable specific alerts\n   * @returns A complete MonitoringConfig object ready to use in VirtualMachine props\n   *\n   * @example\n   * // Basic usage with all defaults\n   * const vm = new VirtualMachine(this, \"vm\", {\n   *   // ... other properties ...\n   *   monitoring: VirtualMachine.defaultMonitoring(actionGroup.id, workspace.id)\n   * });\n   *\n   * @example\n   * // Custom thresholds\n   * const vm = new VirtualMachine(this, \"vm\", {\n   *   // ... other properties ...\n   *   monitoring: VirtualMachine.defaultMonitoring(\n   *     actionGroup.id,\n   *     workspace.id,\n   *     {\n   *       cpuThreshold: 90,\n   *       memoryThreshold: 536870912, // 512MB\n   *       enableDiskQueueAlert: false\n   *     }\n   *   )\n   * });\n   */\n  public static defaultMonitoring(\n    actionGroupId: string,\n    workspaceId?: string,\n    options?: VirtualMachineMonitoringOptions,\n  ): MonitoringConfig {\n    const metricAlerts: any[] = [];\n\n    // High CPU Alert\n    if (options?.enableCpuAlert !== false) {\n      metricAlerts.push({\n        name: \"high-cpu-alert\",\n        description: \"Alert when CPU usage exceeds threshold\",\n        severity: (options?.cpuAlertSeverity ?? 2) as 0 | 1 | 2 | 3 | 4,\n        scopes: [], // Will be set automatically by base class\n        evaluationFrequency: \"PT5M\",\n        windowSize: \"PT15M\",\n        criteria: {\n          type: \"StaticThreshold\" as const,\n          metricName: \"Percentage CPU\",\n          metricNamespace: \"Microsoft.Compute/virtualMachines\",\n          operator: \"GreaterThan\" as const,\n          threshold: options?.cpuThreshold ?? 80,\n          timeAggregation: \"Average\" as const,\n        },\n        actions: [{ actionGroupId }],\n      });\n    }\n\n    // Low Memory Alert\n    if (options?.enableMemoryAlert !== false) {\n      metricAlerts.push({\n        name: \"low-memory-alert\",\n        description: \"Alert when available memory falls below threshold\",\n        severity: (options?.memoryAlertSeverity ?? 2) as 0 | 1 | 2 | 3 | 4,\n        scopes: [], // Will be set automatically by base class\n        evaluationFrequency: \"PT5M\",\n        windowSize: \"PT15M\",\n        criteria: {\n          type: \"StaticThreshold\" as const,\n          metricName: \"Available Memory Bytes\",\n          metricNamespace: \"Microsoft.Compute/virtualMachines\",\n          operator: \"LessThan\" as const,\n          threshold: options?.memoryThreshold ?? 1073741824,\n          timeAggregation: \"Average\" as const,\n        },\n        actions: [{ actionGroupId }],\n      });\n    }\n\n    // High Disk Queue Alert\n    if (options?.enableDiskQueueAlert !== false) {\n      metricAlerts.push({\n        name: \"high-disk-queue-alert\",\n        description: \"Alert when disk queue depth exceeds threshold\",\n        severity: (options?.diskQueueAlertSeverity ?? 2) as 0 | 1 | 2 | 3 | 4,\n        scopes: [], // Will be set automatically by base class\n        evaluationFrequency: \"PT5M\",\n        windowSize: \"PT15M\",\n        criteria: {\n          type: \"StaticThreshold\" as const,\n          metricName: \"OS Disk Queue Depth\",\n          metricNamespace: \"Microsoft.Compute/virtualMachines\",\n          operator: \"GreaterThan\" as const,\n          threshold: options?.diskQueueThreshold ?? 32,\n          timeAggregation: \"Average\" as const,\n        },\n        actions: [{ actionGroupId }],\n      });\n    }\n\n    // Build diagnostic settings if workspace ID is provided\n    const diagnosticSettings = workspaceId\n      ? {\n          name: \"vm-diagnostics\",\n          targetResourceId: \"\", // Will be set automatically by base class\n          workspaceId: workspaceId,\n          logs: [{ categoryGroup: \"allLogs\", enabled: true }],\n          metrics: [{ category: \"AllMetrics\", enabled: true }],\n        }\n      : undefined;\n\n    // Build activity log alerts\n    const activityLogAlerts =\n      options?.enableDeletionAlert !== false\n        ? [\n            {\n              name: \"vm-deletion-alert\",\n              description: \"Alert when virtual machine is deleted\",\n              scopes: [], // Will be set automatically by base class\n              condition: {\n                allOf: [\n                  {\n                    field: \"operationName\",\n                    equalsValue: \"Microsoft.Compute/virtualMachines/delete\",\n                  },\n                ],\n              },\n              actions: {\n                actionGroups: [{ actionGroupId }],\n              },\n            },\n          ]\n        : undefined;\n\n    // Return complete config object\n    return {\n      enabled: true,\n      diagnosticSettings: diagnosticSettings,\n      metricAlerts: metricAlerts,\n      activityLogAlerts: activityLogAlerts,\n    };\n  }\n\n  /**\n   * Static initialization flag to ensure schemas are registered only once\n   */\n  private static schemasRegistered = false;\n\n  /**\n   * Ensures that Virtual Machine schemas are registered with the ApiVersionManager\n   * This is called once during the first VirtualMachine instantiation\n   */\n  private static ensureSchemasRegistered(): void {\n    if (VirtualMachine.schemasRegistered) {\n      return;\n    }\n\n    const apiVersionManager = ApiVersionManager.instance();\n\n    try {\n      // Register all Virtual Machine versions\n      apiVersionManager.registerResourceType(\n        VIRTUAL_MACHINE_TYPE,\n        ALL_VIRTUAL_MACHINE_VERSIONS,\n      );\n\n      VirtualMachine.schemasRegistered = true;\n\n      console.log(\n        `Registered ${ALL_VIRTUAL_MACHINE_VERSIONS.length} API versions for ${VIRTUAL_MACHINE_TYPE}`,\n      );\n    } catch (error) {\n      console.warn(\n        `Failed to register Virtual Machine schemas: ${error}. ` +\n          `This may indicate the schemas are already registered or there's a configuration issue.`,\n      );\n      // Don't throw here as the schemas might already be registered\n      VirtualMachine.schemasRegistered = true;\n    }\n  }\n\n  /**\n   * The input properties for this Virtual Machine instance\n   */\n  public readonly props: VirtualMachineProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n  public readonly vmIdOutput: cdktf.TerraformOutput;\n\n  // Public properties that match common VM interface patterns\n  public readonly id: string;\n  public readonly tags: { [key: string]: string };\n\n  /**\n   * Creates a new Azure Virtual Machine using the VersionedAzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Virtual Machine\n   */\n  constructor(scope: Construct, id: string, props: VirtualMachineProps) {\n    // Ensure schemas are registered before calling super\n    VirtualMachine.ensureSchemasRegistered();\n\n    // Call the parent constructor with the props\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n    this.id = `\\${${this.terraformResource.fqn}.id}`;\n    this.tags = props.tags || {};\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Virtual Machine\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Virtual Machine\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Virtual Machine\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Virtual Machine\",\n    });\n\n    this.vmIdOutput = new cdktf.TerraformOutput(this, \"vmId\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.vmId}`,\n      description: \"The unique identifier of the Virtual Machine\",\n    });\n\n    // Override logical IDs to match naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n    this.vmIdOutput.overrideLogicalId(\"vmId\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the most recent stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2025-04-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Virtual Machines\n   */\n  protected resourceType(): string {\n    return VIRTUAL_MACHINE_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   * Transforms the input properties into the JSON format expected by Azure REST API\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as VirtualMachineProps;\n    return {\n      location: typedProps.location || \"eastus\",\n      tags: typedProps.tags || {},\n      identity: typedProps.identity,\n      zones: typedProps.zones,\n      plan: typedProps.plan,\n      properties: {\n        hardwareProfile: typedProps.hardwareProfile,\n        storageProfile: typedProps.storageProfile,\n        osProfile: typedProps.osProfile,\n        networkProfile: typedProps.networkProfile,\n        diagnosticsProfile: typedProps.diagnosticsProfile,\n        availabilitySet: typedProps.availabilitySet,\n        virtualMachineScaleSet: typedProps.virtualMachineScaleSet,\n        proximityPlacementGroup: typedProps.proximityPlacementGroup,\n        priority: typedProps.priority,\n        evictionPolicy: typedProps.evictionPolicy,\n        billingProfile: typedProps.billingProfile,\n        host: typedProps.host,\n        licenseType: typedProps.licenseType,\n        additionalCapabilities: typedProps.additionalCapabilities,\n        securityProfile: typedProps.securityProfile,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL MACHINE OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the VM ID (unique identifier assigned by Azure)\n   */\n  public get vmId(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.vmId}`;\n  }\n\n  /**\n   * Get the provisioning state of the Virtual Machine\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Get the OS profile computer name\n   */\n  public get computerName(): string | undefined {\n    return this.props.osProfile?.computerName;\n  }\n\n  /**\n   * Get the VM size\n   */\n  public get vmSize(): string {\n    return this.props.hardwareProfile.vmSize;\n  }\n\n  /**\n   * Add a tag to the Virtual Machine\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the Virtual Machine\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      // Common properties that are safe to ignore for Virtual Machines\n      // adminPassword should often be ignored to prevent drift\n      const validIgnoreChanges = this.props.ignoreChanges.filter(\n        (change) => change !== \"name\", // name cannot be changed after creation\n      );\n\n      if (validIgnoreChanges.length > 0) {\n        this.terraformResource.addOverride(\"lifecycle\", {\n          ignore_changes: validIgnoreChanges,\n        });\n      }\n    }\n  }\n}\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Integration test for Azure Virtual Machine
3
+ *
4
+ * This test demonstrates comprehensive usage of the VirtualMachine construct
5
+ * and validates deployment, idempotency, and cleanup.
6
+ *
7
+ * Run with: npm run integration:nostream
8
+ */
9
+ import "cdktf/lib/testing/adapters/jest";