@microsoft/terraform-cdk-constructs 1.3.1 → 1.5.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 (86) hide show
  1. package/.jsii +32238 -27310
  2. package/API.md +43714 -35942
  3. package/lib/azure-actiongroup/lib/action-group.js +1 -1
  4. package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
  5. package/lib/azure-aks/lib/aks-cluster.js +1 -1
  6. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
  7. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
  8. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
  9. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
  10. package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
  11. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
  12. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
  13. package/lib/azure-dnszone/lib/dns-zone.js +1 -1
  14. package/lib/azure-metricalert/lib/metric-alert.js +1 -1
  15. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  16. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  17. package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
  18. package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
  19. package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
  20. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  21. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  22. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  23. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  24. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  25. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  26. package/lib/azure-subnet/lib/subnet.js +1 -1
  27. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  28. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  29. package/lib/azure-virtualnetworkgateway/index.d.ts +4 -0
  30. package/lib/azure-virtualnetworkgateway/index.js +21 -0
  31. package/lib/azure-virtualnetworkgateway/lib/index.d.ts +5 -0
  32. package/lib/azure-virtualnetworkgateway/lib/index.js +22 -0
  33. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.d.ts +32 -0
  34. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +298 -0
  35. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +368 -0
  36. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +285 -0
  37. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.d.ts +12 -0
  38. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.js +129 -0
  39. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.d.ts +8 -0
  40. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +691 -0
  41. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  42. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
  43. package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
  44. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
  45. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
  46. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
  47. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
  48. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
  49. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
  50. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
  51. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
  52. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  53. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  54. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  55. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  56. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  57. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.d.ts +225 -0
  58. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
  59. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
  60. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
  61. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
  62. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
  63. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
  64. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
  65. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
  66. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
  67. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
  68. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
  69. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
  70. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  71. package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
  72. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  73. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  74. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  75. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  76. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  77. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  78. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  79. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  80. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  81. package/lib/index.d.ts +2 -0
  82. package/lib/index.js +4 -2
  83. package/lib/testing/index.js +2 -2
  84. package/lib/testing/lib/cleanup.js +1 -1
  85. package/lib/testing/lib/metadata.js +1 -1
  86. package/package.json +1 -1
@@ -0,0 +1,285 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.VirtualNetworkGateway = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Azure Virtual Network Gateway implementation using AzapiResource framework
8
+ *
9
+ * This class provides a unified implementation for Azure Virtual Network Gateways that
10
+ * automatically handles version management, schema validation, and property
11
+ * transformation across all supported API versions.
12
+ *
13
+ * Supported API Versions:
14
+ * - 2024-01-01 (Active)
15
+ * - 2024-05-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
22
+ * - JSII compliance for multi-language support
23
+ */
24
+ const cdktf = require("cdktf");
25
+ const virtual_network_gateway_schemas_1 = require("./virtual-network-gateway-schemas");
26
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
27
+ /**
28
+ * Azure Virtual Network Gateway implementation
29
+ *
30
+ * This class provides a single, version-aware implementation that replaces
31
+ * version-specific Virtual Network Gateway classes. It automatically handles version
32
+ * resolution, schema validation, and property transformation while maintaining
33
+ * full backward compatibility.
34
+ *
35
+ * Virtual Network Gateways are used to send encrypted traffic between Azure virtual
36
+ * networks and on-premises locations over the public Internet (VPN) or through
37
+ * Azure ExpressRoute circuits (ExpressRoute).
38
+ *
39
+ * @example
40
+ * // Basic VPN Gateway:
41
+ * const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
42
+ * name: "my-vpn-gateway",
43
+ * location: "eastus",
44
+ * resourceGroupId: resourceGroup.id,
45
+ * gatewayType: "Vpn",
46
+ * vpnType: "RouteBased",
47
+ * sku: {
48
+ * name: "VpnGw1",
49
+ * tier: "VpnGw1"
50
+ * },
51
+ * ipConfigurations: [{
52
+ * name: "default",
53
+ * subnetId: gatewaySubnet.id,
54
+ * publicIPAddressId: publicIp.id
55
+ * }]
56
+ * });
57
+ *
58
+ * @example
59
+ * // VPN Gateway with BGP:
60
+ * const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
61
+ * name: "my-vpn-gateway-bgp",
62
+ * location: "eastus",
63
+ * resourceGroupId: resourceGroup.id,
64
+ * gatewayType: "Vpn",
65
+ * vpnType: "RouteBased",
66
+ * sku: {
67
+ * name: "VpnGw1",
68
+ * tier: "VpnGw1"
69
+ * },
70
+ * enableBgp: true,
71
+ * bgpSettings: {
72
+ * asn: 65515,
73
+ * peerWeight: 0
74
+ * },
75
+ * ipConfigurations: [{
76
+ * name: "default",
77
+ * subnetId: gatewaySubnet.id,
78
+ * publicIPAddressId: publicIp.id
79
+ * }]
80
+ * });
81
+ *
82
+ * @example
83
+ * // Active-Active VPN Gateway:
84
+ * const vpnGateway = new VirtualNetworkGateway(this, "vpnGateway", {
85
+ * name: "my-vpn-gateway-aa",
86
+ * location: "eastus",
87
+ * resourceGroupId: resourceGroup.id,
88
+ * gatewayType: "Vpn",
89
+ * vpnType: "RouteBased",
90
+ * sku: {
91
+ * name: "VpnGw1",
92
+ * tier: "VpnGw1"
93
+ * },
94
+ * activeActive: true,
95
+ * ipConfigurations: [
96
+ * {
97
+ * name: "config1",
98
+ * subnetId: gatewaySubnet.id,
99
+ * publicIPAddressId: publicIp1.id
100
+ * },
101
+ * {
102
+ * name: "config2",
103
+ * subnetId: gatewaySubnet.id,
104
+ * publicIPAddressId: publicIp2.id
105
+ * }
106
+ * ]
107
+ * });
108
+ *
109
+ * @stability stable
110
+ */
111
+ class VirtualNetworkGateway extends azapi_resource_1.AzapiResource {
112
+ /**
113
+ * Creates a new Azure Virtual Network Gateway using the AzapiResource framework
114
+ *
115
+ * The constructor automatically handles version resolution, schema registration,
116
+ * validation, and resource creation. It maintains full backward compatibility
117
+ * with existing Virtual Network Gateway implementations.
118
+ *
119
+ * @param scope - The scope in which to define this construct
120
+ * @param id - The unique identifier for this instance
121
+ * @param props - Configuration properties for the Virtual Network Gateway
122
+ */
123
+ constructor(scope, id, props) {
124
+ super(scope, id, props);
125
+ this.props = props;
126
+ // Add extended timeouts for gateway provisioning (30-45 minutes typical)
127
+ this.terraformResource.addOverride("timeouts", {
128
+ create: "60m",
129
+ update: "60m",
130
+ delete: "60m",
131
+ });
132
+ // Create Terraform outputs for easy access and referencing from other resources
133
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
134
+ value: this.id,
135
+ description: "The ID of the Virtual Network Gateway",
136
+ });
137
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
138
+ value: `\${${this.terraformResource.fqn}.name}`,
139
+ description: "The name of the Virtual Network Gateway",
140
+ });
141
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
142
+ value: `\${${this.terraformResource.fqn}.location}`,
143
+ description: "The location of the Virtual Network Gateway",
144
+ });
145
+ this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
146
+ value: `\${${this.terraformResource.fqn}.tags}`,
147
+ description: "The tags assigned to the Virtual Network Gateway",
148
+ });
149
+ // Override logical IDs to match original naming convention
150
+ this.idOutput.overrideLogicalId("id");
151
+ this.nameOutput.overrideLogicalId("name");
152
+ this.locationOutput.overrideLogicalId("location");
153
+ this.tagsOutput.overrideLogicalId("tags");
154
+ // Apply ignore changes if specified
155
+ this._applyIgnoreChanges();
156
+ }
157
+ // =============================================================================
158
+ // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource
159
+ // =============================================================================
160
+ /**
161
+ * Gets the default API version to use when no explicit version is specified
162
+ * Returns the most recent stable version as the default
163
+ */
164
+ defaultVersion() {
165
+ return "2024-05-01";
166
+ }
167
+ /**
168
+ * Gets the Azure resource type for Virtual Network Gateways
169
+ */
170
+ resourceType() {
171
+ return virtual_network_gateway_schemas_1.VIRTUAL_NETWORK_GATEWAY_TYPE;
172
+ }
173
+ /**
174
+ * Gets the API schema for the resolved version
175
+ * Uses the framework's schema resolution to get the appropriate schema
176
+ */
177
+ apiSchema() {
178
+ return this.resolveSchema();
179
+ }
180
+ /**
181
+ * Indicates that location is required for Virtual Network Gateways
182
+ */
183
+ requiresLocation() {
184
+ return true;
185
+ }
186
+ /**
187
+ * Creates the resource body for the Azure API call
188
+ * Transforms the input properties into the JSON format expected by Azure REST API
189
+ */
190
+ createResourceBody(props) {
191
+ const typedProps = props;
192
+ // Transform IP configurations to Azure API format
193
+ const ipConfigurations = typedProps.ipConfigurations.map((config) => ({
194
+ name: config.name,
195
+ properties: {
196
+ privateIPAllocationMethod: config.privateIPAllocationMethod || "Dynamic",
197
+ subnet: {
198
+ id: config.subnetId,
199
+ },
200
+ publicIPAddress: {
201
+ id: config.publicIPAddressId,
202
+ },
203
+ },
204
+ }));
205
+ return {
206
+ location: this.location,
207
+ tags: this.allTags(),
208
+ properties: {
209
+ gatewayType: typedProps.gatewayType,
210
+ vpnType: typedProps.vpnType || "RouteBased",
211
+ enableBgp: typedProps.enableBgp || false,
212
+ activeActive: typedProps.activeActive || false,
213
+ sku: typedProps.sku,
214
+ ipConfigurations: ipConfigurations,
215
+ bgpSettings: typedProps.bgpSettings,
216
+ vpnGatewayGeneration: typedProps.vpnGatewayGeneration,
217
+ customRoutes: typedProps.customRoutes,
218
+ enablePrivateIpAddress: typedProps.enablePrivateIpAddress,
219
+ gatewayDefaultSite: typedProps.gatewayDefaultSite,
220
+ vpnClientConfiguration: typedProps.vpnClientConfiguration,
221
+ },
222
+ };
223
+ }
224
+ // =============================================================================
225
+ // PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY OPERATIONS
226
+ // =============================================================================
227
+ /**
228
+ * Get the subscription ID from the Virtual Network Gateway ID
229
+ * Extracts the subscription ID from the Azure resource ID format
230
+ */
231
+ get subscriptionId() {
232
+ const idParts = this.id.split("/");
233
+ const subscriptionIndex = idParts.indexOf("subscriptions");
234
+ if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {
235
+ return idParts[subscriptionIndex + 1];
236
+ }
237
+ throw new Error("Unable to extract subscription ID from Virtual Network Gateway ID");
238
+ }
239
+ /**
240
+ * Get the full resource identifier for use in other Azure resources
241
+ * Alias for the id property to match original interface
242
+ */
243
+ get resourceId() {
244
+ return this.id;
245
+ }
246
+ /**
247
+ * Add a tag to the Virtual Network Gateway
248
+ * Note: This modifies the construct props but requires a new deployment to take effect
249
+ */
250
+ addTag(key, value) {
251
+ if (!this.props.tags) {
252
+ this.props.tags = {};
253
+ }
254
+ this.props.tags[key] = value;
255
+ }
256
+ /**
257
+ * Remove a tag from the Virtual Network Gateway
258
+ * Note: This modifies the construct props but requires a new deployment to take effect
259
+ */
260
+ removeTag(key) {
261
+ if (this.props.tags && this.props.tags[key]) {
262
+ delete this.props.tags[key];
263
+ }
264
+ }
265
+ // =============================================================================
266
+ // PRIVATE HELPER METHODS
267
+ // =============================================================================
268
+ /**
269
+ * Applies ignore changes lifecycle rules if specified in props
270
+ */
271
+ _applyIgnoreChanges() {
272
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
273
+ this.terraformResource.addOverride("lifecycle", {
274
+ ignore_changes: this.props.ignoreChanges,
275
+ });
276
+ }
277
+ }
278
+ }
279
+ exports.VirtualNetworkGateway = VirtualNetworkGateway;
280
+ _a = JSII_RTTI_SYMBOL_1;
281
+ VirtualNetworkGateway[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualNetworkGateway", version: "1.5.0" };
282
+ (() => {
283
+ azapi_resource_1.AzapiResource.registerSchemas(virtual_network_gateway_schemas_1.VIRTUAL_NETWORK_GATEWAY_TYPE, virtual_network_gateway_schemas_1.ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS);
284
+ })();
285
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgateway/lib/virtual-network-gateway.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,+BAA+B;AAE/B,uFAG2C;AAC3C,8EAGmD;AAqOnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmFG;AACH,MAAa,qBAAsB,SAAQ,8BAAa;IAmBtD;;;;;;;;;;OAUG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAiC;QACzE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,yEAAyE;QACzE,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,UAAU,EAAE;YAC7C,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,KAAK;SACd,CAAC,CAAC;QAEH,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,uCAAuC;SACrD,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,yCAAyC;SACvD,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YAChE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,YAAY;YACnD,WAAW,EAAE,6CAA6C;SAC3D,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,kDAAkD;SAChE,CAAC,CAAC;QAEH,2DAA2D;QAC3D,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAE1C,oCAAoC;QACpC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,gFAAgF;IAChF,wDAAwD;IACxD,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,8DAA4B,CAAC;IACtC,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACO,gBAAgB;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;OAGG;IACO,kBAAkB,CAAC,KAAU;QACrC,MAAM,UAAU,GAAG,KAAmC,CAAC;QAEvD,kDAAkD;QAClD,MAAM,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;YACpE,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,UAAU,EAAE;gBACV,yBAAyB,EACvB,MAAM,CAAC,yBAAyB,IAAI,SAAS;gBAC/C,MAAM,EAAE;oBACN,EAAE,EAAE,MAAM,CAAC,QAAQ;iBACpB;gBACD,eAAe,EAAE;oBACf,EAAE,EAAE,MAAM,CAAC,iBAAiB;iBAC7B;aACF;SACF,CAAC,CAAC,CAAC;QAEJ,OAAO;YACL,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE;YACpB,UAAU,EAAE;gBACV,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,OAAO,EAAE,UAAU,CAAC,OAAO,IAAI,YAAY;gBAC3C,SAAS,EAAE,UAAU,CAAC,SAAS,IAAI,KAAK;gBACxC,YAAY,EAAE,UAAU,CAAC,YAAY,IAAI,KAAK;gBAC9C,GAAG,EAAE,UAAU,CAAC,GAAG;gBACnB,gBAAgB,EAAE,gBAAgB;gBAClC,WAAW,EAAE,UAAU,CAAC,WAAW;gBACnC,oBAAoB,EAAE,UAAU,CAAC,oBAAoB;gBACrD,YAAY,EAAE,UAAU,CAAC,YAAY;gBACrC,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;gBACzD,kBAAkB,EAAE,UAAU,CAAC,kBAAkB;gBACjD,sBAAsB,EAAE,UAAU,CAAC,sBAAsB;aAC1D;SACF,CAAC;IACJ,CAAC;IAED,gFAAgF;IAChF,wDAAwD;IACxD,gFAAgF;IAEhF;;;OAGG;IACH,IAAW,cAAc;QACvB,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACnC,MAAM,iBAAiB,GAAG,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;QAC3D,IAAI,iBAAiB,KAAK,CAAC,CAAC,IAAI,iBAAiB,GAAG,CAAC,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YACvE,OAAO,OAAO,CAAC,iBAAiB,GAAG,CAAC,CAAC,CAAC;QACxC,CAAC;QACD,MAAM,IAAI,KAAK,CACb,mEAAmE,CACpE,CAAC;IACJ,CAAC;IAED;;;OAGG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,EAAE,CAAC;IACjB,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,GAAW,EAAE,KAAa;QACtC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;YACpB,IAAI,CAAC,KAAa,CAAC,IAAI,GAAG,EAAE,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,IAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAChC,CAAC;IAED;;;OAGG;IACI,SAAS,CAAC,GAAW;QAC1B,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,gFAAgF;IAChF,yBAAyB;IACzB,gFAAgF;IAEhF;;OAEG;IACK,mBAAmB;QACzB,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,WAAW,EAAE;gBAC9C,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa;aACzC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;;AAlNH,sDAmNC;;;AAlNC;IACE,8BAAa,CAAC,eAAe,CAC3B,8DAA4B,EAC5B,sEAAoC,CACrC,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Azure Virtual Network Gateway implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Virtual Network Gateways that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2024-01-01 (Active)\n * - 2024-05-01 (Active, Latest)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full backward compatibility\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS,\n  VIRTUAL_NETWORK_GATEWAY_TYPE,\n} from \"./virtual-network-gateway-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 * SKU configuration for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewaySku {\n  /**\n   * Name of the SKU\n   * @example \"Basic\", \"VpnGw1\", \"VpnGw2\", \"VpnGw3\", \"VpnGw4\", \"VpnGw5\", \"ErGw1AZ\", \"ErGw2AZ\", \"ErGw3AZ\"\n   */\n  readonly name: string;\n\n  /**\n   * Tier of the SKU\n   * @example \"Basic\", \"VpnGw1\", \"VpnGw2\", \"VpnGw3\", \"VpnGw4\", \"VpnGw5\", \"ErGw1AZ\", \"ErGw2AZ\", \"ErGw3AZ\"\n   */\n  readonly tier: string;\n}\n\n/**\n * IP configuration for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewayIpConfiguration {\n  /**\n   * Name of the IP configuration\n   */\n  readonly name: string;\n\n  /**\n   * Private IP allocation method\n   * @defaultValue \"Dynamic\"\n   */\n  readonly privateIPAllocationMethod?: string;\n\n  /**\n   * ID of the subnet to use (must be GatewaySubnet)\n   */\n  readonly subnetId: string;\n\n  /**\n   * ID of the public IP address to use\n   */\n  readonly publicIPAddressId: string;\n}\n\n/**\n * BGP settings for Virtual Network Gateway\n */\nexport interface VirtualNetworkGatewayBgpSettings {\n  /**\n   * BGP ASN (Autonomous System Number)\n   * @example 65515\n   */\n  readonly asn?: number;\n\n  /**\n   * BGP peering address\n   */\n  readonly bgpPeeringAddress?: string;\n\n  /**\n   * Weight added to routes learned from this BGP speaker\n   */\n  readonly peerWeight?: number;\n\n  /**\n   * BGP peering addresses for active-active configuration\n   */\n  readonly bgpPeeringAddresses?: any[];\n}\n\n/**\n * VPN client address pool configuration\n */\nexport interface VirtualNetworkGatewayVpnClientAddressPool {\n  /**\n   * List of address prefixes for VPN client connections\n   */\n  readonly addressPrefixes: string[];\n}\n\n/**\n * VPN client configuration for point-to-site connections\n */\nexport interface VirtualNetworkGatewayVpnClientConfiguration {\n  /**\n   * VPN client address pool\n   */\n  readonly vpnClientAddressPool?: VirtualNetworkGatewayVpnClientAddressPool;\n\n  /**\n   * VPN client protocols\n   * @example [\"IkeV2\", \"SSTP\", \"OpenVPN\"]\n   */\n  readonly vpnClientProtocols?: string[];\n\n  /**\n   * VPN client root certificates\n   */\n  readonly vpnClientRootCertificates?: any[];\n\n  /**\n   * VPN client revoked certificates\n   */\n  readonly vpnClientRevokedCertificates?: any[];\n\n  /**\n   * Radius server address\n   */\n  readonly radiusServerAddress?: string;\n\n  /**\n   * Radius server secret\n   */\n  readonly radiusServerSecret?: string;\n}\n\n/**\n * Custom routes configuration\n */\nexport interface VirtualNetworkGatewayCustomRoutes {\n  /**\n   * List of address prefixes\n   */\n  readonly addressPrefixes?: string[];\n}\n\n/**\n * Gateway default site reference\n */\nexport interface VirtualNetworkGatewayDefaultSite {\n  /**\n   * Resource ID of the local network gateway to use as default site\n   */\n  readonly id: string;\n}\n\n/**\n * Properties for the Azure Virtual Network Gateway\n *\n * Extends AzapiResourceProps with Virtual Network Gateway specific properties\n */\nexport interface VirtualNetworkGatewayProps extends AzapiResourceProps {\n  /**\n   * Gateway type\n   * Must be either \"Vpn\" or \"ExpressRoute\"\n   */\n  readonly gatewayType: \"Vpn\" | \"ExpressRoute\";\n\n  /**\n   * VPN type for VPN gateways\n   * @defaultValue \"RouteBased\"\n   */\n  readonly vpnType?: \"RouteBased\" | \"PolicyBased\";\n\n  /**\n   * SKU configuration for the gateway\n   */\n  readonly sku: VirtualNetworkGatewaySku;\n\n  /**\n   * IP configurations for the gateway\n   * At least one IP configuration is required\n   * Two IP configurations are required for active-active mode\n   */\n  readonly ipConfigurations: VirtualNetworkGatewayIpConfiguration[];\n\n  /**\n   * Enable BGP for the gateway\n   * @defaultValue false\n   */\n  readonly enableBgp?: boolean;\n\n  /**\n   * Enable active-active mode for the gateway\n   * Requires two IP configurations\n   * @defaultValue false\n   */\n  readonly activeActive?: boolean;\n\n  /**\n   * BGP settings for the gateway\n   * Required if enableBgp is true\n   */\n  readonly bgpSettings?: VirtualNetworkGatewayBgpSettings;\n\n  /**\n   * VPN gateway generation\n   * @example \"Generation1\", \"Generation2\"\n   */\n  readonly vpnGatewayGeneration?: string;\n\n  /**\n   * Custom routes for the gateway\n   */\n  readonly customRoutes?: VirtualNetworkGatewayCustomRoutes;\n\n  /**\n   * Enable private IP address for the gateway\n   * @defaultValue false\n   */\n  readonly enablePrivateIpAddress?: boolean;\n\n  /**\n   * Default site for force tunneling\n   */\n  readonly gatewayDefaultSite?: VirtualNetworkGatewayDefaultSite;\n\n  /**\n   * VPN client configuration for point-to-site connections\n   */\n  readonly vpnClientConfiguration?: VirtualNetworkGatewayVpnClientConfiguration;\n\n  /**\n   * Resource group ID where the Gateway will be created\n   * Optional - will use the subscription scope if not provided\n   */\n  readonly resourceGroupId?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   *\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Azure Virtual Network Gateway implementation\n *\n * This class provides a single, version-aware implementation that replaces\n * version-specific Virtual Network Gateway classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * Virtual Network Gateways are used to send encrypted traffic between Azure virtual\n * networks and on-premises locations over the public Internet (VPN) or through\n * Azure ExpressRoute circuits (ExpressRoute).\n *\n * @example\n * // Basic VPN Gateway:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   ipConfigurations: [{\n *     name: \"default\",\n *     subnetId: gatewaySubnet.id,\n *     publicIPAddressId: publicIp.id\n *   }]\n * });\n *\n * @example\n * // VPN Gateway with BGP:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway-bgp\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   enableBgp: true,\n *   bgpSettings: {\n *     asn: 65515,\n *     peerWeight: 0\n *   },\n *   ipConfigurations: [{\n *     name: \"default\",\n *     subnetId: gatewaySubnet.id,\n *     publicIPAddressId: publicIp.id\n *   }]\n * });\n *\n * @example\n * // Active-Active VPN Gateway:\n * const vpnGateway = new VirtualNetworkGateway(this, \"vpnGateway\", {\n *   name: \"my-vpn-gateway-aa\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   gatewayType: \"Vpn\",\n *   vpnType: \"RouteBased\",\n *   sku: {\n *     name: \"VpnGw1\",\n *     tier: \"VpnGw1\"\n *   },\n *   activeActive: true,\n *   ipConfigurations: [\n *     {\n *       name: \"config1\",\n *       subnetId: gatewaySubnet.id,\n *       publicIPAddressId: publicIp1.id\n *     },\n *     {\n *       name: \"config2\",\n *       subnetId: gatewaySubnet.id,\n *       publicIPAddressId: publicIp2.id\n *     }\n *   ]\n * });\n *\n * @stability stable\n */\nexport class VirtualNetworkGateway extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      VIRTUAL_NETWORK_GATEWAY_TYPE,\n      ALL_VIRTUAL_NETWORK_GATEWAY_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Virtual Network Gateway instance\n   */\n  public readonly props: VirtualNetworkGatewayProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly locationOutput: cdktf.TerraformOutput;\n  public readonly tagsOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Virtual Network Gateway using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation. It maintains full backward compatibility\n   * with existing Virtual Network Gateway implementations.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Virtual Network Gateway\n   */\n  constructor(scope: Construct, id: string, props: VirtualNetworkGatewayProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Add extended timeouts for gateway provisioning (30-45 minutes typical)\n    this.terraformResource.addOverride(\"timeouts\", {\n      create: \"60m\",\n      update: \"60m\",\n      delete: \"60m\",\n    });\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Virtual Network Gateway\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Virtual Network Gateway\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Virtual Network Gateway\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description: \"The tags assigned to the Virtual Network Gateway\",\n    });\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.tagsOutput.overrideLogicalId(\"tags\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the most recent stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2024-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Virtual Network Gateways\n   */\n  protected resourceType(): string {\n    return VIRTUAL_NETWORK_GATEWAY_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Indicates that location is required for Virtual Network Gateways\n   */\n  protected requiresLocation(): boolean {\n    return true;\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   * Transforms the input properties into the JSON format expected by Azure REST API\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as VirtualNetworkGatewayProps;\n\n    // Transform IP configurations to Azure API format\n    const ipConfigurations = typedProps.ipConfigurations.map((config) => ({\n      name: config.name,\n      properties: {\n        privateIPAllocationMethod:\n          config.privateIPAllocationMethod || \"Dynamic\",\n        subnet: {\n          id: config.subnetId,\n        },\n        publicIPAddress: {\n          id: config.publicIPAddressId,\n        },\n      },\n    }));\n\n    return {\n      location: this.location,\n      tags: this.allTags(),\n      properties: {\n        gatewayType: typedProps.gatewayType,\n        vpnType: typedProps.vpnType || \"RouteBased\",\n        enableBgp: typedProps.enableBgp || false,\n        activeActive: typedProps.activeActive || false,\n        sku: typedProps.sku,\n        ipConfigurations: ipConfigurations,\n        bgpSettings: typedProps.bgpSettings,\n        vpnGatewayGeneration: typedProps.vpnGatewayGeneration,\n        customRoutes: typedProps.customRoutes,\n        enablePrivateIpAddress: typedProps.enablePrivateIpAddress,\n        gatewayDefaultSite: typedProps.gatewayDefaultSite,\n        vpnClientConfiguration: typedProps.vpnClientConfiguration,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subscription ID from the Virtual Network Gateway ID\n   * Extracts the subscription ID from the Azure resource ID format\n   */\n  public get subscriptionId(): string {\n    const idParts = this.id.split(\"/\");\n    const subscriptionIndex = idParts.indexOf(\"subscriptions\");\n    if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {\n      return idParts[subscriptionIndex + 1];\n    }\n    throw new Error(\n      \"Unable to extract subscription ID from Virtual Network Gateway ID\",\n    );\n  }\n\n  /**\n   * Get the full resource identifier for use in other Azure resources\n   * Alias for the id property to match original interface\n   */\n  public get resourceId(): string {\n    return this.id;\n  }\n\n  /**\n   * Add a tag to the Virtual Network Gateway\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.props.tags) {\n      (this.props as any).tags = {};\n    }\n    this.props.tags![key] = value;\n  }\n\n  /**\n   * Remove a tag from the Virtual Network Gateway\n   * Note: This modifies the construct props but requires a new deployment to take effect\n   */\n  public removeTag(key: string): void {\n    if (this.props.tags && this.props.tags[key]) {\n      delete this.props.tags[key];\n    }\n  }\n\n  // =============================================================================\n  // PRIVATE HELPER METHODS\n  // =============================================================================\n\n  /**\n   * Applies ignore changes lifecycle rules if specified in props\n   */\n  private _applyIgnoreChanges(): void {\n    if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {\n      this.terraformResource.addOverride(\"lifecycle\", {\n        ignore_changes: this.props.ignoreChanges,\n      });\n    }\n  }\n}\n"]}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Integration test for Azure Virtual Network Gateway
3
+ *
4
+ * This test demonstrates basic usage of the VirtualNetworkGateway construct
5
+ * and validates deployment, idempotency, and cleanup.
6
+ *
7
+ * Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test
8
+ * has an extended timeout.
9
+ *
10
+ * Run with: npm run integration:nostream
11
+ */
12
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure Virtual Network Gateway
4
+ *
5
+ * This test demonstrates basic usage of the VirtualNetworkGateway construct
6
+ * and validates deployment, idempotency, and cleanup.
7
+ *
8
+ * Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test
9
+ * has an extended timeout.
10
+ *
11
+ * Run with: npm run integration:nostream
12
+ */
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ const cdktf_1 = require("cdktf");
15
+ require("cdktf/lib/testing/adapters/jest");
16
+ const azure_publicipaddress_1 = require("../../azure-publicipaddress");
17
+ const azure_resourcegroup_1 = require("../../azure-resourcegroup");
18
+ const azure_subnet_1 = require("../../azure-subnet");
19
+ const azure_virtualnetwork_1 = require("../../azure-virtualnetwork");
20
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
21
+ const testing_1 = require("../../testing");
22
+ const metadata_1 = require("../../testing/lib/metadata");
23
+ const virtual_network_gateway_1 = require("../lib/virtual-network-gateway");
24
+ // Generate unique test run metadata for this test suite
25
+ const testMetadata = new metadata_1.TestRunMetadata("virtual-network-gateway-integration", {
26
+ maxAgeHours: 4,
27
+ });
28
+ /**
29
+ * Example stack demonstrating Virtual Network Gateway usage
30
+ */
31
+ class VirtualNetworkGatewayExampleStack extends testing_1.BaseTestStack {
32
+ constructor(scope, id) {
33
+ super(scope, id, {
34
+ testRunOptions: {
35
+ maxAgeHours: testMetadata.maxAgeHours,
36
+ autoCleanup: testMetadata.autoCleanup,
37
+ cleanupPolicy: testMetadata.cleanupPolicy,
38
+ },
39
+ });
40
+ // Configure AZAPI provider
41
+ new provider_1.AzapiProvider(this, "azapi", {});
42
+ // Generate unique names
43
+ const rgName = this.generateResourceName("Microsoft.Resources/resourceGroups", "vng");
44
+ // Create resource group
45
+ const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "rg", {
46
+ name: rgName,
47
+ location: "eastus",
48
+ tags: {
49
+ ...this.systemTags(),
50
+ },
51
+ });
52
+ // Create virtual network
53
+ const vnet = new azure_virtualnetwork_1.VirtualNetwork(this, "vnet", {
54
+ name: "vnet-gateway-example",
55
+ location: "eastus",
56
+ resourceGroupId: resourceGroup.id,
57
+ addressSpace: {
58
+ addressPrefixes: ["10.0.0.0/16"],
59
+ },
60
+ tags: {
61
+ ...this.systemTags(),
62
+ },
63
+ });
64
+ // Create GatewaySubnet (required for VPN Gateway)
65
+ const gatewaySubnet = new azure_subnet_1.Subnet(this, "gateway-subnet", {
66
+ name: "GatewaySubnet", // Must be named "GatewaySubnet"
67
+ virtualNetworkName: "vnet-gateway-example",
68
+ virtualNetworkId: vnet.id,
69
+ resourceGroupId: resourceGroup.id,
70
+ addressPrefix: "10.0.1.0/24",
71
+ });
72
+ // Create public IP for the gateway
73
+ const publicIp = new azure_publicipaddress_1.PublicIPAddress(this, "public-ip", {
74
+ name: "pip-gateway-example",
75
+ location: "eastus",
76
+ resourceGroupId: resourceGroup.id,
77
+ sku: {
78
+ name: "Standard",
79
+ tier: "Regional",
80
+ },
81
+ publicIPAllocationMethod: "Static",
82
+ tags: {
83
+ ...this.systemTags(),
84
+ },
85
+ });
86
+ // Example: Basic VPN Gateway
87
+ new virtual_network_gateway_1.VirtualNetworkGateway(this, "vpn-gateway", {
88
+ name: "vng-basic-example",
89
+ location: "eastus",
90
+ resourceGroupId: resourceGroup.id,
91
+ gatewayType: "Vpn",
92
+ vpnType: "RouteBased",
93
+ sku: {
94
+ name: "VpnGw1",
95
+ tier: "VpnGw1",
96
+ },
97
+ ipConfigurations: [
98
+ {
99
+ name: "default",
100
+ subnetId: gatewaySubnet.id,
101
+ publicIPAddressId: publicIp.id,
102
+ },
103
+ ],
104
+ tags: {
105
+ ...this.systemTags(),
106
+ example: "basic-vpn",
107
+ },
108
+ });
109
+ }
110
+ }
111
+ describe("Virtual Network Gateway Integration Test", () => {
112
+ // NOTE: Test is skipped due to 30-45 minute gateway provisioning time.
113
+ // This test has been validated and confirms the gateway deploys successfully.
114
+ // Run manually when needed: npx jest src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts
115
+ //
116
+ // Known issue: Cleanup may fail due to Terraform dependency ordering with the gateway resource.
117
+ // Manual cleanup may be required via Azure Portal if destroy fails.
118
+ it.skip("should deploy, validate idempotency, and cleanup virtual network gateway resources", () => {
119
+ const app = cdktf_1.Testing.app();
120
+ const stack = new VirtualNetworkGatewayExampleStack(app, "test-virtual-network-gateway");
121
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
122
+ // This will:
123
+ // 1. Run terraform apply to deploy resources
124
+ // 2. Run terraform plan to check idempotency (no changes expected)
125
+ // 3. Run terraform destroy to cleanup resources
126
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
127
+ }, 4500000); // Increased from 3600000 (60 min) to 4500000 (75 min) for gateway provisioning
128
+ });
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway.integ.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Virtual Network Gateway\n *\n * This test demonstrates basic usage of the VirtualNetworkGateway construct\n * and validates deployment, idempotency, and cleanup.\n *\n * Note: Virtual Network Gateways take 20-45 minutes to deploy, so this test\n * has an extended timeout.\n *\n * Run with: npm run integration:nostream\n */\n\nimport { Testing } from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport \"cdktf/lib/testing/adapters/jest\";\nimport { PublicIPAddress } from \"../../azure-publicipaddress\";\nimport { ResourceGroup } from \"../../azure-resourcegroup\";\nimport { Subnet } from \"../../azure-subnet\";\nimport { VirtualNetwork } from \"../../azure-virtualnetwork\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { VirtualNetworkGateway } from \"../lib/virtual-network-gateway\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\n  \"virtual-network-gateway-integration\",\n  {\n    maxAgeHours: 4,\n  },\n);\n\n/**\n * Example stack demonstrating Virtual Network Gateway usage\n */\nclass VirtualNetworkGatewayExampleStack extends BaseTestStack {\n  constructor(scope: Construct, id: string) {\n    super(scope, id, {\n      testRunOptions: {\n        maxAgeHours: testMetadata.maxAgeHours,\n        autoCleanup: testMetadata.autoCleanup,\n        cleanupPolicy: testMetadata.cleanupPolicy,\n      },\n    });\n\n    // Configure AZAPI provider\n    new AzapiProvider(this, \"azapi\", {});\n\n    // Generate unique names\n    const rgName = this.generateResourceName(\n      \"Microsoft.Resources/resourceGroups\",\n      \"vng\",\n    );\n\n    // Create resource group\n    const resourceGroup = new ResourceGroup(this, \"rg\", {\n      name: rgName,\n      location: \"eastus\",\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Create virtual network\n    const vnet = new VirtualNetwork(this, \"vnet\", {\n      name: \"vnet-gateway-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.0.0.0/16\"],\n      },\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Create GatewaySubnet (required for VPN Gateway)\n    const gatewaySubnet = new Subnet(this, \"gateway-subnet\", {\n      name: \"GatewaySubnet\", // Must be named \"GatewaySubnet\"\n      virtualNetworkName: \"vnet-gateway-example\",\n      virtualNetworkId: vnet.id,\n      resourceGroupId: resourceGroup.id,\n      addressPrefix: \"10.0.1.0/24\",\n    });\n\n    // Create public IP for the gateway\n    const publicIp = new PublicIPAddress(this, \"public-ip\", {\n      name: \"pip-gateway-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      sku: {\n        name: \"Standard\",\n        tier: \"Regional\",\n      },\n      publicIPAllocationMethod: \"Static\",\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // Example: Basic VPN Gateway\n    new VirtualNetworkGateway(this, \"vpn-gateway\", {\n      name: \"vng-basic-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      gatewayType: \"Vpn\",\n      vpnType: \"RouteBased\",\n      sku: {\n        name: \"VpnGw1\",\n        tier: \"VpnGw1\",\n      },\n      ipConfigurations: [\n        {\n          name: \"default\",\n          subnetId: gatewaySubnet.id,\n          publicIPAddressId: publicIp.id,\n        },\n      ],\n      tags: {\n        ...this.systemTags(),\n        example: \"basic-vpn\",\n      },\n    });\n  }\n}\n\ndescribe(\"Virtual Network Gateway Integration Test\", () => {\n  // NOTE: Test is skipped due to 30-45 minute gateway provisioning time.\n  // This test has been validated and confirms the gateway deploys successfully.\n  // Run manually when needed: npx jest src/azure-virtualnetworkgateway/test/virtual-network-gateway.integ.ts\n  //\n  // Known issue: Cleanup may fail due to Terraform dependency ordering with the gateway resource.\n  // Manual cleanup may be required via Azure Portal if destroy fails.\n  it.skip(\"should deploy, validate idempotency, and cleanup virtual network gateway resources\", () => {\n    const app = Testing.app();\n    const stack = new VirtualNetworkGatewayExampleStack(\n      app,\n      \"test-virtual-network-gateway\",\n    );\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources\n    // 2. Run terraform plan to check idempotency (no changes expected)\n    // 3. Run terraform destroy to cleanup resources\n    TerraformApplyCheckAndDestroy(synthesized, { verifyCleanup: true });\n  }, 4500000); // Increased from 3600000 (60 min) to 4500000 (75 min) for gateway provisioning\n});\n"]}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Comprehensive tests for the Virtual Network Gateway implementation
3
+ *
4
+ * This test suite validates the VirtualNetworkGateway class using the AzapiResource framework.
5
+ * Tests cover automatic version resolution, explicit version pinning, schema validation,
6
+ * property transformation, and resource creation.
7
+ */
8
+ export {};