@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,214 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.DnsForwardingRuleset = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure DNS Forwarding Ruleset implementation using AzapiResource framework
8
+ *
9
+ * This class provides a unified implementation for creating DNS Forwarding Rulesets
10
+ * that work with DNS Resolver Outbound Endpoints to enable conditional forwarding rules.
11
+ *
12
+ * Supported API Versions:
13
+ * - 2022-07-01 (Active, Latest)
14
+ *
15
+ * Features:
16
+ * - Automatic latest version resolution when no version is specified
17
+ * - Explicit version pinning for stability requirements
18
+ * - Schema-driven validation and transformation
19
+ * - Full backward compatibility with existing interface
20
+ * - JSII compliance for multi-language support
21
+ * - Conditional DNS forwarding for hybrid scenarios
22
+ */
23
+ const cdktf = require("cdktf");
24
+ const dns_forwarding_ruleset_schemas_1 = require("./dns-forwarding-ruleset-schemas");
25
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
26
+ /**
27
+ * Unified Azure DNS Forwarding Ruleset implementation
28
+ *
29
+ * This class provides a unified implementation for creating DNS Forwarding Rulesets
30
+ * that enable conditional forwarding of DNS queries. Rulesets work with DNS Resolver
31
+ * Outbound Endpoints to route queries to specific target DNS servers based on domain names.
32
+ *
33
+ * Key Requirements:
34
+ * - Requires at least one DNS Resolver Outbound Endpoint
35
+ * - Each ruleset can contain up to 1000 forwarding rules
36
+ * - Regional resource (must match outbound endpoint location)
37
+ * - Can be linked to multiple virtual networks
38
+ *
39
+ * @example
40
+ * // Basic DNS forwarding ruleset with automatic version resolution:
41
+ * const ruleset = new DnsForwardingRuleset(this, "ruleset", {
42
+ * name: "my-ruleset",
43
+ * location: "eastus",
44
+ * resourceGroupId: resourceGroup.id,
45
+ * dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
46
+ * });
47
+ *
48
+ * @example
49
+ * // DNS forwarding ruleset with tags:
50
+ * const ruleset = new DnsForwardingRuleset(this, "ruleset", {
51
+ * name: "my-ruleset",
52
+ * location: "eastus",
53
+ * resourceGroupId: resourceGroup.id,
54
+ * dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
55
+ * tags: {
56
+ * environment: "production",
57
+ * purpose: "hybrid-dns"
58
+ * }
59
+ * });
60
+ *
61
+ * @example
62
+ * // DNS forwarding ruleset with explicit version pinning:
63
+ * const ruleset = new DnsForwardingRuleset(this, "ruleset", {
64
+ * name: "my-ruleset",
65
+ * location: "eastus",
66
+ * resourceGroupId: resourceGroup.id,
67
+ * dnsResolverOutboundEndpointIds: [outboundEndpoint.id],
68
+ * apiVersion: "2022-07-01",
69
+ * });
70
+ *
71
+ * @stability stable
72
+ */
73
+ class DnsForwardingRuleset extends azapi_resource_1.AzapiResource {
74
+ // Public properties
75
+ /**
76
+ * Creates a new Azure DNS Forwarding Ruleset using the AzapiResource framework
77
+ *
78
+ * @param scope - The scope in which to define this construct
79
+ * @param id - The unique identifier for this instance
80
+ * @param props - Configuration properties for the DNS Forwarding Ruleset
81
+ */
82
+ constructor(scope, id, props) {
83
+ super(scope, id, props);
84
+ this.props = props;
85
+ // Extract properties from the AZAPI resource outputs
86
+ // Create Terraform outputs
87
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
88
+ value: this.id,
89
+ description: "The ID of the DNS Forwarding Ruleset",
90
+ });
91
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
92
+ value: `\${${this.terraformResource.fqn}.location}`,
93
+ description: "The location of the DNS Forwarding Ruleset",
94
+ });
95
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
96
+ value: `\${${this.terraformResource.fqn}.name}`,
97
+ description: "The name of the DNS Forwarding Ruleset",
98
+ });
99
+ this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
100
+ value: `\${${this.terraformResource.fqn}.tags}`,
101
+ description: "The tags assigned to the DNS Forwarding Ruleset",
102
+ });
103
+ this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioning_state", {
104
+ value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
105
+ description: "The provisioning state of the DNS Forwarding Ruleset resource",
106
+ });
107
+ this.resourceGuidOutput = new cdktf.TerraformOutput(this, "resource_guid", {
108
+ value: `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,
109
+ description: "The unique identifier for the DNS Forwarding Ruleset resource",
110
+ });
111
+ // Override logical IDs
112
+ this.idOutput.overrideLogicalId("id");
113
+ this.locationOutput.overrideLogicalId("location");
114
+ this.nameOutput.overrideLogicalId("name");
115
+ this.tagsOutput.overrideLogicalId("tags");
116
+ this.provisioningStateOutput.overrideLogicalId("provisioning_state");
117
+ this.resourceGuidOutput.overrideLogicalId("resource_guid");
118
+ // Apply ignore changes if specified
119
+ this._applyIgnoreChanges();
120
+ }
121
+ // =============================================================================
122
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
123
+ // =============================================================================
124
+ /**
125
+ * Gets the default API version to use when no explicit version is specified
126
+ */
127
+ defaultVersion() {
128
+ return "2022-07-01";
129
+ }
130
+ /**
131
+ * Gets the Azure resource type for DNS Forwarding Rulesets
132
+ */
133
+ resourceType() {
134
+ return dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE;
135
+ }
136
+ /**
137
+ * Gets the API schema for the resolved version
138
+ */
139
+ apiSchema() {
140
+ return this.resolveSchema();
141
+ }
142
+ /**
143
+ * Indicates that location is required for DNS Forwarding Rulesets
144
+ */
145
+ requiresLocation() {
146
+ return true;
147
+ }
148
+ /**
149
+ * Creates the resource body for the Azure API call
150
+ */
151
+ createResourceBody(props) {
152
+ const typedProps = props;
153
+ const body = {
154
+ location: this.location,
155
+ tags: this.allTags(),
156
+ properties: {
157
+ dnsResolverOutboundEndpoints: typedProps.dnsResolverOutboundEndpointIds.map((id) => ({ id })),
158
+ },
159
+ };
160
+ return body;
161
+ }
162
+ // =============================================================================
163
+ // PUBLIC METHODS FOR DNS FORWARDING RULESET OPERATIONS
164
+ // =============================================================================
165
+ /**
166
+ * Get the provisioning state of the DNS Forwarding Ruleset
167
+ */
168
+ get provisioningState() {
169
+ return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
170
+ }
171
+ /**
172
+ * Get the unique identifier for the DNS Forwarding Ruleset resource
173
+ */
174
+ get resourceGuid() {
175
+ return `\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;
176
+ }
177
+ /**
178
+ * Add a tag to the DNS Forwarding Ruleset
179
+ */
180
+ addTag(key, value) {
181
+ if (!this.props.tags) {
182
+ this.props.tags = {};
183
+ }
184
+ this.props.tags[key] = value;
185
+ }
186
+ /**
187
+ * Remove a tag from the DNS Forwarding Ruleset
188
+ */
189
+ removeTag(key) {
190
+ if (this.props.tags && this.props.tags[key]) {
191
+ delete this.props.tags[key];
192
+ }
193
+ }
194
+ // =============================================================================
195
+ // PRIVATE HELPER METHODS
196
+ // =============================================================================
197
+ /**
198
+ * Applies ignore changes lifecycle rules if specified in props
199
+ */
200
+ _applyIgnoreChanges() {
201
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
202
+ this.terraformResource.addOverride("lifecycle", {
203
+ ignore_changes: this.props.ignoreChanges,
204
+ });
205
+ }
206
+ }
207
+ }
208
+ exports.DnsForwardingRuleset = DnsForwardingRuleset;
209
+ _a = JSII_RTTI_SYMBOL_1;
210
+ DnsForwardingRuleset[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DnsForwardingRuleset", version: "1.3.0" };
211
+ (() => {
212
+ azapi_resource_1.AzapiResource.registerSchemas(dns_forwarding_ruleset_schemas_1.DNS_FORWARDING_RULESET_TYPE, dns_forwarding_ruleset_schemas_1.ALL_DNS_FORWARDING_RULESET_VERSIONS);
213
+ })();
214
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns-forwarding-ruleset.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure DNS Forwarding Ruleset implementation using AzapiResource framework\n *\n * This class provides a unified implementation for creating DNS Forwarding Rulesets\n * that work with DNS Resolver Outbound Endpoints to enable conditional forwarding rules.\n *\n * Supported API Versions:\n * - 2022-07-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 * - Conditional DNS forwarding for hybrid scenarios\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_DNS_FORWARDING_RULESET_VERSIONS,\n  DNS_FORWARDING_RULESET_TYPE,\n} from \"./dns-forwarding-ruleset-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Properties for the unified Azure DNS Forwarding Ruleset\n *\n * Extends AzapiResourceProps with DNS Forwarding Ruleset specific properties\n */\nexport interface DnsForwardingRulesetProps extends AzapiResourceProps {\n  /**\n   * Array of resource IDs of DNS Resolver Outbound Endpoints\n   * The ruleset uses these endpoints to forward DNS queries based on the rules\n   * @example [\"/subscriptions/.../dnsResolvers/resolver1/outboundEndpoints/endpoint1\"]\n   */\n  readonly dnsResolverOutboundEndpointIds: string[];\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 Forwarding Ruleset will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * The resource body interface for Azure DNS Forwarding Ruleset API calls\n * This matches the Azure REST API schema\n */\n/**\n * DNS Resolver Outbound Endpoint reference\n */\nexport interface DnsResolverOutboundEndpointReference {\n  readonly id: string;\n}\n\n/**\n * Properties for the DNS Forwarding Ruleset body\n */\nexport interface DnsForwardingRulesetProperties {\n  readonly dnsResolverOutboundEndpoints: DnsResolverOutboundEndpointReference[];\n}\n\n/**\n * The resource body interface for Azure DNS Forwarding Ruleset API calls\n * This matches the Azure REST API schema\n */\nexport interface DnsForwardingRulesetBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties: DnsForwardingRulesetProperties;\n}\n\n/**\n * Unified Azure DNS Forwarding Ruleset implementation\n *\n * This class provides a unified implementation for creating DNS Forwarding Rulesets\n * that enable conditional forwarding of DNS queries. Rulesets work with DNS Resolver\n * Outbound Endpoints to route queries to specific target DNS servers based on domain names.\n *\n * Key Requirements:\n * - Requires at least one DNS Resolver Outbound Endpoint\n * - Each ruleset can contain up to 1000 forwarding rules\n * - Regional resource (must match outbound endpoint location)\n * - Can be linked to multiple virtual networks\n *\n * @example\n * // Basic DNS forwarding ruleset with automatic version resolution:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n * });\n *\n * @example\n * // DNS forwarding ruleset with tags:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n *   tags: {\n *     environment: \"production\",\n *     purpose: \"hybrid-dns\"\n *   }\n * });\n *\n * @example\n * // DNS forwarding ruleset with explicit version pinning:\n * const ruleset = new DnsForwardingRuleset(this, \"ruleset\", {\n *   name: \"my-ruleset\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   dnsResolverOutboundEndpointIds: [outboundEndpoint.id],\n *   apiVersion: \"2022-07-01\",\n * });\n *\n * @stability stable\n */\nexport class DnsForwardingRuleset extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      DNS_FORWARDING_RULESET_TYPE,\n      ALL_DNS_FORWARDING_RULESET_VERSIONS,\n    );\n  }\n\n  public readonly props: DnsForwardingRulesetProps;\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 provisioningStateOutput: cdktf.TerraformOutput;\n  public readonly resourceGuidOutput: cdktf.TerraformOutput;\n\n  // Public properties\n\n  /**\n   * Creates a new Azure DNS Forwarding Ruleset using the AzapiResource framework\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the DNS Forwarding Ruleset\n   */\n  constructor(scope: Construct, id: string, props: DnsForwardingRulesetProps) {\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 Forwarding Ruleset\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the DNS Forwarding Ruleset\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the DNS Forwarding Ruleset\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the DNS Forwarding Ruleset\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description:\n          \"The provisioning state of the DNS Forwarding Ruleset resource\",\n      },\n    );\n\n    this.resourceGuidOutput = new cdktf.TerraformOutput(this, \"resource_guid\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`,\n      description:\n        \"The unique identifier for the DNS Forwarding Ruleset resource\",\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.provisioningStateOutput.overrideLogicalId(\"provisioning_state\");\n    this.resourceGuidOutput.overrideLogicalId(\"resource_guid\");\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 \"2022-07-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for DNS Forwarding Rulesets\n   */\n  protected resourceType(): string {\n    return DNS_FORWARDING_RULESET_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   * Indicates that location is required for DNS Forwarding Rulesets\n   */\n  protected requiresLocation(): boolean {\n    return true;\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 DnsForwardingRulesetProps;\n\n    const body: DnsForwardingRulesetBody = {\n      location: this.location!,\n      tags: this.allTags(),\n      properties: {\n        dnsResolverOutboundEndpoints:\n          typedProps.dnsResolverOutboundEndpointIds.map((id) => ({ id })),\n      },\n    };\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR DNS FORWARDING RULESET OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the provisioning state of the DNS Forwarding Ruleset\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Get the unique identifier for the DNS Forwarding Ruleset resource\n   */\n  public get resourceGuid(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.resourceGuid}`;\n  }\n\n  /**\n   * Add a tag to the DNS Forwarding Ruleset\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 Forwarding Ruleset\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", {\n        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
@@ -0,0 +1,24 @@
1
+ /**
2
+ * API schemas for Azure DNS Forwarding Rule across all supported versions
3
+ *
4
+ * This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules
5
+ * across all supported API versions. The schemas are used by the AzapiResource
6
+ * framework for validation, transformation, and version management.
7
+ */
8
+ import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
9
+ /**
10
+ * API Schema for Forwarding Rule version 2022-07-01
11
+ */
12
+ export declare const FORWARDING_RULE_SCHEMA_2022_07_01: ApiSchema;
13
+ /**
14
+ * Version configuration for Forwarding Rule 2022-07-01
15
+ */
16
+ export declare const FORWARDING_RULE_VERSION_2022_07_01: VersionConfig;
17
+ /**
18
+ * All supported Forwarding Rule versions for registration
19
+ */
20
+ export declare const ALL_FORWARDING_RULE_VERSIONS: VersionConfig[];
21
+ /**
22
+ * Resource type constant
23
+ */
24
+ export declare const FORWARDING_RULE_TYPE = "Microsoft.Network/dnsForwardingRulesets/forwardingRules";
@@ -0,0 +1,242 @@
1
+ "use strict";
2
+ /**
3
+ * API schemas for Azure DNS Forwarding Rule across all supported versions
4
+ *
5
+ * This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules
6
+ * across all supported API versions. The schemas are used by the AzapiResource
7
+ * framework for validation, transformation, and version management.
8
+ */
9
+ Object.defineProperty(exports, "__esModule", { value: true });
10
+ exports.FORWARDING_RULE_TYPE = exports.ALL_FORWARDING_RULE_VERSIONS = exports.FORWARDING_RULE_VERSION_2022_07_01 = exports.FORWARDING_RULE_SCHEMA_2022_07_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 Forwarding Rule versions
17
+ */
18
+ const COMMON_PROPERTIES = {
19
+ name: {
20
+ dataType: version_interfaces_1.PropertyType.STRING,
21
+ required: true,
22
+ description: "The name of the Forwarding Rule. Must be unique within the ruleset.",
23
+ validation: [
24
+ {
25
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
26
+ message: "Forwarding Rule name is required",
27
+ },
28
+ {
29
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
30
+ value: "^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$",
31
+ message: "Forwarding Rule name must start and end with alphanumeric characters and can contain hyphens",
32
+ },
33
+ {
34
+ ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
35
+ value: { minLength: 1, maxLength: 80 },
36
+ message: "Forwarding Rule name must be between 1 and 80 characters",
37
+ },
38
+ ],
39
+ },
40
+ dnsForwardingRulesetId: {
41
+ dataType: version_interfaces_1.PropertyType.STRING,
42
+ required: true,
43
+ description: "The resource ID of the parent DNS Forwarding Ruleset that this rule belongs to",
44
+ validation: [
45
+ {
46
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
47
+ message: "DNS Forwarding Ruleset ID is required",
48
+ },
49
+ {
50
+ ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
51
+ value: "^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/dnsForwardingRulesets/[^/]+$",
52
+ message: "DNS Forwarding Ruleset ID must be a valid resource ID",
53
+ },
54
+ ],
55
+ },
56
+ domainName: {
57
+ dataType: version_interfaces_1.PropertyType.STRING,
58
+ required: true,
59
+ description: "The domain name to forward (e.g., 'contoso.com.'). Must end with a dot for FQDN.",
60
+ validation: [
61
+ {
62
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
63
+ message: "Domain name is required for Forwarding Rules",
64
+ },
65
+ {
66
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
67
+ value: version_interfaces_1.PropertyType.STRING,
68
+ message: "Domain name must be a string",
69
+ },
70
+ ],
71
+ },
72
+ targetDnsServers: {
73
+ dataType: version_interfaces_1.PropertyType.ARRAY,
74
+ required: true,
75
+ description: "Array of target DNS servers to forward queries to. Maximum of 6 servers per rule. Each server requires ipAddress, and optionally port (default 53).",
76
+ validation: [
77
+ {
78
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
79
+ message: "At least one target DNS server is required for Forwarding Rules",
80
+ },
81
+ {
82
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
83
+ value: version_interfaces_1.PropertyType.ARRAY,
84
+ message: "TargetDnsServers must be an array",
85
+ },
86
+ ],
87
+ },
88
+ forwardingRuleState: {
89
+ dataType: version_interfaces_1.PropertyType.STRING,
90
+ required: false,
91
+ defaultValue: "Enabled",
92
+ description: "The state of the forwarding rule. Possible values: 'Enabled' or 'Disabled'. Default is 'Enabled'.",
93
+ validation: [
94
+ {
95
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
96
+ value: version_interfaces_1.PropertyType.STRING,
97
+ message: "ForwardingRuleState must be a string",
98
+ },
99
+ ],
100
+ },
101
+ metadata: {
102
+ dataType: version_interfaces_1.PropertyType.OBJECT,
103
+ required: false,
104
+ defaultValue: {},
105
+ description: "Metadata attached to the forwarding rule as key-value pairs",
106
+ validation: [
107
+ {
108
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
109
+ value: version_interfaces_1.PropertyType.OBJECT,
110
+ message: "Metadata must be an object with string key-value pairs",
111
+ },
112
+ ],
113
+ },
114
+ ignoreChanges: {
115
+ dataType: version_interfaces_1.PropertyType.ARRAY,
116
+ required: false,
117
+ description: "Array of property names to ignore during updates",
118
+ validation: [
119
+ {
120
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
121
+ value: version_interfaces_1.PropertyType.ARRAY,
122
+ message: "IgnoreChanges must be an array of strings",
123
+ },
124
+ ],
125
+ },
126
+ };
127
+ // =============================================================================
128
+ // READ-ONLY PROPERTY DEFINITIONS
129
+ // =============================================================================
130
+ /**
131
+ * Read-only properties that are populated by Azure after creation
132
+ * These properties should not be included in the request body
133
+ */
134
+ const READ_ONLY_PROPERTIES = {
135
+ provisioningState: {
136
+ dataType: version_interfaces_1.PropertyType.STRING,
137
+ required: false,
138
+ description: "The provisioning state of the Forwarding Rule resource (read-only)",
139
+ validation: [
140
+ {
141
+ ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
142
+ value: version_interfaces_1.PropertyType.STRING,
143
+ message: "ProvisioningState must be a string",
144
+ },
145
+ ],
146
+ },
147
+ };
148
+ // =============================================================================
149
+ // VERSION-SPECIFIC SCHEMAS
150
+ // =============================================================================
151
+ /**
152
+ * API Schema for Forwarding Rule version 2022-07-01
153
+ */
154
+ exports.FORWARDING_RULE_SCHEMA_2022_07_01 = {
155
+ resourceType: "Microsoft.Network/dnsForwardingRulesets/forwardingRules",
156
+ version: "2022-07-01",
157
+ properties: {
158
+ ...COMMON_PROPERTIES,
159
+ ...READ_ONLY_PROPERTIES,
160
+ },
161
+ required: [
162
+ "name",
163
+ "dnsForwardingRulesetId",
164
+ "domainName",
165
+ "targetDnsServers",
166
+ ],
167
+ optional: ["forwardingRuleState", "metadata", "ignoreChanges"],
168
+ deprecated: [],
169
+ transformationRules: {},
170
+ validationRules: [
171
+ {
172
+ property: "name",
173
+ rules: [
174
+ {
175
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
176
+ message: "Name is required for Forwarding Rules",
177
+ },
178
+ ],
179
+ },
180
+ {
181
+ property: "dnsForwardingRulesetId",
182
+ rules: [
183
+ {
184
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
185
+ message: "DNS Forwarding Ruleset ID is required for Forwarding Rules",
186
+ },
187
+ ],
188
+ },
189
+ {
190
+ property: "domainName",
191
+ rules: [
192
+ {
193
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
194
+ message: "Domain name is required for Forwarding Rules",
195
+ },
196
+ ],
197
+ },
198
+ {
199
+ property: "targetDnsServers",
200
+ rules: [
201
+ {
202
+ ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
203
+ message: "At least one target DNS server is required",
204
+ },
205
+ ],
206
+ },
207
+ ],
208
+ };
209
+ // =============================================================================
210
+ // VERSION CONFIGURATIONS
211
+ // =============================================================================
212
+ /**
213
+ * Version configuration for Forwarding Rule 2022-07-01
214
+ */
215
+ exports.FORWARDING_RULE_VERSION_2022_07_01 = {
216
+ version: "2022-07-01",
217
+ schema: exports.FORWARDING_RULE_SCHEMA_2022_07_01,
218
+ supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
219
+ releaseDate: "2022-07-01",
220
+ deprecationDate: undefined,
221
+ sunsetDate: undefined,
222
+ breakingChanges: [],
223
+ migrationGuide: "/docs/forwarding-rule/migration-2022-07-01",
224
+ changeLog: [
225
+ {
226
+ changeType: "added",
227
+ description: "Stable release of Forwarding Rule API with support for conditional DNS forwarding",
228
+ breaking: false,
229
+ },
230
+ ],
231
+ };
232
+ /**
233
+ * All supported Forwarding Rule versions for registration
234
+ */
235
+ exports.ALL_FORWARDING_RULE_VERSIONS = [
236
+ exports.FORWARDING_RULE_VERSION_2022_07_01,
237
+ ];
238
+ /**
239
+ * Resource type constant
240
+ */
241
+ exports.FORWARDING_RULE_TYPE = "Microsoft.Network/dnsForwardingRulesets/forwardingRules";
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"forwarding-rule-schemas.js","sourceRoot":"","sources":["../../../src/azure-dnsforwardingruleset/lib/forwarding-rule-schemas.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,2GAO4E;AAE5E,gFAAgF;AAChF,8BAA8B;AAC9B,gFAAgF;AAEhF;;GAEG;AACH,MAAM,iBAAiB,GAA0C;IAC/D,IAAI,EAAE;QACJ,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,qEAAqE;QACvE,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,kCAAkC;aAC5C;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,aAAa;gBAC1C,KAAK,EAAE,0CAA0C;gBACjD,OAAO,EACL,8FAA8F;aACjG;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,WAAW;gBACxC,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;gBACtC,OAAO,EAAE,0DAA0D;aACpE;SACF;KACF;IACD,sBAAsB,EAAE;QACtB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,gFAAgF;QAClF,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,uCAAuC;aACjD;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,aAAa;gBAC1C,KAAK,EACH,qGAAqG;gBACvG,OAAO,EAAE,uDAAuD;aACjE;SACF;KACF;IACD,UAAU,EAAE;QACV,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,kFAAkF;QACpF,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EAAE,8CAA8C;aACxD;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,8BAA8B;aACxC;SACF;KACF;IACD,gBAAgB,EAAE;QAChB,QAAQ,EAAE,iCAAY,CAAC,KAAK;QAC5B,QAAQ,EAAE,IAAI;QACd,WAAW,EACT,qJAAqJ;QACvJ,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;gBACrC,OAAO,EACL,iEAAiE;aACpE;YACD;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,KAAK;gBACzB,OAAO,EAAE,mCAAmC;aAC7C;SACF;KACF;IACD,mBAAmB,EAAE;QACnB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,SAAS;QACvB,WAAW,EACT,mGAAmG;QACrG,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,sCAAsC;aAChD;SACF;KACF;IACD,QAAQ,EAAE;QACR,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE;QAChB,WAAW,EAAE,6DAA6D;QAC1E,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,wDAAwD;aAClE;SACF;KACF;IACD,aAAa,EAAE;QACb,QAAQ,EAAE,iCAAY,CAAC,KAAK;QAC5B,QAAQ,EAAE,KAAK;QACf,WAAW,EAAE,kDAAkD;QAC/D,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,KAAK;gBACzB,OAAO,EAAE,2CAA2C;aACrD;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,iCAAiC;AACjC,gFAAgF;AAEhF;;;GAGG;AACH,MAAM,oBAAoB,GAA0C;IAClE,iBAAiB,EAAE;QACjB,QAAQ,EAAE,iCAAY,CAAC,MAAM;QAC7B,QAAQ,EAAE,KAAK;QACf,WAAW,EACT,oEAAoE;QACtE,UAAU,EAAE;YACV;gBACE,QAAQ,EAAE,uCAAkB,CAAC,UAAU;gBACvC,KAAK,EAAE,iCAAY,CAAC,MAAM;gBAC1B,OAAO,EAAE,oCAAoC;aAC9C;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,2BAA2B;AAC3B,gFAAgF;AAEhF;;GAEG;AACU,QAAA,iCAAiC,GAAc;IAC1D,YAAY,EAAE,yDAAyD;IACvE,OAAO,EAAE,YAAY;IACrB,UAAU,EAAE;QACV,GAAG,iBAAiB;QACpB,GAAG,oBAAoB;KACxB;IACD,QAAQ,EAAE;QACR,MAAM;QACN,wBAAwB;QACxB,YAAY;QACZ,kBAAkB;KACnB;IACD,QAAQ,EAAE,CAAC,qBAAqB,EAAE,UAAU,EAAE,eAAe,CAAC;IAC9D,UAAU,EAAE,EAAE;IACd,mBAAmB,EAAE,EAAE;IACvB,eAAe,EAAE;QACf;YACE,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,uCAAuC;iBACjD;aACF;SACF;QACD;YACE,QAAQ,EAAE,wBAAwB;YAClC,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,4DAA4D;iBACtE;aACF;SACF;QACD;YACE,QAAQ,EAAE,YAAY;YACtB,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,8CAA8C;iBACxD;aACF;SACF;QACD;YACE,QAAQ,EAAE,kBAAkB;YAC5B,KAAK,EAAE;gBACL;oBACE,QAAQ,EAAE,uCAAkB,CAAC,QAAQ;oBACrC,OAAO,EAAE,4CAA4C;iBACtD;aACF;SACF;KACF;CACF,CAAC;AAEF,gFAAgF;AAChF,yBAAyB;AACzB,gFAAgF;AAEhF;;GAEG;AACU,QAAA,kCAAkC,GAAkB;IAC/D,OAAO,EAAE,YAAY;IACrB,MAAM,EAAE,yCAAiC;IACzC,YAAY,EAAE,wCAAmB,CAAC,MAAM;IACxC,WAAW,EAAE,YAAY;IACzB,eAAe,EAAE,SAAS;IAC1B,UAAU,EAAE,SAAS;IACrB,eAAe,EAAE,EAAE;IACnB,cAAc,EAAE,4CAA4C;IAC5D,SAAS,EAAE;QACT;YACE,UAAU,EAAE,OAAO;YACnB,WAAW,EACT,mFAAmF;YACrF,QAAQ,EAAE,KAAK;SAChB;KACF;CACF,CAAC;AAEF;;GAEG;AACU,QAAA,4BAA4B,GAAoB;IAC3D,0CAAkC;CACnC,CAAC;AAEF;;GAEG;AACU,QAAA,oBAAoB,GAC/B,yDAAyD,CAAC","sourcesContent":["/**\n * API schemas for Azure DNS Forwarding Rule across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/dnsForwardingRulesets/forwardingRules\n * across all supported API versions. The schemas are used by the AzapiResource\n * framework for validation, transformation, and version management.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all Forwarding Rule versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The name of the Forwarding Rule. Must be unique within the ruleset.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Forwarding Rule name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9]([a-zA-Z0-9-]*[a-zA-Z0-9])?$\",\n        message:\n          \"Forwarding Rule name must start and end with alphanumeric characters and can contain hyphens\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 80 },\n        message: \"Forwarding Rule name must be between 1 and 80 characters\",\n      },\n    ],\n  },\n  dnsForwardingRulesetId: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The resource ID of the parent DNS Forwarding Ruleset that this rule belongs to\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"DNS Forwarding Ruleset ID is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value:\n          \"^/subscriptions/[^/]+/resourceGroups/[^/]+/providers/Microsoft.Network/dnsForwardingRulesets/[^/]+$\",\n        message: \"DNS Forwarding Ruleset ID must be a valid resource ID\",\n      },\n    ],\n  },\n  domainName: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The domain name to forward (e.g., 'contoso.com.'). Must end with a dot for FQDN.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Domain name is required for Forwarding Rules\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"Domain name must be a string\",\n      },\n    ],\n  },\n  targetDnsServers: {\n    dataType: PropertyType.ARRAY,\n    required: true,\n    description:\n      \"Array of target DNS servers to forward queries to. Maximum of 6 servers per rule. Each server requires ipAddress, and optionally port (default 53).\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message:\n          \"At least one target DNS server is required for Forwarding Rules\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message: \"TargetDnsServers must be an array\",\n      },\n    ],\n  },\n  forwardingRuleState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Enabled\",\n    description:\n      \"The state of the forwarding rule. Possible values: 'Enabled' or 'Disabled'. Default is 'Enabled'.\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ForwardingRuleState must be a string\",\n      },\n    ],\n  },\n  metadata: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    defaultValue: {},\n    description: \"Metadata attached to the forwarding rule as key-value pairs\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.OBJECT,\n        message: \"Metadata must be an object with string key-value pairs\",\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// READ-ONLY PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Read-only properties that are populated by Azure after creation\n * These properties should not be included in the request body\n */\nconst READ_ONLY_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  provisioningState: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The provisioning state of the Forwarding Rule resource (read-only)\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.STRING,\n        message: \"ProvisioningState must be a string\",\n      },\n    ],\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Forwarding Rule version 2022-07-01\n */\nexport const FORWARDING_RULE_SCHEMA_2022_07_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/dnsForwardingRulesets/forwardingRules\",\n  version: \"2022-07-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n    ...READ_ONLY_PROPERTIES,\n  },\n  required: [\n    \"name\",\n    \"dnsForwardingRulesetId\",\n    \"domainName\",\n    \"targetDnsServers\",\n  ],\n  optional: [\"forwardingRuleState\", \"metadata\", \"ignoreChanges\"],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"dnsForwardingRulesetId\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"DNS Forwarding Ruleset ID is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"domainName\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Domain name is required for Forwarding Rules\",\n        },\n      ],\n    },\n    {\n      property: \"targetDnsServers\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"At least one target DNS server is required\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Forwarding Rule 2022-07-01\n */\nexport const FORWARDING_RULE_VERSION_2022_07_01: VersionConfig = {\n  version: \"2022-07-01\",\n  schema: FORWARDING_RULE_SCHEMA_2022_07_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2022-07-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/forwarding-rule/migration-2022-07-01\",\n  changeLog: [\n    {\n      changeType: \"added\",\n      description:\n        \"Stable release of Forwarding Rule API with support for conditional DNS forwarding\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Forwarding Rule versions for registration\n */\nexport const ALL_FORWARDING_RULE_VERSIONS: VersionConfig[] = [\n  FORWARDING_RULE_VERSION_2022_07_01,\n];\n\n/**\n * Resource type constant\n */\nexport const FORWARDING_RULE_TYPE =\n  \"Microsoft.Network/dnsForwardingRulesets/forwardingRules\";\n"]}