@microsoft/terraform-cdk-constructs 1.9.0 → 2.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (246) hide show
  1. package/.jsii +38110 -28389
  2. package/API.md +40683 -30877
  3. package/lib/azure-actiongroup/lib/action-group.d.ts +3 -3
  4. package/lib/azure-actiongroup/lib/action-group.js +5 -5
  5. package/lib/azure-actiongroup/test/action-group.integ.d.ts +1 -1
  6. package/lib/azure-actiongroup/test/action-group.integ.js +5 -5
  7. package/lib/azure-actiongroup/test/action-group.spec.js +9 -9
  8. package/lib/azure-activitylogalert/lib/activity-log-alert.d.ts +3 -3
  9. package/lib/azure-activitylogalert/lib/activity-log-alert.js +5 -5
  10. package/lib/azure-activitylogalert/test/activity-log-alert.integ.d.ts +1 -1
  11. package/lib/azure-activitylogalert/test/activity-log-alert.integ.js +6 -6
  12. package/lib/azure-activitylogalert/test/activity-log-alert.spec.js +9 -9
  13. package/lib/azure-aks/lib/aks-cluster.d.ts +6 -6
  14. package/lib/azure-aks/lib/aks-cluster.js +8 -8
  15. package/lib/azure-aks/test/aks-cluster.integ.d.ts +1 -1
  16. package/lib/azure-aks/test/aks-cluster.integ.js +5 -5
  17. package/lib/azure-aks/test/aks-cluster.spec.js +12 -12
  18. package/lib/azure-containerapps/index.d.ts +1 -0
  19. package/lib/azure-containerapps/index.js +18 -0
  20. package/lib/azure-containerapps/lib/container-app-environment-schemas.d.ts +50 -0
  21. package/lib/azure-containerapps/lib/container-app-environment-schemas.js +522 -0
  22. package/lib/azure-containerapps/lib/container-app-environment.d.ts +374 -0
  23. package/lib/azure-containerapps/lib/container-app-environment.js +310 -0
  24. package/lib/azure-containerapps/lib/container-app-schemas.d.ts +48 -0
  25. package/lib/azure-containerapps/lib/container-app-schemas.js +466 -0
  26. package/lib/azure-containerapps/lib/container-app.d.ts +925 -0
  27. package/lib/azure-containerapps/lib/container-app.js +320 -0
  28. package/lib/azure-containerapps/lib/index.d.ts +4 -0
  29. package/lib/azure-containerapps/lib/index.js +21 -0
  30. package/lib/azure-containerapps/test/container-app-environment.integ.d.ts +10 -0
  31. package/lib/azure-containerapps/test/container-app-environment.integ.js +82 -0
  32. package/lib/azure-containerapps/test/container-app-environment.spec.d.ts +9 -0
  33. package/lib/azure-containerapps/test/container-app-environment.spec.js +412 -0
  34. package/lib/azure-containerapps/test/container-app.integ.d.ts +10 -0
  35. package/lib/azure-containerapps/test/container-app.integ.js +119 -0
  36. package/lib/azure-containerapps/test/container-app.spec.d.ts +9 -0
  37. package/lib/azure-containerapps/test/container-app.spec.js +839 -0
  38. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.d.ts +3 -3
  39. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +5 -5
  40. package/lib/azure-diagnosticsettings/test/diagnostic-settings.spec.js +9 -9
  41. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.d.ts +7 -7
  42. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +9 -9
  43. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.d.ts +4 -4
  44. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +6 -6
  45. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.d.ts +4 -4
  46. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +6 -6
  47. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.d.ts +1 -1
  48. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.integ.js +5 -5
  49. package/lib/azure-dnsforwardingruleset/test/dns-forwarding-ruleset.spec.js +11 -11
  50. package/lib/azure-dnsforwardingruleset/test/forwarding-rule.spec.js +14 -14
  51. package/lib/azure-dnsforwardingruleset/test/virtual-network-link.spec.js +12 -12
  52. package/lib/azure-dnsresolver/lib/dns-resolver.d.ts +8 -8
  53. package/lib/azure-dnsresolver/lib/dns-resolver.js +10 -10
  54. package/lib/azure-dnsresolver/lib/inbound-endpoint.d.ts +6 -6
  55. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +8 -8
  56. package/lib/azure-dnsresolver/lib/outbound-endpoint.d.ts +7 -7
  57. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +9 -9
  58. package/lib/azure-dnsresolver/test/dns-resolver.integ.d.ts +1 -1
  59. package/lib/azure-dnsresolver/test/dns-resolver.integ.js +5 -5
  60. package/lib/azure-dnsresolver/test/dns-resolver.spec.js +11 -11
  61. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.d.ts +1 -1
  62. package/lib/azure-dnsresolver/test/inbound-endpoint.integ.js +5 -5
  63. package/lib/azure-dnsresolver/test/inbound-endpoint.spec.js +12 -12
  64. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.d.ts +1 -1
  65. package/lib/azure-dnsresolver/test/outbound-endpoint.integ.js +5 -5
  66. package/lib/azure-dnsresolver/test/outbound-endpoint.spec.js +9 -9
  67. package/lib/azure-dnszone/lib/dns-zone.d.ts +6 -6
  68. package/lib/azure-dnszone/lib/dns-zone.js +8 -8
  69. package/lib/azure-dnszone/lib/records/dns-records.d.ts +31 -31
  70. package/lib/azure-dnszone/lib/records/dns-records.js +42 -42
  71. package/lib/azure-dnszone/test/dns-records.integ.d.ts +1 -1
  72. package/lib/azure-dnszone/test/dns-records.integ.js +5 -5
  73. package/lib/azure-dnszone/test/dns-records.spec.js +57 -57
  74. package/lib/azure-dnszone/test/dns-zone.integ.d.ts +1 -1
  75. package/lib/azure-dnszone/test/dns-zone.integ.js +5 -5
  76. package/lib/azure-dnszone/test/dns-zone.spec.js +11 -11
  77. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +1 -1
  78. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +3 -3
  79. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +1 -1
  80. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +6 -6
  81. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +6 -6
  82. package/lib/azure-metricalert/lib/metric-alert.d.ts +3 -3
  83. package/lib/azure-metricalert/lib/metric-alert.js +5 -5
  84. package/lib/azure-metricalert/test/metric-alert.integ.d.ts +1 -1
  85. package/lib/azure-metricalert/test/metric-alert.integ.js +5 -5
  86. package/lib/azure-metricalert/test/metric-alert.spec.js +9 -9
  87. package/lib/azure-networkinterface/lib/network-interface.d.ts +5 -5
  88. package/lib/azure-networkinterface/lib/network-interface.js +7 -7
  89. package/lib/azure-networkinterface/test/network-interface.integ.d.ts +1 -1
  90. package/lib/azure-networkinterface/test/network-interface.integ.js +5 -5
  91. package/lib/azure-networkinterface/test/network-interface.spec.js +11 -11
  92. package/lib/azure-networksecuritygroup/lib/network-security-group.d.ts +6 -6
  93. package/lib/azure-networksecuritygroup/lib/network-security-group.js +8 -8
  94. package/lib/azure-networksecuritygroup/test/network-security-group.integ.d.ts +1 -1
  95. package/lib/azure-networksecuritygroup/test/network-security-group.integ.js +5 -5
  96. package/lib/azure-networksecuritygroup/test/network-security-group.spec.js +12 -12
  97. package/lib/azure-networkwatcher/lib/network-watcher.d.ts +1 -1
  98. package/lib/azure-networkwatcher/lib/network-watcher.js +3 -3
  99. package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +1 -1
  100. package/lib/azure-networkwatcher/test/network-watcher.integ.js +6 -6
  101. package/lib/azure-networkwatcher/test/network-watcher.spec.js +6 -6
  102. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +3 -3
  103. package/lib/azure-policyassignment/lib/policy-assignment.js +5 -5
  104. package/lib/azure-policyassignment/test/policy-assignment.integ.d.ts +1 -1
  105. package/lib/azure-policyassignment/test/policy-assignment.integ.js +5 -5
  106. package/lib/azure-policyassignment/test/policy-assignment.spec.js +12 -12
  107. package/lib/azure-policydefinition/lib/policy-definition.d.ts +3 -3
  108. package/lib/azure-policydefinition/lib/policy-definition.js +5 -5
  109. package/lib/azure-policydefinition/test/policy-definition.integ.d.ts +1 -1
  110. package/lib/azure-policydefinition/test/policy-definition.integ.js +5 -5
  111. package/lib/azure-policydefinition/test/policy-definition.spec.js +19 -19
  112. package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +1 -1
  113. package/lib/azure-policysetdefinition/lib/policy-set-definition.js +3 -3
  114. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +1 -1
  115. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +6 -6
  116. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +6 -6
  117. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +10 -10
  118. package/lib/azure-privatednszone/lib/private-dns-zone.js +12 -12
  119. package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +25 -25
  120. package/lib/azure-privatednszone/lib/records/private-dns-records.js +34 -34
  121. package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +1 -1
  122. package/lib/azure-privatednszone/test/private-dns-records.integ.js +5 -5
  123. package/lib/azure-privatednszone/test/private-dns-records.spec.js +49 -49
  124. package/lib/azure-privatednszone/test/private-dns-zone.integ.d.ts +1 -1
  125. package/lib/azure-privatednszone/test/private-dns-zone.integ.js +5 -5
  126. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +12 -12
  127. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.d.ts +6 -6
  128. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +8 -8
  129. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.d.ts +1 -1
  130. package/lib/azure-privatednszonelink/test/private-dns-zone-link.integ.js +5 -5
  131. package/lib/azure-privatednszonelink/test/private-dns-zone-link.spec.js +12 -12
  132. package/lib/azure-publicipaddress/lib/public-ip-address.d.ts +5 -5
  133. package/lib/azure-publicipaddress/lib/public-ip-address.js +7 -7
  134. package/lib/azure-publicipaddress/test/public-ip-address.integ.d.ts +1 -1
  135. package/lib/azure-publicipaddress/test/public-ip-address.integ.js +6 -6
  136. package/lib/azure-publicipaddress/test/public-ip-address.spec.js +11 -11
  137. package/lib/azure-resourcegroup/lib/resource-group.d.ts +5 -5
  138. package/lib/azure-resourcegroup/lib/resource-group.js +7 -7
  139. package/lib/azure-resourcegroup/test/resource-group.integ.d.ts +1 -1
  140. package/lib/azure-resourcegroup/test/resource-group.integ.js +5 -5
  141. package/lib/azure-resourcegroup/test/resource-group.spec.js +14 -14
  142. package/lib/azure-roleassignment/lib/role-assignment.d.ts +3 -3
  143. package/lib/azure-roleassignment/lib/role-assignment.js +5 -5
  144. package/lib/azure-roleassignment/test/role-assignment.integ.d.ts +1 -1
  145. package/lib/azure-roleassignment/test/role-assignment.integ.js +5 -5
  146. package/lib/azure-roleassignment/test/role-assignment.spec.js +12 -12
  147. package/lib/azure-roledefinition/lib/role-definition.d.ts +3 -3
  148. package/lib/azure-roledefinition/lib/role-definition.js +5 -5
  149. package/lib/azure-roledefinition/test/role-definition.integ.d.ts +1 -1
  150. package/lib/azure-roledefinition/test/role-definition.integ.js +5 -5
  151. package/lib/azure-roledefinition/test/role-definition.spec.js +12 -12
  152. package/lib/azure-storageaccount/lib/storage-account.d.ts +6 -6
  153. package/lib/azure-storageaccount/lib/storage-account.js +8 -8
  154. package/lib/azure-storageaccount/test/storage-account.integ.d.ts +1 -1
  155. package/lib/azure-storageaccount/test/storage-account.integ.js +5 -5
  156. package/lib/azure-storageaccount/test/storage-account.spec.js +11 -11
  157. package/lib/azure-subnet/lib/subnet.d.ts +3 -3
  158. package/lib/azure-subnet/lib/subnet.js +5 -5
  159. package/lib/azure-subnet/test/subnet.integ.d.ts +1 -1
  160. package/lib/azure-subnet/test/subnet.integ.js +5 -5
  161. package/lib/azure-subnet/test/subnet.spec.js +9 -9
  162. package/lib/azure-virtualmachine/lib/virtual-machine.d.ts +6 -6
  163. package/lib/azure-virtualmachine/lib/virtual-machine.js +8 -8
  164. package/lib/azure-virtualmachine/test/virtual-machine.integ.d.ts +1 -1
  165. package/lib/azure-virtualmachine/test/virtual-machine.integ.js +5 -5
  166. package/lib/azure-virtualmachine/test/virtual-machine.spec.js +17 -17
  167. package/lib/azure-virtualnetwork/lib/virtual-network.d.ts +6 -6
  168. package/lib/azure-virtualnetwork/lib/virtual-network.js +8 -8
  169. package/lib/azure-virtualnetwork/test/virtual-network.integ.d.ts +1 -1
  170. package/lib/azure-virtualnetwork/test/virtual-network.integ.js +5 -5
  171. package/lib/azure-virtualnetwork/test/virtual-network.spec.js +12 -12
  172. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +5 -5
  173. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +7 -7
  174. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.d.ts +1 -1
  175. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.js +5 -5
  176. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +13 -13
  177. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.d.ts +5 -5
  178. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +7 -7
  179. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.integ.d.ts +1 -1
  180. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.integ.js +5 -5
  181. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.spec.js +20 -20
  182. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.d.ts +4 -4
  183. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +6 -6
  184. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +4 -4
  185. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +6 -6
  186. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +4 -4
  187. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +6 -6
  188. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.d.ts +4 -4
  189. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +6 -6
  190. package/lib/azure-virtualnetworkmanager/lib/network-group.d.ts +4 -4
  191. package/lib/azure-virtualnetworkmanager/lib/network-group.js +6 -6
  192. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.d.ts +4 -4
  193. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +6 -6
  194. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.d.ts +4 -4
  195. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +6 -6
  196. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.d.ts +4 -4
  197. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +6 -6
  198. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +7 -7
  199. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +9 -9
  200. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +17 -17
  201. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +15 -15
  202. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +1 -1
  203. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +5 -5
  204. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +57 -57
  205. package/lib/azure-vmss/lib/virtual-machine-scale-set.d.ts +6 -6
  206. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +8 -8
  207. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.d.ts +1 -1
  208. package/lib/azure-vmss/test/virtual-machine-scale-set.integ.js +5 -5
  209. package/lib/azure-vmss/test/virtual-machine-scale-set.spec.js +12 -12
  210. package/lib/core-azure/lib/azapi/azapi-resource-tags.spec.js +6 -6
  211. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +7 -7
  212. package/lib/core-azure/lib/azapi/azapi-resource.js +6 -6
  213. package/lib/core-azure/lib/azapi/azapi-resource.spec.js +7 -7
  214. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.d.ts +12 -12
  215. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +15 -15
  216. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.d.ts +35 -35
  217. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +58 -58
  218. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.d.ts +25 -25
  219. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-action/index.js +49 -49
  220. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.d.ts +13 -13
  221. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-id/index.js +22 -22
  222. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.d.ts +24 -24
  223. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource-list/index.js +40 -40
  224. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.d.ts +44 -44
  225. package/lib/core-azure/lib/azapi/providers-azapi/data-plane-resource/index.js +72 -72
  226. package/lib/core-azure/lib/azapi/providers-azapi/index.js +2 -2
  227. package/lib/core-azure/lib/azapi/providers-azapi/lazy-index.js +2 -2
  228. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.d.ts +54 -54
  229. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +86 -86
  230. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.d.ts +65 -65
  231. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +102 -102
  232. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.d.ts +25 -25
  233. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +62 -62
  234. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.d.ts +36 -36
  235. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +69 -69
  236. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  237. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  238. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  239. package/lib/index.d.ts +3 -0
  240. package/lib/index.js +5 -2
  241. package/lib/testing/index.d.ts +1 -1
  242. package/lib/testing/index.js +8 -8
  243. package/lib/testing/lib/cleanup.js +1 -1
  244. package/lib/testing/lib/metadata.js +1 -1
  245. package/package.json +10 -22
  246. package/setup.js +2 -2
@@ -0,0 +1,310 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.ContainerAppEnvironment = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure Container App Managed Environment implementation using AzapiResource 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
+ * - 2024-03-01 (Active)
15
+ * - 2025-07-01 (Active, Latest)
16
+ *
17
+ * Features:
18
+ * - Automatic latest version resolution when no version is specified
19
+ * - Explicit version pinning for stability requirements
20
+ * - Schema-driven validation and transformation
21
+ * - Full backward compatibility with existing interface
22
+ * - JSII compliance for multi-language support
23
+ * - Log Analytics and Azure Monitor integration
24
+ * - VNet injection for network isolation
25
+ * - Workload profiles for compute customization
26
+ * - Zone redundancy for high availability
27
+ * - Peer authentication (mTLS) and traffic encryption (2025-07-01+)
28
+ */
29
+ const cdktn = require("cdktn");
30
+ const container_app_environment_schemas_1 = require("./container-app-environment-schemas");
31
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
32
+ // =============================================================================
33
+ // MAIN CLASS
34
+ // =============================================================================
35
+ /**
36
+ * Unified Azure Container App Managed Environment implementation
37
+ *
38
+ * Azure Container App Environments provide the hosting infrastructure for
39
+ * Container Apps. They manage the underlying Kubernetes cluster, networking,
40
+ * and observability resources.
41
+ *
42
+ * Key features:
43
+ * - Log Analytics and Azure Monitor integration for observability
44
+ * - VNet injection for network isolation
45
+ * - Workload profiles for compute customization (Consumption, Dedicated)
46
+ * - Zone redundancy for high availability
47
+ * - Custom domain support
48
+ * - Dapr integration for microservice patterns
49
+ * - Peer authentication (mTLS) and traffic encryption (2025-07-01+)
50
+ *
51
+ * @example
52
+ * // Basic environment with Log Analytics:
53
+ * const environment = new ContainerAppEnvironment(this, "env", {
54
+ * name: "my-container-env",
55
+ * location: "eastus",
56
+ * resourceGroupId: resourceGroup.id,
57
+ * appLogsConfiguration: {
58
+ * destination: "log-analytics",
59
+ * logAnalyticsConfiguration: {
60
+ * customerId: logAnalytics.workspaceId,
61
+ * sharedKey: logAnalytics.primarySharedKey,
62
+ * },
63
+ * },
64
+ * });
65
+ *
66
+ * @example
67
+ * // Environment with VNet injection and zone redundancy:
68
+ * const environment = new ContainerAppEnvironment(this, "env", {
69
+ * name: "my-container-env",
70
+ * location: "eastus",
71
+ * resourceGroupId: resourceGroup.id,
72
+ * vnetConfiguration: {
73
+ * infrastructureSubnetId: subnet.id,
74
+ * internal: true,
75
+ * },
76
+ * zoneRedundant: true,
77
+ * });
78
+ *
79
+ * @stability stable
80
+ */
81
+ class ContainerAppEnvironment extends azapi_resource_1.AzapiResource {
82
+ /**
83
+ * Creates a new Azure Container App Managed Environment
84
+ *
85
+ * @param scope - The scope in which to define this construct
86
+ * @param id - The unique identifier for this instance
87
+ * @param props - Configuration properties for the Container App Environment
88
+ */
89
+ constructor(scope, id, props) {
90
+ super(scope, id, props);
91
+ this.props = props;
92
+ // Create Terraform outputs
93
+ this.idOutput = new cdktn.TerraformOutput(this, "id", {
94
+ value: this.id,
95
+ description: "The ID of the Container App Environment",
96
+ });
97
+ this.locationOutput = new cdktn.TerraformOutput(this, "location", {
98
+ value: `\${${this.terraformResource.fqn}.location}`,
99
+ description: "The location of the Container App Environment",
100
+ });
101
+ this.nameOutput = new cdktn.TerraformOutput(this, "name", {
102
+ value: `\${${this.terraformResource.fqn}.name}`,
103
+ description: "The name of the Container App Environment",
104
+ });
105
+ this.tagsOutput = new cdktn.TerraformOutput(this, "tags", {
106
+ value: `\${${this.terraformResource.fqn}.tags}`,
107
+ description: "The tags assigned to the Container App Environment",
108
+ });
109
+ this.defaultDomainOutput = new cdktn.TerraformOutput(this, "default_domain", {
110
+ value: `\${${this.terraformResource.fqn}.output.properties.defaultDomain}`,
111
+ description: "The default domain of the Container App Environment",
112
+ });
113
+ this.staticIpOutput = new cdktn.TerraformOutput(this, "static_ip", {
114
+ value: `\${${this.terraformResource.fqn}.output.properties.staticIp}`,
115
+ description: "The static IP of the Container App Environment",
116
+ });
117
+ this.provisioningStateOutput = new cdktn.TerraformOutput(this, "provisioning_state", {
118
+ value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
119
+ description: "The provisioning state of the Container App Environment",
120
+ });
121
+ // Override logical IDs
122
+ this.idOutput.overrideLogicalId("id");
123
+ this.locationOutput.overrideLogicalId("location");
124
+ this.nameOutput.overrideLogicalId("name");
125
+ this.tagsOutput.overrideLogicalId("tags");
126
+ this.defaultDomainOutput.overrideLogicalId("default_domain");
127
+ this.staticIpOutput.overrideLogicalId("static_ip");
128
+ this.provisioningStateOutput.overrideLogicalId("provisioning_state");
129
+ // Apply ignore changes if specified
130
+ this._applyIgnoreChanges();
131
+ }
132
+ // =============================================================================
133
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
134
+ // =============================================================================
135
+ /**
136
+ * Gets the default API version to use when no explicit version is specified
137
+ */
138
+ defaultVersion() {
139
+ return "2025-02-02-preview";
140
+ }
141
+ /**
142
+ * Gets the Azure resource type for Container App Environments
143
+ */
144
+ resourceType() {
145
+ return container_app_environment_schemas_1.CONTAINER_APP_ENVIRONMENT_TYPE;
146
+ }
147
+ /**
148
+ * Gets the API schema for the resolved version
149
+ */
150
+ apiSchema() {
151
+ return this.resolveSchema();
152
+ }
153
+ /**
154
+ * Indicates that location is required for Container App Environments
155
+ */
156
+ requiresLocation() {
157
+ return true;
158
+ }
159
+ /**
160
+ * Creates the resource body for the Azure API call
161
+ */
162
+ createResourceBody(props) {
163
+ const typedProps = props;
164
+ const properties = {};
165
+ // App logs configuration
166
+ if (typedProps.appLogsConfiguration) {
167
+ properties.appLogsConfiguration = typedProps.appLogsConfiguration;
168
+ }
169
+ // VNet configuration
170
+ if (typedProps.vnetConfiguration) {
171
+ properties.vnetConfiguration = typedProps.vnetConfiguration;
172
+ }
173
+ // Workload profiles
174
+ if (typedProps.workloadProfiles) {
175
+ properties.workloadProfiles = typedProps.workloadProfiles;
176
+ }
177
+ // Zone redundancy
178
+ if (typedProps.zoneRedundant !== undefined) {
179
+ properties.zoneRedundant = typedProps.zoneRedundant;
180
+ }
181
+ // Dapr AI instrumentation key
182
+ if (typedProps.daprAIInstrumentationKey) {
183
+ properties.daprAIInstrumentationKey = typedProps.daprAIInstrumentationKey;
184
+ }
185
+ // Dapr AI connection string
186
+ if (typedProps.daprAIConnectionString) {
187
+ properties.daprAIConnectionString = typedProps.daprAIConnectionString;
188
+ }
189
+ // Custom domain configuration
190
+ if (typedProps.customDomainConfiguration) {
191
+ properties.customDomainConfiguration =
192
+ typedProps.customDomainConfiguration;
193
+ }
194
+ // Infrastructure resource group
195
+ if (typedProps.infrastructureResourceGroup) {
196
+ properties.infrastructureResourceGroup =
197
+ typedProps.infrastructureResourceGroup;
198
+ }
199
+ // 2025-07-01+ properties
200
+ if (typedProps.peerAuthentication) {
201
+ properties.peerAuthentication = typedProps.peerAuthentication;
202
+ }
203
+ if (typedProps.peerTrafficConfiguration) {
204
+ properties.peerTrafficConfiguration = typedProps.peerTrafficConfiguration;
205
+ }
206
+ if (typedProps.ingressConfiguration) {
207
+ properties.ingressConfiguration = typedProps.ingressConfiguration;
208
+ }
209
+ if (typedProps.publicNetworkAccess) {
210
+ properties.publicNetworkAccess = typedProps.publicNetworkAccess;
211
+ }
212
+ const body = {
213
+ location: this.location,
214
+ tags: this.allTags(),
215
+ properties: Object.keys(properties).length > 0 ? properties : undefined,
216
+ };
217
+ return body;
218
+ }
219
+ // =============================================================================
220
+ // PUBLIC METHODS
221
+ // =============================================================================
222
+ /**
223
+ * Get the default domain of the Container App Environment
224
+ */
225
+ get defaultDomain() {
226
+ return `\${${this.terraformResource.fqn}.output.properties.defaultDomain}`;
227
+ }
228
+ /**
229
+ * Get the static IP of the Container App Environment
230
+ */
231
+ get staticIp() {
232
+ return `\${${this.terraformResource.fqn}.output.properties.staticIp}`;
233
+ }
234
+ /**
235
+ * Get the provisioning state of the Container App Environment
236
+ */
237
+ get provisioningState() {
238
+ return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
239
+ }
240
+ /**
241
+ * Add a tag to the Container App Environment
242
+ */
243
+ addTag(key, value) {
244
+ if (!this.props.tags) {
245
+ this.props.tags = {};
246
+ }
247
+ this.props.tags[key] = value;
248
+ }
249
+ /**
250
+ * Remove a tag from the Container App Environment
251
+ */
252
+ removeTag(key) {
253
+ if (this.props.tags && this.props.tags[key]) {
254
+ delete this.props.tags[key];
255
+ }
256
+ }
257
+ // =============================================================================
258
+ // RESOURCE CONFIG CUSTOMIZATION
259
+ // =============================================================================
260
+ /**
261
+ * Customizes the resource configuration to handle Azure value normalization.
262
+ *
263
+ * Azure normalizes values in API responses:
264
+ * - Location: "eastus" → "East US"
265
+ * - Enum values: "auto" → "Auto", "enabled" → "Enabled"
266
+ *
267
+ * This override:
268
+ * 1. Removes `location` from the body (the framework passes it as a top-level
269
+ * attribute which the azapi provider normalizes properly)
270
+ * 2. Enables `ignoreCasing` to suppress diffs from Azure's value normalization
271
+ * (e.g., "auto" vs "Auto" for transport, "enabled" vs "Enabled")
272
+ */
273
+ customizeResourceConfig(config) {
274
+ const updatedConfig = { ...config, ignoreCasing: true };
275
+ // Remove location from body to prevent "East US" vs "eastus" drift
276
+ // The framework handles location as a top-level azapi attribute instead
277
+ if (updatedConfig.body && updatedConfig.body.location) {
278
+ const { location: _location, ...bodyWithoutLocation } = updatedConfig.body;
279
+ return {
280
+ ...updatedConfig,
281
+ body: bodyWithoutLocation,
282
+ // Ensure location is set as top-level attribute
283
+ location: updatedConfig.location || _location,
284
+ };
285
+ }
286
+ return updatedConfig;
287
+ }
288
+ // =============================================================================
289
+ // PRIVATE HELPER METHODS
290
+ // =============================================================================
291
+ /**
292
+ * Applies ignore changes lifecycle rules if specified in props
293
+ */
294
+ _applyIgnoreChanges() {
295
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
296
+ this.terraformResource.addOverride("lifecycle", [
297
+ {
298
+ ignore_changes: this.props.ignoreChanges,
299
+ },
300
+ ]);
301
+ }
302
+ }
303
+ }
304
+ exports.ContainerAppEnvironment = ContainerAppEnvironment;
305
+ _a = JSII_RTTI_SYMBOL_1;
306
+ ContainerAppEnvironment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.ContainerAppEnvironment", version: "2.2.0" };
307
+ (() => {
308
+ azapi_resource_1.AzapiResource.registerSchemas(container_app_environment_schemas_1.CONTAINER_APP_ENVIRONMENT_TYPE, container_app_environment_schemas_1.ALL_CONTAINER_APP_ENVIRONMENT_VERSIONS);
309
+ })();
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"container-app-environment.js","sourceRoot":"","sources":["../../../src/azure-containerapps/lib/container-app-environment.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Container App Managed Environment implementation using AzapiResource 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 * - 2024-03-01 (Active)\n * - 2025-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 * - Log Analytics and Azure Monitor integration\n * - VNet injection for network isolation\n * - Workload profiles for compute customization\n * - Zone redundancy for high availability\n * - Peer authentication (mTLS) and traffic encryption (2025-07-01+)\n */\n\nimport * as cdktn from \"cdktn\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_CONTAINER_APP_ENVIRONMENT_VERSIONS,\n  CONTAINER_APP_ENVIRONMENT_TYPE,\n} from \"./container-app-environment-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// SUPPORTING INTERFACES\n// =============================================================================\n\n/**\n * Log Analytics configuration for the Container App Environment\n */\nexport interface ContainerAppEnvironmentLogAnalyticsConfig {\n  /**\n   * Log Analytics workspace customer ID (workspace ID)\n   */\n  readonly customerId: string;\n\n  /**\n   * Log Analytics workspace shared key\n   */\n  readonly sharedKey: string;\n}\n\n/**\n * Application logs configuration for the Container App Environment\n */\nexport interface ContainerAppEnvironmentAppLogsConfig {\n  /**\n   * Logs destination. Can be 'log-analytics', 'azure-monitor', or 'none'.\n   * @default \"log-analytics\"\n   */\n  readonly destination?: string;\n\n  /**\n   * Log Analytics configuration. Required when destination is 'log-analytics'.\n   */\n  readonly logAnalyticsConfiguration?: ContainerAppEnvironmentLogAnalyticsConfig;\n}\n\n/**\n * VNet configuration for the Container App Environment\n */\nexport interface ContainerAppEnvironmentVnetConfig {\n  /**\n   * Resource ID of a subnet for infrastructure components.\n   * Must be at least /21 for consumption-only environments or /23 for workload profile environments.\n   */\n  readonly infrastructureSubnetId?: string;\n\n  /**\n   * Whether the environment only has an internal load balancer (no public endpoint).\n   * @default false\n   */\n  readonly internal?: boolean;\n}\n\n/**\n * Workload profile configuration\n */\nexport interface ContainerAppEnvironmentWorkloadProfile {\n  /**\n   * Friendly name of the workload profile\n   */\n  readonly name: string;\n\n  /**\n   * Workload profile type. Values include 'Consumption', 'GeneralPurpose',\n   * 'MemoryOptimized', 'ComputeOptimized', 'D4', 'D8', 'D16', 'D32',\n   * 'E4', 'E8', 'E16', 'E32'.\n   */\n  readonly workloadProfileType: string;\n\n  /**\n   * Minimum number of instances for this workload profile (not applicable for Consumption).\n   */\n  readonly minimumCount?: number;\n\n  /**\n   * Maximum number of instances for this workload profile (not applicable for Consumption).\n   */\n  readonly maximumCount?: number;\n}\n\n/**\n * Custom domain configuration for the environment\n */\nexport interface ContainerAppEnvironmentCustomDomainConfig {\n  /**\n   * Custom DNS suffix for the environment\n   */\n  readonly dnsSuffix?: string;\n\n  /**\n   * PFX or PEM certificate value (base64 encoded)\n   */\n  readonly certificateValue?: string;\n\n  /**\n   * Certificate password\n   */\n  readonly certificatePassword?: string;\n}\n\n/**\n * Mutual TLS settings for peer authentication\n */\nexport interface ContainerAppEnvironmentMtlsConfig {\n  /**\n   * Whether mTLS is enabled\n   */\n  readonly enabled?: boolean;\n}\n\n/**\n * Peer authentication settings (mTLS) for the Managed Environment.\n * Available in API version 2025-07-01+.\n */\nexport interface ContainerAppEnvironmentPeerAuthentication {\n  /**\n   * Mutual TLS settings\n   */\n  readonly mtls?: ContainerAppEnvironmentMtlsConfig;\n}\n\n/**\n * Encryption settings for peer traffic\n */\nexport interface ContainerAppEnvironmentEncryptionConfig {\n  /**\n   * Whether encryption is enabled\n   */\n  readonly enabled?: boolean;\n}\n\n/**\n * Peer traffic encryption settings for the Managed Environment.\n * Available in API version 2025-07-01+.\n */\nexport interface ContainerAppEnvironmentPeerTrafficConfig {\n  /**\n   * Encryption settings\n   */\n  readonly encryption?: ContainerAppEnvironmentEncryptionConfig;\n}\n\n/**\n * Ingress configuration settings for the Managed Environment.\n * Available in API version 2025-07-01+.\n */\nexport interface ContainerAppEnvironmentIngressConfig {\n  /**\n   * Workload profile name for the ingress component\n   */\n  readonly workloadProfileName?: string;\n\n  /**\n   * Termination grace period in seconds\n   */\n  readonly terminationGracePeriodSeconds?: number;\n\n  /**\n   * Header count limit\n   */\n  readonly headerCountLimit?: number;\n\n  /**\n   * Request idle timeout in seconds\n   */\n  readonly requestIdleTimeout?: number;\n}\n\n// =============================================================================\n// MAIN PROPS INTERFACE\n// =============================================================================\n\n/**\n * Properties for the unified Azure Container App Environment\n *\n * Extends AzapiResourceProps with Container App Environment specific properties\n */\nexport interface ContainerAppEnvironmentProps extends AzapiResourceProps {\n  /**\n   * Application logs configuration\n   */\n  readonly appLogsConfiguration?: ContainerAppEnvironmentAppLogsConfig;\n\n  /**\n   * VNet configuration for the environment\n   */\n  readonly vnetConfiguration?: ContainerAppEnvironmentVnetConfig;\n\n  /**\n   * Workload profiles configured for the Managed Environment\n   */\n  readonly workloadProfiles?: ContainerAppEnvironmentWorkloadProfile[];\n\n  /**\n   * Whether or not this Managed Environment is zone-redundant.\n   * @default false\n   */\n  readonly zoneRedundant?: boolean;\n\n  /**\n   * Azure Monitor instrumentation key used by Dapr to export\n   * Service to Service communication telemetry\n   */\n  readonly daprAIInstrumentationKey?: string;\n\n  /**\n   * Application Insights connection string used by Dapr to export\n   * Service to Service communication telemetry\n   */\n  readonly daprAIConnectionString?: string;\n\n  /**\n   * Custom domain configuration for the environment\n   */\n  readonly customDomainConfiguration?: ContainerAppEnvironmentCustomDomainConfig;\n\n  /**\n   * Name of the platform-managed resource group created for the Managed Environment\n   * to host infrastructure resources.\n   */\n  readonly infrastructureResourceGroup?: string;\n\n  /**\n   * Peer authentication settings for the Managed Environment (mTLS).\n   * Available in API version 2025-07-01+.\n   */\n  readonly peerAuthentication?: ContainerAppEnvironmentPeerAuthentication;\n\n  /**\n   * Peer traffic settings for the Managed Environment (encryption).\n   * Available in API version 2025-07-01+.\n   */\n  readonly peerTrafficConfiguration?: ContainerAppEnvironmentPeerTrafficConfig;\n\n  /**\n   * Ingress configuration for the Managed Environment.\n   * Available in API version 2025-07-01+.\n   */\n  readonly ingressConfiguration?: ContainerAppEnvironmentIngressConfig;\n\n  /**\n   * Property to allow or block all public traffic.\n   * Allowed Values: 'Enabled', 'Disabled'.\n   * Available in API version 2025-07-01+.\n   */\n  readonly publicNetworkAccess?: 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 Container App Environment will be created\n   */\n  readonly resourceGroupId?: string;\n}\n\n/**\n * The resource body interface for Azure Container App Environment API calls\n */\nexport interface ContainerAppEnvironmentBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties?: any;\n}\n\n// =============================================================================\n// MAIN CLASS\n// =============================================================================\n\n/**\n * Unified Azure Container App Managed Environment implementation\n *\n * Azure Container App Environments provide the hosting infrastructure for\n * Container Apps. They manage the underlying Kubernetes cluster, networking,\n * and observability resources.\n *\n * Key features:\n * - Log Analytics and Azure Monitor integration for observability\n * - VNet injection for network isolation\n * - Workload profiles for compute customization (Consumption, Dedicated)\n * - Zone redundancy for high availability\n * - Custom domain support\n * - Dapr integration for microservice patterns\n * - Peer authentication (mTLS) and traffic encryption (2025-07-01+)\n *\n * @example\n * // Basic environment with Log Analytics:\n * const environment = new ContainerAppEnvironment(this, \"env\", {\n *   name: \"my-container-env\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   appLogsConfiguration: {\n *     destination: \"log-analytics\",\n *     logAnalyticsConfiguration: {\n *       customerId: logAnalytics.workspaceId,\n *       sharedKey: logAnalytics.primarySharedKey,\n *     },\n *   },\n * });\n *\n * @example\n * // Environment with VNet injection and zone redundancy:\n * const environment = new ContainerAppEnvironment(this, \"env\", {\n *   name: \"my-container-env\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   vnetConfiguration: {\n *     infrastructureSubnetId: subnet.id,\n *     internal: true,\n *   },\n *   zoneRedundant: true,\n * });\n *\n * @stability stable\n */\nexport class ContainerAppEnvironment extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      CONTAINER_APP_ENVIRONMENT_TYPE,\n      ALL_CONTAINER_APP_ENVIRONMENT_VERSIONS,\n    );\n  }\n\n  public readonly props: ContainerAppEnvironmentProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktn.TerraformOutput;\n  public readonly locationOutput: cdktn.TerraformOutput;\n  public readonly nameOutput: cdktn.TerraformOutput;\n  public readonly tagsOutput: cdktn.TerraformOutput;\n  public readonly defaultDomainOutput: cdktn.TerraformOutput;\n  public readonly staticIpOutput: cdktn.TerraformOutput;\n  public readonly provisioningStateOutput: cdktn.TerraformOutput;\n\n  /**\n   * Creates a new Azure Container App Managed Environment\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 Container App Environment\n   */\n  constructor(\n    scope: Construct,\n    id: string,\n    props: ContainerAppEnvironmentProps,\n  ) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Create Terraform outputs\n    this.idOutput = new cdktn.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Container App Environment\",\n    });\n\n    this.locationOutput = new cdktn.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Container App Environment\",\n    });\n\n    this.nameOutput = new cdktn.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Container App Environment\",\n    });\n\n    this.tagsOutput = new cdktn.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Container App Environment\",\n    });\n\n    this.defaultDomainOutput = new cdktn.TerraformOutput(\n      this,\n      \"default_domain\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.defaultDomain}`,\n        description: \"The default domain of the Container App Environment\",\n      },\n    );\n\n    this.staticIpOutput = new cdktn.TerraformOutput(this, \"static_ip\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.staticIp}`,\n      description: \"The static IP of the Container App Environment\",\n    });\n\n    this.provisioningStateOutput = new cdktn.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description: \"The provisioning state of the Container App Environment\",\n      },\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.defaultDomainOutput.overrideLogicalId(\"default_domain\");\n    this.staticIpOutput.overrideLogicalId(\"static_ip\");\n    this.provisioningStateOutput.overrideLogicalId(\"provisioning_state\");\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 \"2025-02-02-preview\";\n  }\n\n  /**\n   * Gets the Azure resource type for Container App Environments\n   */\n  protected resourceType(): string {\n    return CONTAINER_APP_ENVIRONMENT_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 Container App Environments\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 ContainerAppEnvironmentProps;\n\n    const properties: any = {};\n\n    // App logs configuration\n    if (typedProps.appLogsConfiguration) {\n      properties.appLogsConfiguration = typedProps.appLogsConfiguration;\n    }\n\n    // VNet configuration\n    if (typedProps.vnetConfiguration) {\n      properties.vnetConfiguration = typedProps.vnetConfiguration;\n    }\n\n    // Workload profiles\n    if (typedProps.workloadProfiles) {\n      properties.workloadProfiles = typedProps.workloadProfiles;\n    }\n\n    // Zone redundancy\n    if (typedProps.zoneRedundant !== undefined) {\n      properties.zoneRedundant = typedProps.zoneRedundant;\n    }\n\n    // Dapr AI instrumentation key\n    if (typedProps.daprAIInstrumentationKey) {\n      properties.daprAIInstrumentationKey = typedProps.daprAIInstrumentationKey;\n    }\n\n    // Dapr AI connection string\n    if (typedProps.daprAIConnectionString) {\n      properties.daprAIConnectionString = typedProps.daprAIConnectionString;\n    }\n\n    // Custom domain configuration\n    if (typedProps.customDomainConfiguration) {\n      properties.customDomainConfiguration =\n        typedProps.customDomainConfiguration;\n    }\n\n    // Infrastructure resource group\n    if (typedProps.infrastructureResourceGroup) {\n      properties.infrastructureResourceGroup =\n        typedProps.infrastructureResourceGroup;\n    }\n\n    // 2025-07-01+ properties\n    if (typedProps.peerAuthentication) {\n      properties.peerAuthentication = typedProps.peerAuthentication;\n    }\n\n    if (typedProps.peerTrafficConfiguration) {\n      properties.peerTrafficConfiguration = typedProps.peerTrafficConfiguration;\n    }\n\n    if (typedProps.ingressConfiguration) {\n      properties.ingressConfiguration = typedProps.ingressConfiguration;\n    }\n\n    if (typedProps.publicNetworkAccess) {\n      properties.publicNetworkAccess = typedProps.publicNetworkAccess;\n    }\n\n    const body: ContainerAppEnvironmentBody = {\n      location: this.location!,\n      tags: this.allTags(),\n      properties: Object.keys(properties).length > 0 ? properties : undefined,\n    };\n\n    return body;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS\n  // =============================================================================\n\n  /**\n   * Get the default domain of the Container App Environment\n   */\n  public get defaultDomain(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.defaultDomain}`;\n  }\n\n  /**\n   * Get the static IP of the Container App Environment\n   */\n  public get staticIp(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.staticIp}`;\n  }\n\n  /**\n   * Get the provisioning state of the Container App Environment\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\n  }\n\n  /**\n   * Add a tag to the Container App Environment\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 Container App Environment\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  // RESOURCE CONFIG CUSTOMIZATION\n  // =============================================================================\n\n  /**\n   * Customizes the resource configuration to handle Azure value normalization.\n   *\n   * Azure normalizes values in API responses:\n   * - Location: \"eastus\" → \"East US\"\n   * - Enum values: \"auto\" → \"Auto\", \"enabled\" → \"Enabled\"\n   *\n   * This override:\n   * 1. Removes `location` from the body (the framework passes it as a top-level\n   *    attribute which the azapi provider normalizes properly)\n   * 2. Enables `ignoreCasing` to suppress diffs from Azure's value normalization\n   *    (e.g., \"auto\" vs \"Auto\" for transport, \"enabled\" vs \"Enabled\")\n   */\n  protected customizeResourceConfig(config: any): any {\n    const updatedConfig = { ...config, ignoreCasing: true };\n\n    // Remove location from body to prevent \"East US\" vs \"eastus\" drift\n    // The framework handles location as a top-level azapi attribute instead\n    if (updatedConfig.body && updatedConfig.body.location) {\n      const { location: _location, ...bodyWithoutLocation } =\n        updatedConfig.body;\n      return {\n        ...updatedConfig,\n        body: bodyWithoutLocation,\n        // Ensure location is set as top-level attribute\n        location: updatedConfig.location || _location,\n      };\n    }\n    return updatedConfig;\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,48 @@
1
+ /**
2
+ * API schemas for Azure Container App across all supported versions
3
+ *
4
+ * This file defines the complete API schemas for Microsoft.App/containerApps
5
+ * across all supported API versions. The schemas are used by the AzapiResource
6
+ * framework for validation, transformation, and version management.
7
+ *
8
+ * Supported API Versions:
9
+ * - 2024-03-01 (Active)
10
+ * - 2025-02-02-preview (Active, Latest azapi-compatible)
11
+ * - 2025-07-01 (Active, Latest)
12
+ */
13
+ import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
14
+ /**
15
+ * API Schema for Container App version 2024-03-01
16
+ */
17
+ export declare const CONTAINER_APP_SCHEMA_2024_03_01: ApiSchema;
18
+ /**
19
+ * API Schema for Container App version 2025-07-01
20
+ */
21
+ export declare const CONTAINER_APP_SCHEMA_2025_07_01: ApiSchema;
22
+ /**
23
+ * API Schema for Container App version 2025-02-02-preview
24
+ *
25
+ * This is the latest version supported by the azapi provider ~> 2.7.0.
26
+ * It has the same properties as 2024-03-01 with additional preview features.
27
+ */
28
+ export declare const CONTAINER_APP_SCHEMA_2025_02_02_PREVIEW: ApiSchema;
29
+ /**
30
+ * Version configuration for Container App 2024-03-01
31
+ */
32
+ export declare const CONTAINER_APP_VERSION_2024_03_01: VersionConfig;
33
+ /**
34
+ * Version configuration for Container App 2025-02-02-preview
35
+ */
36
+ export declare const CONTAINER_APP_VERSION_2025_02_02_PREVIEW: VersionConfig;
37
+ /**
38
+ * Version configuration for Container App 2025-07-01
39
+ */
40
+ export declare const CONTAINER_APP_VERSION_2025_07_01: VersionConfig;
41
+ /**
42
+ * All supported Container App versions for registration
43
+ */
44
+ export declare const ALL_CONTAINER_APP_VERSIONS: VersionConfig[];
45
+ /**
46
+ * Resource type constant
47
+ */
48
+ export declare const CONTAINER_APP_TYPE = "Microsoft.App/containerApps";