@microsoft/terraform-cdk-constructs 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (291) hide show
  1. package/.jsii +54846 -26661
  2. package/API.md +72091 -23784
  3. package/lib/azure-actiongroup/index.d.ts +0 -10
  4. package/lib/azure-actiongroup/index.js +1 -11
  5. package/lib/azure-actiongroup/lib/action-group.d.ts +0 -10
  6. package/lib/azure-actiongroup/lib/action-group.js +6 -32
  7. package/lib/azure-actiongroup/lib/index.d.ts +1 -4
  8. package/lib/azure-actiongroup/lib/index.js +2 -5
  9. package/lib/azure-activitylogalert/index.d.ts +0 -10
  10. package/lib/azure-activitylogalert/index.js +1 -11
  11. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +0 -10
  12. package/lib/azure-activitylogalert/lib/activity-log-alert.js +6 -32
  13. package/lib/azure-activitylogalert/lib/index.d.ts +1 -4
  14. package/lib/azure-activitylogalert/lib/index.js +2 -5
  15. package/lib/azure-aks/index.d.ts +0 -8
  16. package/lib/azure-aks/index.js +1 -11
  17. package/lib/azure-aks/lib/aks-cluster.d.ts +4 -13
  18. package/lib/azure-aks/lib/aks-cluster.js +13 -36
  19. package/lib/azure-aks/lib/index.d.ts +1 -10
  20. package/lib/azure-aks/lib/index.js +2 -21
  21. package/lib/azure-diagnosticsettings/index.d.ts +0 -6
  22. package/lib/azure-diagnosticsettings/index.js +1 -7
  23. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +0 -10
  24. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +6 -32
  25. package/lib/azure-diagnosticsettings/lib/index.d.ts +1 -7
  26. package/lib/azure-diagnosticsettings/lib/index.js +2 -8
  27. package/lib/azure-dnsforwardingruleset/index.d.ts +1 -0
  28. package/lib/azure-dnsforwardingruleset/index.js +18 -0
  29. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.d.ts +24 -0
  30. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset-schemas.js +206 -0
  31. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +174 -0
  32. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +214 -0
  33. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.d.ts +24 -0
  34. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.js +242 -0
  35. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +193 -0
  36. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +193 -0
  37. package/lib/azure-dnsforwardingruleset/lib/index.d.ts +6 -0
  38. package/lib/azure-dnsforwardingruleset/lib/index.js +23 -0
  39. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.d.ts +24 -0
  40. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link-schemas.js +199 -0
  41. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +160 -0
  42. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +178 -0
  43. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +9 -0
  44. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +133 -0
  45. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.d.ts +9 -0
  46. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +350 -0
  47. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.d.ts +9 -0
  48. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +397 -0
  49. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.d.ts +9 -0
  50. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +285 -0
  51. package/lib/azure-dnsresolver/index.d.ts +1 -0
  52. package/lib/azure-dnsresolver/index.js +18 -0
  53. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.d.ts +24 -0
  54. package/lib/azure-dnsresolver/lib/dns-resolver-schemas.js +218 -0
  55. package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +170 -0
  56. package/lib/azure-dnsresolver/lib/dns-resolver.js +236 -0
  57. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.d.ts +24 -0
  58. package/lib/azure-dnsresolver/lib/inbound-endpoint-schemas.js +261 -0
  59. package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +189 -0
  60. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +243 -0
  61. package/lib/azure-dnsresolver/lib/index.d.ts +6 -0
  62. package/lib/azure-dnsresolver/lib/index.js +23 -0
  63. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.d.ts +24 -0
  64. package/lib/azure-dnsresolver/lib/outbound-endpoint-schemas.js +231 -0
  65. package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +175 -0
  66. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +234 -0
  67. package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +14 -0
  68. package/lib/azure-dnsresolver/test/dns-resolver.integ.js +117 -0
  69. package/lib/azure-dnsresolver/test/dns-resolver.spec.d.ts +9 -0
  70. package/lib/azure-dnsresolver/test/dns-resolver.spec.js +353 -0
  71. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +9 -0
  72. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +151 -0
  73. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.d.ts +9 -0
  74. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +441 -0
  75. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +9 -0
  76. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +149 -0
  77. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.d.ts +9 -0
  78. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +301 -0
  79. package/lib/azure-dnszone/index.d.ts +1 -0
  80. package/lib/azure-dnszone/index.js +18 -0
  81. package/lib/azure-dnszone/lib/dns-zone-schemas.d.ts +24 -0
  82. package/lib/azure-dnszone/lib/dns-zone-schemas.js +191 -0
  83. package/lib/azure-dnszone/lib/dns-zone.d.ts +182 -0
  84. package/lib/azure-dnszone/lib/dns-zone.js +228 -0
  85. package/lib/azure-dnszone/lib/index.d.ts +2 -0
  86. package/lib/azure-dnszone/lib/index.js +19 -0
  87. package/lib/azure-dnszone/test/dns-zone.integ.d.ts +9 -0
  88. package/lib/azure-dnszone/test/dns-zone.integ.js +85 -0
  89. package/lib/azure-dnszone/test/dns-zone.spec.d.ts +9 -0
  90. package/lib/azure-dnszone/test/dns-zone.spec.js +285 -0
  91. package/lib/azure-metricalert/index.d.ts +0 -10
  92. package/lib/azure-metricalert/index.js +1 -11
  93. package/lib/azure-metricalert/lib/index.d.ts +1 -4
  94. package/lib/azure-metricalert/lib/index.js +2 -5
  95. package/lib/azure-metricalert/lib/metric-alert.d.ts +0 -10
  96. package/lib/azure-metricalert/lib/metric-alert.js +6 -32
  97. package/lib/azure-networkinterface/index.d.ts +0 -3
  98. package/lib/azure-networkinterface/index.js +1 -4
  99. package/lib/azure-networkinterface/lib/index.d.ts +1 -5
  100. package/lib/azure-networkinterface/lib/index.js +2 -5
  101. package/lib/azure-networkinterface/lib/network-interface.d.ts +4 -9
  102. package/lib/azure-networkinterface/lib/network-interface.js +14 -29
  103. package/lib/azure-networkinterface/test/network-interface.integ.js +20 -6
  104. package/lib/azure-networksecuritygroup/index.d.ts +0 -5
  105. package/lib/azure-networksecuritygroup/index.js +1 -6
  106. package/lib/azure-networksecuritygroup/lib/index.d.ts +2 -5
  107. package/lib/azure-networksecuritygroup/lib/index.js +17 -14
  108. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +4 -13
  109. package/lib/azure-networksecuritygroup/lib/network-security-group.js +14 -36
  110. package/lib/azure-policyassignment/index.d.ts +1 -0
  111. package/lib/azure-policyassignment/index.js +18 -0
  112. package/lib/azure-policyassignment/lib/index.d.ts +2 -0
  113. package/lib/azure-policyassignment/lib/index.js +19 -0
  114. package/lib/azure-policyassignment/lib/policy-assignment-schemas.d.ts +25 -0
  115. package/lib/azure-policyassignment/lib/policy-assignment-schemas.js +260 -0
  116. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +342 -0
  117. package/lib/azure-policyassignment/lib/policy-assignment.js +228 -0
  118. package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +13 -0
  119. package/lib/azure-policyassignment/test/policy-assignment.integ.js +153 -0
  120. package/lib/azure-policyassignment/test/policy-assignment.spec.d.ts +9 -0
  121. package/lib/azure-policyassignment/test/policy-assignment.spec.js +651 -0
  122. package/lib/azure-policydefinition/index.d.ts +1 -0
  123. package/lib/azure-policydefinition/index.js +18 -0
  124. package/lib/azure-policydefinition/lib/index.d.ts +2 -0
  125. package/lib/azure-policydefinition/lib/index.js +19 -0
  126. package/lib/azure-policydefinition/lib/policy-definition-schemas.d.ts +25 -0
  127. package/lib/azure-policydefinition/lib/policy-definition-schemas.js +210 -0
  128. package/lib/azure-policydefinition/lib/policy-definition.d.ts +260 -0
  129. package/lib/azure-policydefinition/lib/policy-definition.js +199 -0
  130. package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +9 -0
  131. package/lib/azure-policydefinition/test/policy-definition.integ.js +137 -0
  132. package/lib/azure-policydefinition/test/policy-definition.spec.d.ts +9 -0
  133. package/lib/azure-policydefinition/test/policy-definition.spec.js +596 -0
  134. package/lib/azure-privatednszone/index.d.ts +1 -0
  135. package/lib/azure-privatednszone/index.js +18 -0
  136. package/lib/azure-privatednszone/lib/index.d.ts +2 -0
  137. package/lib/azure-privatednszone/lib/index.js +19 -0
  138. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.d.ts +24 -0
  139. package/lib/azure-privatednszone/lib/private-dns-zone-schemas.js +254 -0
  140. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +178 -0
  141. package/lib/azure-privatednszone/lib/private-dns-zone.js +272 -0
  142. package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +9 -0
  143. package/lib/azure-privatednszone/test/private-dns-zone.integ.js +84 -0
  144. package/lib/azure-privatednszone/test/private-dns-zone.spec.d.ts +9 -0
  145. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +341 -0
  146. package/lib/azure-privatednszonelink/index.d.ts +1 -0
  147. package/lib/azure-privatednszonelink/index.js +18 -0
  148. package/lib/azure-privatednszonelink/lib/index.d.ts +2 -0
  149. package/lib/azure-privatednszonelink/lib/index.js +19 -0
  150. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.d.ts +24 -0
  151. package/lib/azure-privatednszonelink/lib/private-dns-zone-link-schemas.js +262 -0
  152. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +202 -0
  153. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +250 -0
  154. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +9 -0
  155. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +110 -0
  156. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.d.ts +9 -0
  157. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +465 -0
  158. package/lib/azure-publicipaddress/index.d.ts +0 -5
  159. package/lib/azure-publicipaddress/index.js +1 -6
  160. package/lib/azure-publicipaddress/lib/index.d.ts +2 -9
  161. package/lib/azure-publicipaddress/lib/index.js +17 -17
  162. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +4 -13
  163. package/lib/azure-publicipaddress/lib/public-ip-address.js +14 -36
  164. package/lib/azure-resourcegroup/index.d.ts +0 -37
  165. package/lib/azure-resourcegroup/index.js +1 -39
  166. package/lib/azure-resourcegroup/lib/index.d.ts +1 -44
  167. package/lib/azure-resourcegroup/lib/index.js +2 -43
  168. package/lib/azure-resourcegroup/lib/resource-group.d.ts +9 -23
  169. package/lib/azure-resourcegroup/lib/resource-group.js +23 -56
  170. package/lib/azure-resourcegroup/test/resource-group.spec.js +13 -19
  171. package/lib/azure-roleassignment/index.d.ts +1 -0
  172. package/lib/azure-roleassignment/index.js +18 -0
  173. package/lib/azure-roleassignment/lib/index.d.ts +2 -0
  174. package/lib/azure-roleassignment/lib/index.js +19 -0
  175. package/lib/azure-roleassignment/lib/role-assignment-schemas.d.ts +25 -0
  176. package/lib/azure-roleassignment/lib/role-assignment-schemas.js +238 -0
  177. package/lib/azure-roleassignment/lib/role-assignment.d.ts +294 -0
  178. package/lib/azure-roleassignment/lib/role-assignment.js +257 -0
  179. package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +12 -0
  180. package/lib/azure-roleassignment/test/role-assignment.integ.js +101 -0
  181. package/lib/azure-roleassignment/test/role-assignment.spec.d.ts +9 -0
  182. package/lib/azure-roleassignment/test/role-assignment.spec.js +633 -0
  183. package/lib/azure-roledefinition/index.d.ts +1 -0
  184. package/lib/azure-roledefinition/index.js +18 -0
  185. package/lib/azure-roledefinition/lib/index.d.ts +2 -0
  186. package/lib/azure-roledefinition/lib/index.js +19 -0
  187. package/lib/azure-roledefinition/lib/role-definition-schemas.d.ts +25 -0
  188. package/lib/azure-roledefinition/lib/role-definition-schemas.js +195 -0
  189. package/lib/azure-roledefinition/lib/role-definition.d.ts +236 -0
  190. package/lib/azure-roledefinition/lib/role-definition.js +192 -0
  191. package/lib/azure-roledefinition/test/role-definition.integ.d.ts +12 -0
  192. package/lib/azure-roledefinition/test/role-definition.integ.js +142 -0
  193. package/lib/azure-roledefinition/test/role-definition.spec.d.ts +9 -0
  194. package/lib/azure-roledefinition/test/role-definition.spec.js +946 -0
  195. package/lib/azure-storageaccount/index.d.ts +0 -19
  196. package/lib/azure-storageaccount/index.js +1 -20
  197. package/lib/azure-storageaccount/lib/index.d.ts +1 -7
  198. package/lib/azure-storageaccount/lib/index.js +2 -8
  199. package/lib/azure-storageaccount/lib/storage-account.d.ts +4 -9
  200. package/lib/azure-storageaccount/lib/storage-account.js +15 -29
  201. package/lib/azure-subnet/index.d.ts +0 -3
  202. package/lib/azure-subnet/index.js +1 -4
  203. package/lib/azure-subnet/lib/index.d.ts +1 -4
  204. package/lib/azure-subnet/lib/index.js +2 -5
  205. package/lib/azure-subnet/lib/subnet.d.ts +3 -14
  206. package/lib/azure-subnet/lib/subnet.js +28 -47
  207. package/lib/azure-subnet/test/subnet.integ.js +19 -7
  208. package/lib/azure-subnet/test/subnet.spec.js +1 -2
  209. package/lib/azure-virtualmachine/index.d.ts +0 -6
  210. package/lib/azure-virtualmachine/index.js +1 -7
  211. package/lib/azure-virtualmachine/lib/index.d.ts +1 -10
  212. package/lib/azure-virtualmachine/lib/index.js +2 -21
  213. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +4 -13
  214. package/lib/azure-virtualmachine/lib/virtual-machine.js +15 -36
  215. package/lib/azure-virtualnetwork/index.d.ts +0 -9
  216. package/lib/azure-virtualnetwork/index.js +1 -11
  217. package/lib/azure-virtualnetwork/lib/index.d.ts +2 -9
  218. package/lib/azure-virtualnetwork/lib/index.js +17 -20
  219. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +4 -13
  220. package/lib/azure-virtualnetwork/lib/virtual-network.js +15 -36
  221. package/lib/azure-virtualnetworkmanager/index.d.ts +1 -0
  222. package/lib/azure-virtualnetworkmanager/index.js +18 -0
  223. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.d.ts +48 -0
  224. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration-schemas.js +265 -0
  225. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +185 -0
  226. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +206 -0
  227. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +14 -0
  228. package/lib/azure-virtualnetworkmanager/lib/index.js +31 -0
  229. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.d.ts +32 -0
  230. package/lib/azure-virtualnetworkmanager/lib/network-group-schemas.js +189 -0
  231. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.d.ts +32 -0
  232. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member-schemas.js +201 -0
  233. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +135 -0
  234. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +163 -0
  235. package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +139 -0
  236. package/lib/azure-virtualnetworkmanager/lib/network-group.js +158 -0
  237. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.d.ts +32 -0
  238. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration-schemas.js +182 -0
  239. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +144 -0
  240. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +164 -0
  241. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.d.ts +38 -0
  242. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection-schemas.js +206 -0
  243. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +142 -0
  244. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +162 -0
  245. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.d.ts +39 -0
  246. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-schemas.js +359 -0
  247. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +221 -0
  248. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +204 -0
  249. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.d.ts +32 -0
  250. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager-schemas.js +236 -0
  251. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +337 -0
  252. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +283 -0
  253. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +25 -0
  254. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +402 -0
  255. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.d.ts +9 -0
  256. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +1652 -0
  257. package/lib/azure-vmss/index.d.ts +0 -5
  258. package/lib/azure-vmss/index.js +1 -6
  259. package/lib/azure-vmss/lib/index.d.ts +0 -7
  260. package/lib/azure-vmss/lib/index.js +1 -21
  261. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +5 -13
  262. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +29 -53
  263. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.d.ts +10 -0
  264. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +218 -0
  265. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +178 -26
  266. package/lib/core-azure/lib/azapi/azapi-resource.js +328 -90
  267. package/lib/core-azure/lib/azapi/azapi-resource.spec.js +2 -2
  268. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  269. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  270. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +5 -3
  271. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  272. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  273. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  274. package/lib/core-azure/lib/azapi/resource-schema-validator.d.ts +118 -0
  275. package/lib/core-azure/lib/azapi/resource-schema-validator.js +236 -0
  276. package/lib/core-azure/lib/azapi/resource-version-manager.d.ts +103 -0
  277. package/lib/core-azure/lib/azapi/resource-version-manager.js +168 -0
  278. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +11 -6
  279. package/lib/core-azure/lib/index.d.ts +2 -2
  280. package/lib/core-azure/lib/index.js +5 -5
  281. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  282. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  283. package/lib/index.d.ts +19 -0
  284. package/lib/index.js +21 -2
  285. package/lib/testing/index.js +2 -2
  286. package/lib/testing/lib/cleanup.d.ts +1 -0
  287. package/lib/testing/lib/cleanup.js +19 -12
  288. package/lib/testing/lib/metadata.js +19 -16
  289. package/package.json +1 -1
  290. package/scripts/cleanup-test-resources.ts +22 -4
  291. package/scripts/generate-index.js +25 -8
@@ -0,0 +1,191 @@
1
+ "use strict";
2
+ /**
3
+ * API schemas for Azure DNS Zone across all supported versions
4
+ *
5
+ * This file defines the complete API schemas for Microsoft.Network/dnsZones
6
+ * across all supported API versions. The schemas are used by the VersionedAzapiResource
7
+ * framework for validation, transformation, and version management.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.DNS_ZONE_TYPE = exports.ALL_DNS_ZONE_VERSIONS = exports.DNS_ZONE_VERSION_2018_05_01 = exports.DNS_ZONE_SCHEMA_2018_05_01 = void 0;
11
+ const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
12
+ // =============================================================================
13
+ // COMMON PROPERTY DEFINITIONS
14
+ // =============================================================================
15
+ /**
16
+ * Common property definitions shared across all DNS Zone versions
17
+ */
18
+ const COMMON_PROPERTIES = {
19
+ location: {
20
+ dataType: version_interfaces_1.PropertyType.STRING,
21
+ required: true,
22
+ defaultValue: "global",
23
+ description: "The Azure region where the DNS Zone will be created. DNS Zones are global resources, so this is typically 'global'",
24
+ validation: [
25
+ {
26
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
27
+ message: "Location is required for DNS Zones",
28
+ },
29
+ ],
30
+ },
31
+ tags: {
32
+ dataType: version_interfaces_1.PropertyType.OBJECT,
33
+ required: false,
34
+ defaultValue: {},
35
+ description: "A dictionary of tags to apply to the DNS Zone for organizational, billing, or other purposes",
36
+ validation: [
37
+ {
38
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
39
+ value: version_interfaces_1.PropertyType.OBJECT,
40
+ message: "Tags must be an object with string key-value pairs",
41
+ },
42
+ ],
43
+ },
44
+ name: {
45
+ dataType: version_interfaces_1.PropertyType.STRING,
46
+ required: true,
47
+ description: "The name of the DNS Zone (without a terminating dot). Must be a valid domain name",
48
+ validation: [
49
+ {
50
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
51
+ message: "DNS Zone name is required",
52
+ },
53
+ {
54
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
55
+ value: "^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)*$",
56
+ message: "DNS Zone name must be a valid domain name without terminating dot",
57
+ },
58
+ {
59
+ ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
60
+ value: { minLength: 1, maxLength: 253 },
61
+ message: "DNS Zone name must be between 1 and 253 characters",
62
+ },
63
+ ],
64
+ },
65
+ zoneType: {
66
+ dataType: version_interfaces_1.PropertyType.STRING,
67
+ required: false,
68
+ defaultValue: "Public",
69
+ description: "The type of this DNS zone (Public or Private). Public zones are Internet-accessible",
70
+ validation: [
71
+ {
72
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
73
+ value: "^(Public|Private)$",
74
+ message: "Zone type must be either 'Public' or 'Private'",
75
+ },
76
+ ],
77
+ },
78
+ registrationVirtualNetworks: {
79
+ dataType: version_interfaces_1.PropertyType.ARRAY,
80
+ required: false,
81
+ description: "A list of references to virtual networks that register hostnames in this DNS zone. Only valid when zoneType is Private",
82
+ validation: [
83
+ {
84
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
85
+ value: version_interfaces_1.PropertyType.ARRAY,
86
+ message: "RegistrationVirtualNetworks must be an array of virtual network references",
87
+ },
88
+ ],
89
+ },
90
+ resolutionVirtualNetworks: {
91
+ dataType: version_interfaces_1.PropertyType.ARRAY,
92
+ required: false,
93
+ description: "A list of references to virtual networks that resolve records in this DNS zone. Only valid when zoneType is Private",
94
+ validation: [
95
+ {
96
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
97
+ value: version_interfaces_1.PropertyType.ARRAY,
98
+ message: "ResolutionVirtualNetworks must be an array of virtual network references",
99
+ },
100
+ ],
101
+ },
102
+ ignoreChanges: {
103
+ dataType: version_interfaces_1.PropertyType.ARRAY,
104
+ required: false,
105
+ description: "Array of property names to ignore during updates",
106
+ validation: [
107
+ {
108
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
109
+ value: version_interfaces_1.PropertyType.ARRAY,
110
+ message: "IgnoreChanges must be an array of strings",
111
+ },
112
+ ],
113
+ },
114
+ };
115
+ // =============================================================================
116
+ // VERSION-SPECIFIC SCHEMAS
117
+ // =============================================================================
118
+ /**
119
+ * API Schema for DNS Zone version 2018-05-01
120
+ */
121
+ exports.DNS_ZONE_SCHEMA_2018_05_01 = {
122
+ resourceType: "Microsoft.Network/dnsZones",
123
+ version: "2018-05-01",
124
+ properties: {
125
+ ...COMMON_PROPERTIES,
126
+ },
127
+ required: ["location", "name"],
128
+ optional: [
129
+ "tags",
130
+ "zoneType",
131
+ "registrationVirtualNetworks",
132
+ "resolutionVirtualNetworks",
133
+ "ignoreChanges",
134
+ ],
135
+ deprecated: [],
136
+ transformationRules: {},
137
+ validationRules: [
138
+ {
139
+ property: "location",
140
+ rules: [
141
+ {
142
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
143
+ message: "Location is required for DNS Zones",
144
+ },
145
+ ],
146
+ },
147
+ {
148
+ property: "name",
149
+ rules: [
150
+ {
151
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
152
+ message: "Name is required for DNS Zones",
153
+ },
154
+ ],
155
+ },
156
+ ],
157
+ };
158
+ // =============================================================================
159
+ // VERSION CONFIGURATIONS
160
+ // =============================================================================
161
+ /**
162
+ * Version configuration for DNS Zone 2018-05-01
163
+ */
164
+ exports.DNS_ZONE_VERSION_2018_05_01 = {
165
+ version: "2018-05-01",
166
+ schema: exports.DNS_ZONE_SCHEMA_2018_05_01,
167
+ supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
168
+ releaseDate: "2018-05-01",
169
+ deprecationDate: undefined,
170
+ sunsetDate: undefined,
171
+ breakingChanges: [],
172
+ migrationGuide: "/docs/dns-zone/migration-2018-05-01",
173
+ changeLog: [
174
+ {
175
+ changeType: "added",
176
+ description: "Stable release of DNS Zone API with support for public and private DNS zones",
177
+ breaking: false,
178
+ },
179
+ ],
180
+ };
181
+ /**
182
+ * All supported DNS Zone versions for registration
183
+ */
184
+ exports.ALL_DNS_ZONE_VERSIONS = [
185
+ exports.DNS_ZONE_VERSION_2018_05_01,
186
+ ];
187
+ /**
188
+ * Resource type constant
189
+ */
190
+ exports.DNS_ZONE_TYPE = "Microsoft.Network/dnsZones";
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-zone-schemas.js","sourceRoot":"","sources":["../../../src/azure-dnszone/lib/dns-zone-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure DNS Zone across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/dnsZones\n * across all supported API versions. The schemas are used by the VersionedAzapiResource\n * framework for validation, transformation, and version management.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all DNS Zone versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  location: {\n    dataType: PropertyType.STRING,\n    required: true,\n    defaultValue: \"global\",\n    description:\n      \"The Azure region where the DNS Zone will be created. DNS Zones are global resources, so this is typically 'global'\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Location is required for DNS Zones\",\n      },\n    ],\n  },\n  tags: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description:\n      \"A dictionary of tags to apply to the DNS Zone for organizational, billing, or other purposes\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Tags must be an object with string key-value pairs\",\n      },\n    ],\n  },\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The name of the DNS Zone (without a terminating dot). Must be a valid domain name\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"DNS Zone name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value:\n          \"^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?(\\\\.[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?)*$\",\n        message:\n          \"DNS Zone name must be a valid domain name without terminating dot\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 253 },\n        message: \"DNS Zone name must be between 1 and 253 characters\",\n      },\n    ],\n  },\n  zoneType: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Public\",\n    description:\n      \"The type of this DNS zone (Public or Private). Public zones are Internet-accessible\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^(Public|Private)$\",\n        message: \"Zone type must be either 'Public' or 'Private'\",\n      },\n    ],\n  },\n  registrationVirtualNetworks: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"A list of references to virtual networks that register hostnames in this DNS zone. Only valid when zoneType is Private\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message:\n          \"RegistrationVirtualNetworks must be an array of virtual network references\",\n      },\n    ],\n  },\n  resolutionVirtualNetworks: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"A list of references to virtual networks that resolve records in this DNS zone. Only valid when zoneType is Private\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message:\n          \"ResolutionVirtualNetworks must be an array of virtual network references\",\n      },\n    ],\n  },\n  ignoreChanges: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description: \"Array of property names to ignore during updates\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"IgnoreChanges must be an array of strings\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for DNS Zone version 2018-05-01\n */\nexport const DNS_ZONE_SCHEMA_2018_05_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/dnsZones\",\n  version: \"2018-05-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"location\", \"name\"],\n  optional: [\n    \"tags\",\n    \"zoneType\",\n    \"registrationVirtualNetworks\",\n    \"resolutionVirtualNetworks\",\n    \"ignoreChanges\",\n  ],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"location\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Location is required for DNS Zones\",\n        },\n      ],\n    },\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for DNS Zones\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for DNS Zone 2018-05-01\n */\nexport const DNS_ZONE_VERSION_2018_05_01: VersionConfig = {\n  version: \"2018-05-01\",\n  schema: DNS_ZONE_SCHEMA_2018_05_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2018-05-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/dns-zone/migration-2018-05-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of DNS Zone API with support for public and private DNS zones\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported DNS Zone versions for registration\n */\nexport const ALL_DNS_ZONE_VERSIONS: VersionConfig[] = [\n  DNS_ZONE_VERSION_2018_05_01,\n];\n\n/**\n * Resource type constant\n */\nexport const DNS_ZONE_TYPE = \"Microsoft.Network/dnsZones\";\n"]}
@@ -0,0 +1,182 @@
1
+ /**
2
+ * Unified Azure DNS Zone implementation using VersionedAzapiResource framework
3
+ *
4
+ * This class provides a single, version-aware implementation that automatically handles
5
+ * version management, schema validation, and property transformation across all
6
+ * supported API versions.
7
+ *
8
+ * Supported API Versions:
9
+ * - 2018-05-01 (Active, Latest)
10
+ *
11
+ * Features:
12
+ * - Automatic latest version resolution when no version is specified
13
+ * - Explicit version pinning for stability requirements
14
+ * - Schema-driven validation and transformation
15
+ * - Full backward compatibility with existing interface
16
+ * - JSII compliance for multi-language support
17
+ * - Support for both Public and Private DNS zones
18
+ */
19
+ import * as cdktf from "cdktf";
20
+ import { Construct } from "constructs";
21
+ import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
22
+ import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
23
+ /**
24
+ * Virtual network reference for private DNS zones
25
+ */
26
+ export interface VirtualNetworkReference {
27
+ /**
28
+ * The resource ID of the virtual network
29
+ */
30
+ readonly id: string;
31
+ }
32
+ /**
33
+ * Properties for the unified Azure DNS Zone
34
+ *
35
+ * Extends AzapiResourceProps with DNS Zone specific properties
36
+ */
37
+ export interface DnsZoneProps extends AzapiResourceProps {
38
+ /**
39
+ * The type of this DNS zone (Public or Private)
40
+ * @default "Public"
41
+ */
42
+ readonly zoneType?: "Public" | "Private";
43
+ /**
44
+ * A list of references to virtual networks that register hostnames in this DNS zone
45
+ * Only valid when zoneType is Private
46
+ */
47
+ readonly registrationVirtualNetworks?: VirtualNetworkReference[];
48
+ /**
49
+ * A list of references to virtual networks that resolve records in this DNS zone
50
+ * Only valid when zoneType is Private
51
+ */
52
+ readonly resolutionVirtualNetworks?: VirtualNetworkReference[];
53
+ /**
54
+ * The lifecycle rules to ignore changes
55
+ * @example ["tags"]
56
+ */
57
+ readonly ignoreChanges?: string[];
58
+ /**
59
+ * Resource group ID where the DNS Zone will be created
60
+ */
61
+ readonly resourceGroupId?: string;
62
+ }
63
+ /**
64
+ * The resource body interface for Azure DNS Zone API calls
65
+ * This matches the Azure REST API schema
66
+ */
67
+ export interface DnsZoneBody {
68
+ readonly location: string;
69
+ readonly tags?: {
70
+ [key: string]: string;
71
+ };
72
+ readonly properties?: {
73
+ [key: string]: any;
74
+ };
75
+ }
76
+ /**
77
+ * Unified Azure DNS Zone implementation
78
+ *
79
+ * This class provides a single, version-aware implementation that replaces all
80
+ * version-specific DNS Zone classes. It automatically handles version
81
+ * resolution, schema validation, and property transformation while maintaining
82
+ * full backward compatibility.
83
+ *
84
+ * Azure DNS Zones are global resources used to host DNS records for a domain.
85
+ * They can be either Public (Internet-accessible) or Private (accessible only
86
+ * from specified virtual networks).
87
+ *
88
+ * @example
89
+ * // Basic public DNS zone with automatic version resolution:
90
+ * const dnsZone = new DnsZone(this, "dns", {
91
+ * name: "contoso.com",
92
+ * location: "global",
93
+ * resourceGroupId: resourceGroup.id,
94
+ * });
95
+ *
96
+ * @example
97
+ * // Private DNS zone with virtual network links:
98
+ * const privateDnsZone = new DnsZone(this, "privateDns", {
99
+ * name: "internal.contoso.com",
100
+ * location: "global",
101
+ * resourceGroupId: resourceGroup.id,
102
+ * zoneType: "Private",
103
+ * registrationVirtualNetworks: [{ id: vnet.id }],
104
+ * tags: { environment: "production" }
105
+ * });
106
+ *
107
+ * @example
108
+ * // DNS zone with explicit version pinning:
109
+ * const dnsZone = new DnsZone(this, "dns", {
110
+ * name: "contoso.com",
111
+ * location: "global",
112
+ * resourceGroupId: resourceGroup.id,
113
+ * apiVersion: "2018-05-01",
114
+ * });
115
+ *
116
+ * @stability stable
117
+ */
118
+ export declare class DnsZone extends AzapiResource {
119
+ readonly props: DnsZoneProps;
120
+ readonly idOutput: cdktf.TerraformOutput;
121
+ readonly locationOutput: cdktf.TerraformOutput;
122
+ readonly nameOutput: cdktf.TerraformOutput;
123
+ readonly tagsOutput: cdktf.TerraformOutput;
124
+ readonly nameServersOutput: cdktf.TerraformOutput;
125
+ /**
126
+ * Creates a new Azure DNS Zone using the VersionedAzapiResource framework
127
+ *
128
+ * @param scope - The scope in which to define this construct
129
+ * @param id - The unique identifier for this instance
130
+ * @param props - Configuration properties for the DNS Zone
131
+ */
132
+ constructor(scope: Construct, id: string, props: DnsZoneProps);
133
+ /**
134
+ * Gets the default API version to use when no explicit version is specified
135
+ */
136
+ protected defaultVersion(): string;
137
+ /**
138
+ * Gets the Azure resource type for DNS Zones
139
+ */
140
+ protected resourceType(): string;
141
+ /**
142
+ * Gets the API schema for the resolved version
143
+ */
144
+ protected apiSchema(): ApiSchema;
145
+ /**
146
+ * Provides default location for DNS Zones (global resource)
147
+ */
148
+ protected defaultLocation(): string;
149
+ /**
150
+ * Creates the resource body for the Azure API call
151
+ */
152
+ protected createResourceBody(props: any): any;
153
+ /**
154
+ * Get the name servers for the DNS Zone
155
+ * These are the Azure DNS name servers that should be configured at your domain registrar
156
+ */
157
+ get nameServers(): string;
158
+ /**
159
+ * Get the maximum number of record sets that can be created in this DNS zone
160
+ */
161
+ get maxNumberOfRecordSets(): string;
162
+ /**
163
+ * Get the current number of record sets in this DNS zone
164
+ */
165
+ get numberOfRecordSets(): string;
166
+ /**
167
+ * Get the zone type (Public or Private)
168
+ */
169
+ get zoneType(): string;
170
+ /**
171
+ * Add a tag to the DNS Zone
172
+ */
173
+ addTag(key: string, value: string): void;
174
+ /**
175
+ * Remove a tag from the DNS Zone
176
+ */
177
+ removeTag(key: string): void;
178
+ /**
179
+ * Applies ignore changes lifecycle rules if specified in props
180
+ */
181
+ private _applyIgnoreChanges;
182
+ }
@@ -0,0 +1,228 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DnsZone = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure DNS Zone implementation using VersionedAzapiResource framework
8
+ *
9
+ * This class provides a single, version-aware implementation that automatically handles
10
+ * version management, schema validation, and property transformation across all
11
+ * supported API versions.
12
+ *
13
+ * Supported API Versions:
14
+ * - 2018-05-01 (Active, Latest)
15
+ *
16
+ * Features:
17
+ * - Automatic latest version resolution when no version is specified
18
+ * - Explicit version pinning for stability requirements
19
+ * - Schema-driven validation and transformation
20
+ * - Full backward compatibility with existing interface
21
+ * - JSII compliance for multi-language support
22
+ * - Support for both Public and Private DNS zones
23
+ */
24
+ const cdktf = require("cdktf");
25
+ const dns_zone_schemas_1 = require("./dns-zone-schemas");
26
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
27
+ /**
28
+ * Unified Azure DNS Zone implementation
29
+ *
30
+ * This class provides a single, version-aware implementation that replaces all
31
+ * version-specific DNS Zone classes. It automatically handles version
32
+ * resolution, schema validation, and property transformation while maintaining
33
+ * full backward compatibility.
34
+ *
35
+ * Azure DNS Zones are global resources used to host DNS records for a domain.
36
+ * They can be either Public (Internet-accessible) or Private (accessible only
37
+ * from specified virtual networks).
38
+ *
39
+ * @example
40
+ * // Basic public DNS zone with automatic version resolution:
41
+ * const dnsZone = new DnsZone(this, "dns", {
42
+ * name: "contoso.com",
43
+ * location: "global",
44
+ * resourceGroupId: resourceGroup.id,
45
+ * });
46
+ *
47
+ * @example
48
+ * // Private DNS zone with virtual network links:
49
+ * const privateDnsZone = new DnsZone(this, "privateDns", {
50
+ * name: "internal.contoso.com",
51
+ * location: "global",
52
+ * resourceGroupId: resourceGroup.id,
53
+ * zoneType: "Private",
54
+ * registrationVirtualNetworks: [{ id: vnet.id }],
55
+ * tags: { environment: "production" }
56
+ * });
57
+ *
58
+ * @example
59
+ * // DNS zone with explicit version pinning:
60
+ * const dnsZone = new DnsZone(this, "dns", {
61
+ * name: "contoso.com",
62
+ * location: "global",
63
+ * resourceGroupId: resourceGroup.id,
64
+ * apiVersion: "2018-05-01",
65
+ * });
66
+ *
67
+ * @stability stable
68
+ */
69
+ class DnsZone extends azapi_resource_1.AzapiResource {
70
+ // Public properties
71
+ /**
72
+ * Creates a new Azure DNS Zone using the VersionedAzapiResource framework
73
+ *
74
+ * @param scope - The scope in which to define this construct
75
+ * @param id - The unique identifier for this instance
76
+ * @param props - Configuration properties for the DNS Zone
77
+ */
78
+ constructor(scope, id, props) {
79
+ super(scope, id, props);
80
+ this.props = props;
81
+ // Extract properties from the AZAPI resource outputs
82
+ // Create Terraform outputs
83
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
84
+ value: this.id,
85
+ description: "The ID of the DNS Zone",
86
+ });
87
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
88
+ value: `\${${this.terraformResource.fqn}.location}`,
89
+ description: "The location of the DNS Zone",
90
+ });
91
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
92
+ value: `\${${this.terraformResource.fqn}.name}`,
93
+ description: "The name of the DNS Zone",
94
+ });
95
+ this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
96
+ value: `\${${this.terraformResource.fqn}.tags}`,
97
+ description: "The tags assigned to the DNS Zone",
98
+ });
99
+ this.nameServersOutput = new cdktf.TerraformOutput(this, "name_servers", {
100
+ value: `\${${this.terraformResource.fqn}.output.properties.nameServers}`,
101
+ description: "The name servers for the DNS Zone",
102
+ });
103
+ // Override logical IDs
104
+ this.idOutput.overrideLogicalId("id");
105
+ this.locationOutput.overrideLogicalId("location");
106
+ this.nameOutput.overrideLogicalId("name");
107
+ this.tagsOutput.overrideLogicalId("tags");
108
+ this.nameServersOutput.overrideLogicalId("name_servers");
109
+ // Apply ignore changes if specified
110
+ this._applyIgnoreChanges();
111
+ }
112
+ // =============================================================================
113
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
114
+ // =============================================================================
115
+ /**
116
+ * Gets the default API version to use when no explicit version is specified
117
+ */
118
+ defaultVersion() {
119
+ return "2018-05-01";
120
+ }
121
+ /**
122
+ * Gets the Azure resource type for DNS Zones
123
+ */
124
+ resourceType() {
125
+ return dns_zone_schemas_1.DNS_ZONE_TYPE;
126
+ }
127
+ /**
128
+ * Gets the API schema for the resolved version
129
+ */
130
+ apiSchema() {
131
+ return this.resolveSchema();
132
+ }
133
+ /**
134
+ * Provides default location for DNS Zones (global resource)
135
+ */
136
+ defaultLocation() {
137
+ return "global";
138
+ }
139
+ /**
140
+ * Creates the resource body for the Azure API call
141
+ */
142
+ createResourceBody(props) {
143
+ const typedProps = props;
144
+ const body = {
145
+ location: this.location,
146
+ // Tags are passed separately to createAzapiResource() for proper idempotency
147
+ // Do not include tags in the body
148
+ };
149
+ // Add properties object if zone type or virtual networks are specified
150
+ if (typedProps.zoneType ||
151
+ typedProps.registrationVirtualNetworks ||
152
+ typedProps.resolutionVirtualNetworks) {
153
+ body.properties = {
154
+ zoneType: typedProps.zoneType || "Public",
155
+ registrationVirtualNetworks: typedProps.registrationVirtualNetworks,
156
+ resolutionVirtualNetworks: typedProps.resolutionVirtualNetworks,
157
+ };
158
+ }
159
+ return body;
160
+ }
161
+ // =============================================================================
162
+ // PUBLIC METHODS FOR DNS ZONE OPERATIONS
163
+ // =============================================================================
164
+ /**
165
+ * Get the name servers for the DNS Zone
166
+ * These are the Azure DNS name servers that should be configured at your domain registrar
167
+ */
168
+ get nameServers() {
169
+ return `\${${this.terraformResource.fqn}.output.properties.nameServers}`;
170
+ }
171
+ /**
172
+ * Get the maximum number of record sets that can be created in this DNS zone
173
+ */
174
+ get maxNumberOfRecordSets() {
175
+ return `\${${this.terraformResource.fqn}.output.properties.maxNumberOfRecordSets}`;
176
+ }
177
+ /**
178
+ * Get the current number of record sets in this DNS zone
179
+ */
180
+ get numberOfRecordSets() {
181
+ return `\${${this.terraformResource.fqn}.output.properties.numberOfRecordSets}`;
182
+ }
183
+ /**
184
+ * Get the zone type (Public or Private)
185
+ */
186
+ get zoneType() {
187
+ return this.props.zoneType || "Public";
188
+ }
189
+ /**
190
+ * Add a tag to the DNS Zone
191
+ */
192
+ addTag(key, value) {
193
+ if (!this.props.tags) {
194
+ this.props.tags = {};
195
+ }
196
+ this.props.tags[key] = value;
197
+ }
198
+ /**
199
+ * Remove a tag from the DNS Zone
200
+ */
201
+ removeTag(key) {
202
+ if (this.props.tags && this.props.tags[key]) {
203
+ delete this.props.tags[key];
204
+ }
205
+ }
206
+ // =============================================================================
207
+ // PRIVATE HELPER METHODS
208
+ // =============================================================================
209
+ /**
210
+ * Applies ignore changes lifecycle rules if specified in props
211
+ */
212
+ _applyIgnoreChanges() {
213
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
214
+ this.terraformResource.addOverride("lifecycle", [
215
+ {
216
+ ignore_changes: this.props.ignoreChanges,
217
+ },
218
+ ]);
219
+ }
220
+ }
221
+ }
222
+ exports.DnsZone = DnsZone;
223
+ _a = JSII_RTTI_SYMBOL_1;
224
+ DnsZone[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsZone", version: "1.3.0" };
225
+ (() => {
226
+ azapi_resource_1.AzapiResource.registerSchemas(dns_zone_schemas_1.DNS_ZONE_TYPE, dns_zone_schemas_1.ALL_DNS_ZONE_VERSIONS);
227
+ })();
228
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-zone.js","sourceRoot":"","sources":["../../../src/azure-dnszone/lib/dns-zone.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure DNS Zone implementation using VersionedAzapiResource framework\n *\n * This class provides a single, version-aware implementation that automatically handles\n * version management, schema validation, and property transformation across all\n * supported API versions.\n *\n * Supported API Versions:\n * - 2018-05-01 (Active, Latest)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full backward compatibility with existing interface\n * - JSII compliance for multi-language support\n * - Support for both Public and Private DNS zones\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ALL_DNS_ZONE_VERSIONS, DNS_ZONE_TYPE } from \"./dns-zone-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Virtual network reference for private DNS zones\n */\nexport interface VirtualNetworkReference {\n  /**\n   * The resource ID of the virtual network\n   */\n  readonly id: string;\n}\n\n/**\n * Properties for the unified Azure DNS Zone\n *\n * Extends AzapiResourceProps with DNS Zone specific properties\n */\nexport interface DnsZoneProps extends AzapiResourceProps {\n  /**\n   * The type of this DNS zone (Public or Private)\n   * @default \"Public\"\n   */\n  readonly zoneType?: \"Public\" | \"Private\";\n\n  /**\n   * A list of references to virtual networks that register hostnames in this DNS zone\n   * Only valid when zoneType is Private\n   */\n  readonly registrationVirtualNetworks?: VirtualNetworkReference[];\n\n  /**\n   * A list of references to virtual networks that resolve records in this DNS zone\n   * Only valid when zoneType is Private\n   */\n  readonly resolutionVirtualNetworks?: VirtualNetworkReference[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n\n  /**\n   * Resource group ID where the DNS Zone will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * The resource body interface for Azure DNS Zone API calls\n * This matches the Azure REST API schema\n */\nexport interface DnsZoneBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties?: { [key: string]: any };\n}\n\n/**\n * Unified Azure DNS Zone implementation\n *\n * This class provides a single, version-aware implementation that replaces all\n * version-specific DNS Zone classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * Azure DNS Zones are global resources used to host DNS records for a domain.\n * They can be either Public (Internet-accessible) or Private (accessible only\n * from specified virtual networks).\n *\n * @example\n * // Basic public DNS zone with automatic version resolution:\n * const dnsZone = new DnsZone(this, \"dns\", {\n *   name: \"contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n * });\n *\n * @example\n * // Private DNS zone with virtual network links:\n * const privateDnsZone = new DnsZone(this, \"privateDns\", {\n *   name: \"internal.contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n *   zoneType: \"Private\",\n *   registrationVirtualNetworks: [{ id: vnet.id }],\n *   tags: { environment: \"production\" }\n * });\n *\n * @example\n * // DNS zone with explicit version pinning:\n * const dnsZone = new DnsZone(this, \"dns\", {\n *   name: \"contoso.com\",\n *   location: \"global\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2018-05-01\",\n * });\n *\n * @stability stable\n */\nexport class DnsZone extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(DNS_ZONE_TYPE, ALL_DNS_ZONE_VERSIONS);\n  }\n\n  public readonly props: DnsZoneProps;\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 nameServersOutput: cdktf.TerraformOutput;\n\n  // Public properties\n\n  /**\n   * Creates a new Azure DNS Zone using the VersionedAzapiResource framework\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the DNS Zone\n   */\n  constructor(scope: Construct, id: string, props: DnsZoneProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs\n\n    // Create Terraform outputs\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the DNS Zone\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the DNS Zone\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the DNS Zone\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the DNS Zone\",\n    });\n\n    this.nameServersOutput = new cdktf.TerraformOutput(this, \"name_servers\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.nameServers}`,\n      description: \"The name servers for the DNS Zone\",\n    });\n\n    // Override logical IDs\n    this.idOutput.overrideLogicalId(\"id\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n    this.nameServersOutput.overrideLogicalId(\"name_servers\");\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   */\n  protected defaultVersion(): string {\n    return \"2018-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for DNS Zones\n   */\n  protected resourceType(): string {\n    return DNS_ZONE_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Provides default location for DNS Zones (global resource)\n   */\n  protected defaultLocation(): string {\n    return \"global\";\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as DnsZoneProps;\n\n    const body: any = {\n      location: this.location!,\n      // Tags are passed separately to createAzapiResource() for proper idempotency\n      // Do not include tags in the body\n    };\n\n    // Add properties object if zone type or virtual networks are specified\n    if (\n      typedProps.zoneType ||\n      typedProps.registrationVirtualNetworks ||\n      typedProps.resolutionVirtualNetworks\n    ) {\n      body.properties = {\n        zoneType: typedProps.zoneType || \"Public\",\n        registrationVirtualNetworks: typedProps.registrationVirtualNetworks,\n        resolutionVirtualNetworks: typedProps.resolutionVirtualNetworks,\n      };\n    }\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR DNS ZONE OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the name servers for the DNS Zone\n   * These are the Azure DNS name servers that should be configured at your domain registrar\n   */\n  public get nameServers(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.nameServers}`;\n  }\n\n  /**\n   * Get the maximum number of record sets that can be created in this DNS zone\n   */\n  public get maxNumberOfRecordSets(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.maxNumberOfRecordSets}`;\n  }\n\n  /**\n   * Get the current number of record sets in this DNS zone\n   */\n  public get numberOfRecordSets(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.numberOfRecordSets}`;\n  }\n\n  /**\n   * Get the zone type (Public or Private)\n   */\n  public get zoneType(): string {\n    return this.props.zoneType || \"Public\";\n  }\n\n  /**\n   * Add a tag to the DNS Zone\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 DNS Zone\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", [\n        {\n          ignore_changes: this.props.ignoreChanges,\n        },\n      ]);\n    }\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export * from "./dns-zone-schemas";
2
+ export * from "./dns-zone";