@microsoft/terraform-cdk-constructs 1.4.0 → 1.6.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 (78) hide show
  1. package/.jsii +12910 -8935
  2. package/API.md +31954 -26602
  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-virtualnetworkgatewayconnection/index.d.ts +6 -0
  42. package/lib/azure-virtualnetworkgatewayconnection/index.js +23 -0
  43. package/lib/azure-virtualnetworkgatewayconnection/lib/index.d.ts +8 -0
  44. package/lib/azure-virtualnetworkgatewayconnection/lib/index.js +25 -0
  45. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection-schemas.d.ts +32 -0
  46. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection-schemas.js +322 -0
  47. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.d.ts +333 -0
  48. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +310 -0
  49. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.integ.d.ts +12 -0
  50. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.integ.js +216 -0
  51. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.spec.d.ts +8 -0
  52. package/lib/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.spec.js +706 -0
  53. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  54. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
  55. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
  56. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  57. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  58. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  59. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  60. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  61. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
  62. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  63. package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
  64. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  65. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  66. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  67. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  68. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  69. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  70. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  71. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  72. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  73. package/lib/index.d.ts +4 -0
  74. package/lib/index.js +6 -2
  75. package/lib/testing/index.js +2 -2
  76. package/lib/testing/lib/cleanup.js +1 -1
  77. package/lib/testing/lib/metadata.js +1 -1
  78. package/package.json +1 -1
@@ -0,0 +1,310 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.VirtualNetworkGatewayConnection = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Azure Virtual Network Gateway Connection implementation using AzapiResource framework
8
+ *
9
+ * This class provides a unified implementation for Azure Virtual Network Gateway Connections 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
+ * - Type-safe connection type handling using discriminated unions
22
+ * - Full backward compatibility
23
+ * - JSII compliance for multi-language support
24
+ */
25
+ const cdktf = require("cdktf");
26
+ const virtual_network_gateway_connection_schemas_1 = require("./virtual-network-gateway-connection-schemas");
27
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
28
+ /**
29
+ * Azure Virtual Network Gateway Connection implementation
30
+ *
31
+ * This class provides a single, version-aware implementation that replaces
32
+ * version-specific Virtual Network Gateway Connection classes. It automatically handles version
33
+ * resolution, schema validation, and property transformation while maintaining
34
+ * full backward compatibility.
35
+ *
36
+ * Virtual Network Gateway Connections establish connectivity between Virtual Network Gateways
37
+ * and other networking endpoints:
38
+ * - IPsec: Site-to-Site VPN connections to on-premises networks
39
+ * - Vnet2Vnet: VNet-to-VNet connections between Azure virtual networks
40
+ * - ExpressRoute: Private connections to Azure via ExpressRoute circuits
41
+ *
42
+ * @example
43
+ * // IPsec (Site-to-Site VPN) Connection:
44
+ * const s2sConnection = new VirtualNetworkGatewayConnection(this, "s2sConnection", {
45
+ * name: "my-s2s-connection",
46
+ * location: "eastus",
47
+ * resourceGroupId: resourceGroup.id,
48
+ * connectionType: "IPsec",
49
+ * virtualNetworkGateway1: { id: vpnGateway.id },
50
+ * localNetworkGateway2: { id: localGateway.id },
51
+ * sharedKey: "mySecureSharedKey123!"
52
+ * });
53
+ *
54
+ * @example
55
+ * // VNet-to-VNet Connection:
56
+ * const vnetConnection = new VirtualNetworkGatewayConnection(this, "vnetConnection", {
57
+ * name: "my-vnet-connection",
58
+ * location: "eastus",
59
+ * resourceGroupId: resourceGroup.id,
60
+ * connectionType: "Vnet2Vnet",
61
+ * virtualNetworkGateway1: { id: vpnGateway1.id },
62
+ * virtualNetworkGateway2: { id: vpnGateway2.id },
63
+ * sharedKey: "mySecureSharedKey123!",
64
+ * enableBgp: true
65
+ * });
66
+ *
67
+ * @example
68
+ * // ExpressRoute Connection:
69
+ * const erConnection = new VirtualNetworkGatewayConnection(this, "erConnection", {
70
+ * name: "my-er-connection",
71
+ * location: "eastus",
72
+ * resourceGroupId: resourceGroup.id,
73
+ * connectionType: "ExpressRoute",
74
+ * virtualNetworkGateway1: { id: erGateway.id },
75
+ * peer: { id: expressRouteCircuit.id },
76
+ * authorizationKey: "optional-auth-key-if-cross-subscription"
77
+ * });
78
+ *
79
+ * @example
80
+ * // IPsec Connection with Custom IPsec Policies:
81
+ * const customConnection = new VirtualNetworkGatewayConnection(this, "customConnection", {
82
+ * name: "my-custom-connection",
83
+ * location: "eastus",
84
+ * resourceGroupId: resourceGroup.id,
85
+ * connectionType: "IPsec",
86
+ * virtualNetworkGateway1: { id: vpnGateway.id },
87
+ * localNetworkGateway2: { id: localGateway.id },
88
+ * sharedKey: "mySecureSharedKey123!",
89
+ * connectionProtocol: "IKEv2",
90
+ * ipsecPolicies: [{
91
+ * dhGroup: "DHGroup14",
92
+ * ikeEncryption: "AES256",
93
+ * ikeIntegrity: "SHA256",
94
+ * ipsecEncryption: "AES256",
95
+ * ipsecIntegrity: "SHA256",
96
+ * pfsGroup: "PFS2048",
97
+ * saLifeTimeSeconds: 3600,
98
+ * saDataSizeKilobytes: 102400000
99
+ * }],
100
+ * usePolicyBasedTrafficSelectors: true
101
+ * });
102
+ *
103
+ * @stability stable
104
+ */
105
+ class VirtualNetworkGatewayConnection extends azapi_resource_1.AzapiResource {
106
+ /**
107
+ * Creates a new Azure Virtual Network Gateway Connection using the AzapiResource framework
108
+ *
109
+ * The constructor automatically handles version resolution, schema registration,
110
+ * validation, and resource creation. It maintains full backward compatibility
111
+ * with existing Virtual Network Gateway Connection implementations.
112
+ *
113
+ * @param scope - The scope in which to define this construct
114
+ * @param id - The unique identifier for this instance
115
+ * @param props - Configuration properties for the Virtual Network Gateway Connection
116
+ */
117
+ constructor(scope, id, props) {
118
+ super(scope, id, props);
119
+ this.props = props;
120
+ // Add timeouts for connection provisioning (typically 30 minutes)
121
+ this.terraformResource.addOverride("timeouts", {
122
+ create: "30m",
123
+ update: "30m",
124
+ delete: "30m",
125
+ });
126
+ // Create Terraform outputs for easy access and referencing from other resources
127
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
128
+ value: this.id,
129
+ description: "The ID of the Virtual Network Gateway Connection",
130
+ });
131
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
132
+ value: `\${${this.terraformResource.fqn}.name}`,
133
+ description: "The name of the Virtual Network Gateway Connection",
134
+ });
135
+ this.locationOutput = new cdktf.TerraformOutput(this, "location", {
136
+ value: `\${${this.terraformResource.fqn}.location}`,
137
+ description: "The location of the Virtual Network Gateway Connection",
138
+ });
139
+ this.tagsOutput = new cdktf.TerraformOutput(this, "tags", {
140
+ value: `\${${this.terraformResource.fqn}.tags}`,
141
+ description: "The tags assigned to the Virtual Network Gateway Connection",
142
+ });
143
+ // Override logical IDs to match original naming convention
144
+ this.idOutput.overrideLogicalId("id");
145
+ this.nameOutput.overrideLogicalId("name");
146
+ this.locationOutput.overrideLogicalId("location");
147
+ this.tagsOutput.overrideLogicalId("tags");
148
+ // Apply ignore changes if specified
149
+ this._applyIgnoreChanges();
150
+ }
151
+ // =============================================================================
152
+ // REQUIRED ABSTRACT METHODS FROM VersionedAzapiResource
153
+ // =============================================================================
154
+ /**
155
+ * Gets the default API version to use when no explicit version is specified
156
+ * Returns the most recent stable version as the default
157
+ */
158
+ defaultVersion() {
159
+ return "2024-05-01";
160
+ }
161
+ /**
162
+ * Gets the Azure resource type for Virtual Network Gateway Connections
163
+ */
164
+ resourceType() {
165
+ return virtual_network_gateway_connection_schemas_1.VIRTUAL_NETWORK_GATEWAY_CONNECTION_TYPE;
166
+ }
167
+ /**
168
+ * Gets the API schema for the resolved version
169
+ * Uses the framework's schema resolution to get the appropriate schema
170
+ */
171
+ apiSchema() {
172
+ return this.resolveSchema();
173
+ }
174
+ /**
175
+ * Indicates that location is required for Virtual Network Gateway Connections
176
+ */
177
+ requiresLocation() {
178
+ return true;
179
+ }
180
+ /**
181
+ * Creates the resource body for the Azure API call
182
+ * Transforms the input properties into the JSON format expected by Azure REST API
183
+ * Handles type-specific properties based on connectionType
184
+ */
185
+ createResourceBody(props) {
186
+ const typedProps = props;
187
+ // Build the properties object based on connection type
188
+ const properties = {
189
+ connectionType: typedProps.connectionType,
190
+ virtualNetworkGateway1: {
191
+ id: typedProps.virtualNetworkGateway1.id,
192
+ properties: {},
193
+ },
194
+ connectionProtocol: typedProps.connectionProtocol || "IKEv2",
195
+ enableBgp: typedProps.enableBgp || false,
196
+ };
197
+ // Add optional common properties
198
+ if (typedProps.routingWeight !== undefined) {
199
+ properties.routingWeight = typedProps.routingWeight;
200
+ }
201
+ if (typedProps.dpdTimeoutSeconds !== undefined) {
202
+ properties.dpdTimeoutSeconds = typedProps.dpdTimeoutSeconds;
203
+ }
204
+ if (typedProps.ipsecPolicies !== undefined) {
205
+ properties.ipsecPolicies = typedProps.ipsecPolicies;
206
+ }
207
+ if (typedProps.usePolicyBasedTrafficSelectors !== undefined) {
208
+ properties.usePolicyBasedTrafficSelectors =
209
+ typedProps.usePolicyBasedTrafficSelectors;
210
+ }
211
+ if (typedProps.connectionMode !== undefined) {
212
+ properties.connectionMode = typedProps.connectionMode;
213
+ }
214
+ if (typedProps.egressNatRules !== undefined) {
215
+ properties.egressNatRules = typedProps.egressNatRules;
216
+ }
217
+ if (typedProps.ingressNatRules !== undefined) {
218
+ properties.ingressNatRules = typedProps.ingressNatRules;
219
+ }
220
+ // Add connection type-specific properties
221
+ switch (typedProps.connectionType) {
222
+ case "IPsec":
223
+ properties.localNetworkGateway2 = {
224
+ id: typedProps.localNetworkGateway2.id,
225
+ properties: {},
226
+ };
227
+ properties.sharedKey = typedProps.sharedKey;
228
+ break;
229
+ case "Vnet2Vnet":
230
+ properties.virtualNetworkGateway2 = {
231
+ id: typedProps.virtualNetworkGateway2.id,
232
+ properties: {},
233
+ };
234
+ properties.sharedKey = typedProps.sharedKey;
235
+ break;
236
+ case "ExpressRoute":
237
+ properties.peer = typedProps.peer;
238
+ if (typedProps.authorizationKey !== undefined) {
239
+ properties.authorizationKey = typedProps.authorizationKey;
240
+ }
241
+ break;
242
+ }
243
+ return {
244
+ location: this.location,
245
+ tags: this.allTags(),
246
+ properties: properties,
247
+ };
248
+ }
249
+ // =============================================================================
250
+ // PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY CONNECTION OPERATIONS
251
+ // =============================================================================
252
+ /**
253
+ * Get the subscription ID from the Virtual Network Gateway Connection ID
254
+ * Extracts the subscription ID from the Azure resource ID format
255
+ */
256
+ get subscriptionId() {
257
+ const idParts = this.id.split("/");
258
+ const subscriptionIndex = idParts.indexOf("subscriptions");
259
+ if (subscriptionIndex !== -1 && subscriptionIndex + 1 < idParts.length) {
260
+ return idParts[subscriptionIndex + 1];
261
+ }
262
+ throw new Error("Unable to extract subscription ID from Virtual Network Gateway Connection ID");
263
+ }
264
+ /**
265
+ * Get the full resource identifier for use in other Azure resources
266
+ * Alias for the id property to match original interface
267
+ */
268
+ get resourceId() {
269
+ return this.id;
270
+ }
271
+ /**
272
+ * Add a tag to the Virtual Network Gateway Connection
273
+ * Note: This modifies the construct props but requires a new deployment to take effect
274
+ */
275
+ addTag(key, value) {
276
+ if (!this.props.tags) {
277
+ this.props.tags = {};
278
+ }
279
+ this.props.tags[key] = value;
280
+ }
281
+ /**
282
+ * Remove a tag from the Virtual Network Gateway Connection
283
+ * Note: This modifies the construct props but requires a new deployment to take effect
284
+ */
285
+ removeTag(key) {
286
+ if (this.props.tags && this.props.tags[key]) {
287
+ delete this.props.tags[key];
288
+ }
289
+ }
290
+ // =============================================================================
291
+ // PRIVATE HELPER METHODS
292
+ // =============================================================================
293
+ /**
294
+ * Applies ignore changes lifecycle rules if specified in props
295
+ */
296
+ _applyIgnoreChanges() {
297
+ if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
298
+ this.terraformResource.addOverride("lifecycle", {
299
+ ignore_changes: this.props.ignoreChanges,
300
+ });
301
+ }
302
+ }
303
+ }
304
+ exports.VirtualNetworkGatewayConnection = VirtualNetworkGatewayConnection;
305
+ _a = JSII_RTTI_SYMBOL_1;
306
+ VirtualNetworkGatewayConnection[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualNetworkGatewayConnection", version: "1.6.0" };
307
+ (() => {
308
+ azapi_resource_1.AzapiResource.registerSchemas(virtual_network_gateway_connection_schemas_1.VIRTUAL_NETWORK_GATEWAY_CONNECTION_TYPE, virtual_network_gateway_connection_schemas_1.ALL_VIRTUAL_NETWORK_GATEWAY_CONNECTION_VERSIONS);
309
+ })();
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway-connection.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Virtual Network Gateway Connection implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Virtual Network Gateway Connections 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 * - Type-safe connection type handling using discriminated unions\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_CONNECTION_VERSIONS,\n  VIRTUAL_NETWORK_GATEWAY_CONNECTION_TYPE,\n} from \"./virtual-network-gateway-connection-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 * Reference to a Virtual Network Gateway\n */\nexport interface GatewayReference {\n  /**\n   * Resource ID of the virtual network gateway\n   */\n  readonly id: string;\n}\n\n/**\n * Reference to an ExpressRoute circuit peer\n */\nexport interface PeerReference {\n  /**\n   * Resource ID of the ExpressRoute circuit\n   */\n  readonly id: string;\n}\n\n/**\n * IPsec policy configuration\n */\nexport interface IpsecPolicy {\n  /**\n   * DH Group for IKE Phase 1\n   * @example \"DHGroup14\", \"DHGroup2048\", \"ECP256\", \"ECP384\"\n   */\n  readonly dhGroup: string;\n\n  /**\n   * IKE encryption algorithm\n   * @example \"AES128\", \"AES192\", \"AES256\", \"GCMAES128\", \"GCMAES256\"\n   */\n  readonly ikeEncryption: string;\n\n  /**\n   * IKE integrity algorithm\n   * @example \"SHA256\", \"SHA384\", \"GCMAES128\", \"GCMAES256\"\n   */\n  readonly ikeIntegrity: string;\n\n  /**\n   * IPsec encryption algorithm\n   * @example \"AES128\", \"AES192\", \"AES256\", \"GCMAES128\", \"GCMAES192\", \"GCMAES256\"\n   */\n  readonly ipsecEncryption: string;\n\n  /**\n   * IPsec integrity algorithm\n   * @example \"SHA256\", \"GCMAES128\", \"GCMAES192\", \"GCMAES256\"\n   */\n  readonly ipsecIntegrity: string;\n\n  /**\n   * PFS Group for IKE Phase 2\n   * @example \"None\", \"PFS1\", \"PFS2\", \"PFS2048\", \"ECP256\", \"ECP384\", \"PFS24\", \"PFS14\", \"PFSMM\"\n   */\n  readonly pfsGroup: string;\n\n  /**\n   * SA lifetime in seconds\n   * @example 3600\n   */\n  readonly saLifeTimeSeconds: number;\n\n  /**\n   * SA data size in kilobytes\n   * @example 102400000\n   */\n  readonly saDataSizeKilobytes: number;\n}\n\n/**\n * NAT rule reference\n */\nexport interface NatRuleReference {\n  /**\n   * Resource ID of the NAT rule\n   */\n  readonly id: string;\n}\n\n/**\n * Properties for the Azure Virtual Network Gateway Connection\n *\n * Supports three connection types: IPsec (Site-to-Site), VNet-to-VNet, and ExpressRoute\n */\nexport interface VirtualNetworkGatewayConnectionProps\n  extends AzapiResourceProps {\n  /**\n   * Connection type\n   * Must be \"IPsec\", \"Vnet2Vnet\", or \"ExpressRoute\"\n   */\n  readonly connectionType: \"IPsec\" | \"Vnet2Vnet\" | \"ExpressRoute\";\n\n  /**\n   * Resource group ID where the connection will be created\n   */\n  readonly resourceGroupId: string;\n\n  /**\n   * Reference to the first virtual network gateway\n   * Required for all connection types\n   */\n  readonly virtualNetworkGateway1: GatewayReference;\n\n  /**\n   * Reference to the local network gateway\n   * Required for IPsec connections only\n   */\n  readonly localNetworkGateway2?: GatewayReference;\n\n  /**\n   * Reference to the second virtual network gateway\n   * Required for Vnet2Vnet connections only\n   */\n  readonly virtualNetworkGateway2?: GatewayReference;\n\n  /**\n   * Reference to the ExpressRoute circuit\n   * Required for ExpressRoute connections only\n   */\n  readonly peer?: PeerReference;\n\n  /**\n   * Shared key for the connection\n   * Required for IPsec and Vnet2Vnet connections\n   */\n  readonly sharedKey?: string;\n\n  /**\n   * Authorization key for the ExpressRoute circuit\n   * Optional - for cross-subscription ExpressRoute connections\n   */\n  readonly authorizationKey?: string;\n\n  /**\n   * Connection protocol to use\n   * @defaultValue \"IKEv2\"\n   */\n  readonly connectionProtocol?: \"IKEv2\" | \"IKEv1\";\n\n  /**\n   * Enable BGP for the connection\n   * @defaultValue false\n   */\n  readonly enableBgp?: boolean;\n\n  /**\n   * Routing weight for the connection\n   */\n  readonly routingWeight?: number;\n\n  /**\n   * DPD timeout in seconds\n   */\n  readonly dpdTimeoutSeconds?: number;\n\n  /**\n   * Custom IPsec policies\n   */\n  readonly ipsecPolicies?: IpsecPolicy[];\n\n  /**\n   * Enable policy-based traffic selectors\n   * @defaultValue false\n   */\n  readonly usePolicyBasedTrafficSelectors?: boolean;\n\n  /**\n   * Connection mode\n   * @defaultValue \"Default\"\n   */\n  readonly connectionMode?: \"Default\" | \"ResponderOnly\" | \"InitiatorOnly\";\n\n  /**\n   * Egress NAT rules\n   */\n  readonly egressNatRules?: NatRuleReference[];\n\n  /**\n   * Ingress NAT rules\n   */\n  readonly ingressNatRules?: NatRuleReference[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Azure Virtual Network Gateway Connection implementation\n *\n * This class provides a single, version-aware implementation that replaces\n * version-specific Virtual Network Gateway Connection classes. It automatically handles version\n * resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * Virtual Network Gateway Connections establish connectivity between Virtual Network Gateways\n * and other networking endpoints:\n * - IPsec: Site-to-Site VPN connections to on-premises networks\n * - Vnet2Vnet: VNet-to-VNet connections between Azure virtual networks\n * - ExpressRoute: Private connections to Azure via ExpressRoute circuits\n *\n * @example\n * // IPsec (Site-to-Site VPN) Connection:\n * const s2sConnection = new VirtualNetworkGatewayConnection(this, \"s2sConnection\", {\n *   name: \"my-s2s-connection\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   connectionType: \"IPsec\",\n *   virtualNetworkGateway1: { id: vpnGateway.id },\n *   localNetworkGateway2: { id: localGateway.id },\n *   sharedKey: \"mySecureSharedKey123!\"\n * });\n *\n * @example\n * // VNet-to-VNet Connection:\n * const vnetConnection = new VirtualNetworkGatewayConnection(this, \"vnetConnection\", {\n *   name: \"my-vnet-connection\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   connectionType: \"Vnet2Vnet\",\n *   virtualNetworkGateway1: { id: vpnGateway1.id },\n *   virtualNetworkGateway2: { id: vpnGateway2.id },\n *   sharedKey: \"mySecureSharedKey123!\",\n *   enableBgp: true\n * });\n *\n * @example\n * // ExpressRoute Connection:\n * const erConnection = new VirtualNetworkGatewayConnection(this, \"erConnection\", {\n *   name: \"my-er-connection\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   connectionType: \"ExpressRoute\",\n *   virtualNetworkGateway1: { id: erGateway.id },\n *   peer: { id: expressRouteCircuit.id },\n *   authorizationKey: \"optional-auth-key-if-cross-subscription\"\n * });\n *\n * @example\n * // IPsec Connection with Custom IPsec Policies:\n * const customConnection = new VirtualNetworkGatewayConnection(this, \"customConnection\", {\n *   name: \"my-custom-connection\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   connectionType: \"IPsec\",\n *   virtualNetworkGateway1: { id: vpnGateway.id },\n *   localNetworkGateway2: { id: localGateway.id },\n *   sharedKey: \"mySecureSharedKey123!\",\n *   connectionProtocol: \"IKEv2\",\n *   ipsecPolicies: [{\n *     dhGroup: \"DHGroup14\",\n *     ikeEncryption: \"AES256\",\n *     ikeIntegrity: \"SHA256\",\n *     ipsecEncryption: \"AES256\",\n *     ipsecIntegrity: \"SHA256\",\n *     pfsGroup: \"PFS2048\",\n *     saLifeTimeSeconds: 3600,\n *     saDataSizeKilobytes: 102400000\n *   }],\n *   usePolicyBasedTrafficSelectors: true\n * });\n *\n * @stability stable\n */\nexport class VirtualNetworkGatewayConnection extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      VIRTUAL_NETWORK_GATEWAY_CONNECTION_TYPE,\n      ALL_VIRTUAL_NETWORK_GATEWAY_CONNECTION_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Virtual Network Gateway Connection instance\n   */\n  public readonly props: VirtualNetworkGatewayConnectionProps;\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 Connection 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 Connection 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 Connection\n   */\n  constructor(\n    scope: Construct,\n    id: string,\n    props: VirtualNetworkGatewayConnectionProps,\n  ) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Add timeouts for connection provisioning (typically 30 minutes)\n    this.terraformResource.addOverride(\"timeouts\", {\n      create: \"30m\",\n      update: \"30m\",\n      delete: \"30m\",\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 Connection\",\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 Connection\",\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 Connection\",\n    });\n\n    this.tagsOutput = new cdktf.TerraformOutput(this, \"tags\", {\n      value: `\\${${this.terraformResource.fqn}.tags}`,\n      description:\n        \"The tags assigned to the Virtual Network Gateway Connection\",\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 Gateway Connections\n   */\n  protected resourceType(): string {\n    return VIRTUAL_NETWORK_GATEWAY_CONNECTION_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 Gateway Connections\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   * Handles type-specific properties based on connectionType\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as VirtualNetworkGatewayConnectionProps;\n\n    // Build the properties object based on connection type\n    const properties: any = {\n      connectionType: typedProps.connectionType,\n      virtualNetworkGateway1: {\n        id: typedProps.virtualNetworkGateway1.id,\n        properties: {},\n      },\n      connectionProtocol: typedProps.connectionProtocol || \"IKEv2\",\n      enableBgp: typedProps.enableBgp || false,\n    };\n\n    // Add optional common properties\n    if (typedProps.routingWeight !== undefined) {\n      properties.routingWeight = typedProps.routingWeight;\n    }\n    if (typedProps.dpdTimeoutSeconds !== undefined) {\n      properties.dpdTimeoutSeconds = typedProps.dpdTimeoutSeconds;\n    }\n    if (typedProps.ipsecPolicies !== undefined) {\n      properties.ipsecPolicies = typedProps.ipsecPolicies;\n    }\n    if (typedProps.usePolicyBasedTrafficSelectors !== undefined) {\n      properties.usePolicyBasedTrafficSelectors =\n        typedProps.usePolicyBasedTrafficSelectors;\n    }\n    if (typedProps.connectionMode !== undefined) {\n      properties.connectionMode = typedProps.connectionMode;\n    }\n    if (typedProps.egressNatRules !== undefined) {\n      properties.egressNatRules = typedProps.egressNatRules;\n    }\n    if (typedProps.ingressNatRules !== undefined) {\n      properties.ingressNatRules = typedProps.ingressNatRules;\n    }\n\n    // Add connection type-specific properties\n    switch (typedProps.connectionType) {\n      case \"IPsec\":\n        properties.localNetworkGateway2 = {\n          id: typedProps.localNetworkGateway2!.id,\n          properties: {},\n        };\n        properties.sharedKey = typedProps.sharedKey;\n        break;\n\n      case \"Vnet2Vnet\":\n        properties.virtualNetworkGateway2 = {\n          id: typedProps.virtualNetworkGateway2!.id,\n          properties: {},\n        };\n        properties.sharedKey = typedProps.sharedKey;\n        break;\n\n      case \"ExpressRoute\":\n        properties.peer = typedProps.peer;\n        if (typedProps.authorizationKey !== undefined) {\n          properties.authorizationKey = typedProps.authorizationKey;\n        }\n        break;\n    }\n\n    return {\n      location: this.location,\n      tags: this.allTags(),\n      properties: properties,\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL NETWORK GATEWAY CONNECTION OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the subscription ID from the Virtual Network Gateway Connection 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 Connection 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 Connection\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 Connection\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 Connection
3
+ *
4
+ * This test demonstrates basic usage of the VirtualNetworkGatewayConnection construct
5
+ * by creating a VNet-to-VNet connection between two virtual network gateways.
6
+ *
7
+ * Note: Virtual Network Gateways take 30-45 minutes each to provision,
8
+ * so this test has an extended timeout (~120 minutes total).
9
+ *
10
+ * Run with: npm run integration:nostream
11
+ */
12
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,216 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure Virtual Network Gateway Connection
4
+ *
5
+ * This test demonstrates basic usage of the VirtualNetworkGatewayConnection construct
6
+ * by creating a VNet-to-VNet connection between two virtual network gateways.
7
+ *
8
+ * Note: Virtual Network Gateways take 30-45 minutes each to provision,
9
+ * so this test has an extended timeout (~120 minutes total).
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 azure_virtualnetworkgateway_1 = require("../../azure-virtualnetworkgateway");
21
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
22
+ const testing_1 = require("../../testing");
23
+ const metadata_1 = require("../../testing/lib/metadata");
24
+ const virtual_network_gateway_connection_1 = require("../lib/virtual-network-gateway-connection");
25
+ // Generate unique test run metadata for this test suite
26
+ const testMetadata = new metadata_1.TestRunMetadata("virtual-network-gateway-connection-integration", {
27
+ maxAgeHours: 4,
28
+ });
29
+ /**
30
+ * Example stack demonstrating Virtual Network Gateway Connection usage
31
+ * Creates two gateways and a VNet-to-VNet connection between them
32
+ */
33
+ class VirtualNetworkGatewayConnectionExampleStack extends testing_1.BaseTestStack {
34
+ constructor(scope, id) {
35
+ super(scope, id, {
36
+ testRunOptions: {
37
+ maxAgeHours: testMetadata.maxAgeHours,
38
+ autoCleanup: testMetadata.autoCleanup,
39
+ cleanupPolicy: testMetadata.cleanupPolicy,
40
+ },
41
+ });
42
+ // Configure AZAPI provider
43
+ new provider_1.AzapiProvider(this, "azapi", {});
44
+ // Generate unique names
45
+ const rgName = this.generateResourceName("Microsoft.Resources/resourceGroups", "conn");
46
+ // Create resource group
47
+ const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "rg", {
48
+ name: rgName,
49
+ location: "eastus",
50
+ tags: {
51
+ ...this.systemTags(),
52
+ },
53
+ });
54
+ // ===== First Virtual Network and Gateway =====
55
+ const vnet1 = new azure_virtualnetwork_1.VirtualNetwork(this, "vnet1", {
56
+ name: "vnet1-conn-example",
57
+ location: "eastus",
58
+ resourceGroupId: resourceGroup.id,
59
+ addressSpace: {
60
+ addressPrefixes: ["10.1.0.0/16"],
61
+ },
62
+ tags: {
63
+ ...this.systemTags(),
64
+ },
65
+ });
66
+ const gatewaySubnet1 = new azure_subnet_1.Subnet(this, "gateway-subnet1", {
67
+ name: "GatewaySubnet",
68
+ virtualNetworkName: "vnet1-conn-example",
69
+ virtualNetworkId: vnet1.id,
70
+ resourceGroupId: resourceGroup.id,
71
+ addressPrefix: "10.1.1.0/24",
72
+ });
73
+ const publicIp1 = new azure_publicipaddress_1.PublicIPAddress(this, "public-ip1", {
74
+ name: "pip-gateway1-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
+ const gateway1 = new azure_virtualnetworkgateway_1.VirtualNetworkGateway(this, "vpn-gateway1", {
87
+ name: "vng1-conn-example",
88
+ location: "eastus",
89
+ resourceGroupId: resourceGroup.id,
90
+ gatewayType: "Vpn",
91
+ vpnType: "RouteBased",
92
+ sku: {
93
+ name: "VpnGw1",
94
+ tier: "VpnGw1",
95
+ },
96
+ ipConfigurations: [
97
+ {
98
+ name: "default",
99
+ subnetId: gatewaySubnet1.id,
100
+ publicIPAddressId: publicIp1.id,
101
+ },
102
+ ],
103
+ tags: {
104
+ ...this.systemTags(),
105
+ },
106
+ });
107
+ // ===== Second Virtual Network and Gateway =====
108
+ const vnet2 = new azure_virtualnetwork_1.VirtualNetwork(this, "vnet2", {
109
+ name: "vnet2-conn-example",
110
+ location: "eastus",
111
+ resourceGroupId: resourceGroup.id,
112
+ addressSpace: {
113
+ addressPrefixes: ["10.2.0.0/16"],
114
+ },
115
+ tags: {
116
+ ...this.systemTags(),
117
+ },
118
+ });
119
+ const gatewaySubnet2 = new azure_subnet_1.Subnet(this, "gateway-subnet2", {
120
+ name: "GatewaySubnet",
121
+ virtualNetworkName: "vnet2-conn-example",
122
+ virtualNetworkId: vnet2.id,
123
+ resourceGroupId: resourceGroup.id,
124
+ addressPrefix: "10.2.1.0/24",
125
+ });
126
+ const publicIp2 = new azure_publicipaddress_1.PublicIPAddress(this, "public-ip2", {
127
+ name: "pip-gateway2-example",
128
+ location: "eastus",
129
+ resourceGroupId: resourceGroup.id,
130
+ sku: {
131
+ name: "Standard",
132
+ tier: "Regional",
133
+ },
134
+ publicIPAllocationMethod: "Static",
135
+ tags: {
136
+ ...this.systemTags(),
137
+ },
138
+ });
139
+ const gateway2 = new azure_virtualnetworkgateway_1.VirtualNetworkGateway(this, "vpn-gateway2", {
140
+ name: "vng2-conn-example",
141
+ location: "eastus",
142
+ resourceGroupId: resourceGroup.id,
143
+ gatewayType: "Vpn",
144
+ vpnType: "RouteBased",
145
+ sku: {
146
+ name: "VpnGw1",
147
+ tier: "VpnGw1",
148
+ },
149
+ ipConfigurations: [
150
+ {
151
+ name: "default",
152
+ subnetId: gatewaySubnet2.id,
153
+ publicIPAddressId: publicIp2.id,
154
+ },
155
+ ],
156
+ tags: {
157
+ ...this.systemTags(),
158
+ },
159
+ });
160
+ // ===== VNet-to-VNet Connections =====
161
+ // Connection from gateway1 to gateway2
162
+ new virtual_network_gateway_connection_1.VirtualNetworkGatewayConnection(this, "vnet-to-vnet-conn1", {
163
+ name: "conn1to2-example",
164
+ location: "eastus",
165
+ resourceGroupId: resourceGroup.id,
166
+ connectionType: "Vnet2Vnet",
167
+ virtualNetworkGateway1: {
168
+ id: gateway1.id,
169
+ },
170
+ virtualNetworkGateway2: {
171
+ id: gateway2.id,
172
+ },
173
+ sharedKey: "SecureSharedKey123!",
174
+ tags: {
175
+ ...this.systemTags(),
176
+ example: "vnet-to-vnet",
177
+ direction: "1-to-2",
178
+ },
179
+ });
180
+ // Connection from gateway2 to gateway1 (bidirectional)
181
+ new virtual_network_gateway_connection_1.VirtualNetworkGatewayConnection(this, "vnet-to-vnet-conn2", {
182
+ name: "conn2to1-example",
183
+ location: "eastus",
184
+ resourceGroupId: resourceGroup.id,
185
+ connectionType: "Vnet2Vnet",
186
+ virtualNetworkGateway1: {
187
+ id: gateway2.id,
188
+ },
189
+ virtualNetworkGateway2: {
190
+ id: gateway1.id,
191
+ },
192
+ sharedKey: "SecureSharedKey123!",
193
+ tags: {
194
+ ...this.systemTags(),
195
+ example: "vnet-to-vnet",
196
+ direction: "2-to-1",
197
+ },
198
+ });
199
+ }
200
+ }
201
+ describe.skip("Virtual Network Gateway Connection Integration Test", () => {
202
+ // NOTE: This test takes 60-90 minutes due to gateway provisioning time (2 gateways).
203
+ // This test provisions two complete VPN gateways and tests VNet-to-VNet connections.
204
+ // SKIPPED BY DEFAULT: Run explicitly with: jest --testNamePattern="Virtual Network Gateway Connection"
205
+ it("should deploy gateways and connections, validate idempotency, and cleanup", () => {
206
+ const app = cdktf_1.Testing.app();
207
+ const stack = new VirtualNetworkGatewayConnectionExampleStack(app, "test-virtual-network-gateway-connection");
208
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
209
+ // This will:
210
+ // 1. Run terraform apply to deploy resources (2 gateways + 2 connections)
211
+ // 2. Run terraform plan to check idempotency (no changes expected)
212
+ // 3. Run terraform destroy to cleanup resources
213
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
214
+ }, 7200000); // 120 minutes timeout (2 hours) for dual gateway provisioning
215
+ });
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-gateway-connection.integ.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkgatewayconnection/test/virtual-network-gateway-connection.integ.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Integration test for Azure Virtual Network Gateway Connection\n *\n * This test demonstrates basic usage of the VirtualNetworkGatewayConnection construct\n * by creating a VNet-to-VNet connection between two virtual network gateways.\n *\n * Note: Virtual Network Gateways take 30-45 minutes each to provision,\n * so this test has an extended timeout (~120 minutes total).\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 { VirtualNetworkGateway } from \"../../azure-virtualnetworkgateway\";\nimport { AzapiProvider } from \"../../core-azure/lib/azapi/providers-azapi/provider\";\nimport { BaseTestStack, TerraformApplyCheckAndDestroy } from \"../../testing\";\nimport { TestRunMetadata } from \"../../testing/lib/metadata\";\nimport { VirtualNetworkGatewayConnection } from \"../lib/virtual-network-gateway-connection\";\n\n// Generate unique test run metadata for this test suite\nconst testMetadata = new TestRunMetadata(\n  \"virtual-network-gateway-connection-integration\",\n  {\n    maxAgeHours: 4,\n  },\n);\n\n/**\n * Example stack demonstrating Virtual Network Gateway Connection usage\n * Creates two gateways and a VNet-to-VNet connection between them\n */\nclass VirtualNetworkGatewayConnectionExampleStack 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      \"conn\",\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    // ===== First Virtual Network and Gateway =====\n    const vnet1 = new VirtualNetwork(this, \"vnet1\", {\n      name: \"vnet1-conn-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.1.0.0/16\"],\n      },\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    const gatewaySubnet1 = new Subnet(this, \"gateway-subnet1\", {\n      name: \"GatewaySubnet\",\n      virtualNetworkName: \"vnet1-conn-example\",\n      virtualNetworkId: vnet1.id,\n      resourceGroupId: resourceGroup.id,\n      addressPrefix: \"10.1.1.0/24\",\n    });\n\n    const publicIp1 = new PublicIPAddress(this, \"public-ip1\", {\n      name: \"pip-gateway1-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    const gateway1 = new VirtualNetworkGateway(this, \"vpn-gateway1\", {\n      name: \"vng1-conn-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: gatewaySubnet1.id,\n          publicIPAddressId: publicIp1.id,\n        },\n      ],\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // ===== Second Virtual Network and Gateway =====\n    const vnet2 = new VirtualNetwork(this, \"vnet2\", {\n      name: \"vnet2-conn-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      addressSpace: {\n        addressPrefixes: [\"10.2.0.0/16\"],\n      },\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    const gatewaySubnet2 = new Subnet(this, \"gateway-subnet2\", {\n      name: \"GatewaySubnet\",\n      virtualNetworkName: \"vnet2-conn-example\",\n      virtualNetworkId: vnet2.id,\n      resourceGroupId: resourceGroup.id,\n      addressPrefix: \"10.2.1.0/24\",\n    });\n\n    const publicIp2 = new PublicIPAddress(this, \"public-ip2\", {\n      name: \"pip-gateway2-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    const gateway2 = new VirtualNetworkGateway(this, \"vpn-gateway2\", {\n      name: \"vng2-conn-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: gatewaySubnet2.id,\n          publicIPAddressId: publicIp2.id,\n        },\n      ],\n      tags: {\n        ...this.systemTags(),\n      },\n    });\n\n    // ===== VNet-to-VNet Connections =====\n    // Connection from gateway1 to gateway2\n    new VirtualNetworkGatewayConnection(this, \"vnet-to-vnet-conn1\", {\n      name: \"conn1to2-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      connectionType: \"Vnet2Vnet\",\n      virtualNetworkGateway1: {\n        id: gateway1.id,\n      },\n      virtualNetworkGateway2: {\n        id: gateway2.id,\n      },\n      sharedKey: \"SecureSharedKey123!\",\n      tags: {\n        ...this.systemTags(),\n        example: \"vnet-to-vnet\",\n        direction: \"1-to-2\",\n      },\n    });\n\n    // Connection from gateway2 to gateway1 (bidirectional)\n    new VirtualNetworkGatewayConnection(this, \"vnet-to-vnet-conn2\", {\n      name: \"conn2to1-example\",\n      location: \"eastus\",\n      resourceGroupId: resourceGroup.id,\n      connectionType: \"Vnet2Vnet\",\n      virtualNetworkGateway1: {\n        id: gateway2.id,\n      },\n      virtualNetworkGateway2: {\n        id: gateway1.id,\n      },\n      sharedKey: \"SecureSharedKey123!\",\n      tags: {\n        ...this.systemTags(),\n        example: \"vnet-to-vnet\",\n        direction: \"2-to-1\",\n      },\n    });\n  }\n}\n\ndescribe.skip(\"Virtual Network Gateway Connection Integration Test\", () => {\n  // NOTE: This test takes 60-90 minutes due to gateway provisioning time (2 gateways).\n  // This test provisions two complete VPN gateways and tests VNet-to-VNet connections.\n  // SKIPPED BY DEFAULT: Run explicitly with: jest --testNamePattern=\"Virtual Network Gateway Connection\"\n  it(\"should deploy gateways and connections, validate idempotency, and cleanup\", () => {\n    const app = Testing.app();\n    const stack = new VirtualNetworkGatewayConnectionExampleStack(\n      app,\n      \"test-virtual-network-gateway-connection\",\n    );\n    const synthesized = Testing.fullSynth(stack);\n\n    // This will:\n    // 1. Run terraform apply to deploy resources (2 gateways + 2 connections)\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  }, 7200000); // 120 minutes timeout (2 hours) for dual gateway provisioning\n});\n"]}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Comprehensive tests for the Virtual Network Gateway Connection implementation
3
+ *
4
+ * This test suite validates the VirtualNetworkGatewayConnection class using the AzapiResource framework.
5
+ * Tests cover automatic version resolution, explicit version pinning, schema validation,
6
+ * property transformation, and resource creation for all connection types.
7
+ */
8
+ export {};