@microsoft/terraform-cdk-constructs 1.3.1 → 1.4.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 (72) hide show
  1. package/.jsii +10617 -7822
  2. package/API.md +25592 -20586
  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-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  30. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
  31. package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
  32. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
  33. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
  34. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
  35. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
  36. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
  37. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
  38. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
  39. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
  40. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  41. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  42. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  43. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  44. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  45. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.d.ts +225 -0
  46. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
  47. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
  48. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
  49. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
  50. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
  51. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
  52. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
  53. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
  54. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
  55. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
  56. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
  57. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
  58. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  59. package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
  60. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  61. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  62. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  63. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  64. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  65. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  66. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  67. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  68. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  69. package/lib/testing/index.js +2 -2
  70. package/lib/testing/lib/cleanup.js +1 -1
  71. package/lib/testing/lib/metadata.js +1 -1
  72. package/package.json +1 -1
@@ -21,6 +21,7 @@ import * as cdktf from "cdktf";
21
21
  import { Construct } from "constructs";
22
22
  import { ConnectivityConfiguration } from "./connectivity-configuration";
23
23
  import { ConnectivityGroupItem, Hub } from "./connectivity-configuration-schemas";
24
+ import { IpamPool } from "./ipam-pool";
24
25
  import { NetworkGroup } from "./network-group";
25
26
  import { SecurityAdminConfiguration } from "./security-admin-configuration";
26
27
  import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
@@ -165,6 +166,40 @@ export interface AddSecurityAdminConfigurationProps extends AzapiResourceProps {
165
166
  */
166
167
  readonly ignoreChanges?: string[];
167
168
  }
169
+ /**
170
+ * Properties for adding an IpamPool via the convenience method
171
+ * This interface excludes networkManagerId as it's automatically set
172
+ */
173
+ export interface AddIpamPoolProps extends AzapiResourceProps {
174
+ /**
175
+ * IP address prefixes for the pool
176
+ * Must be valid CIDR notation (e.g., "10.0.0.0/8")
177
+ * Multiple prefixes must not overlap
178
+ * @example ["10.0.0.0/8", "172.16.0.0/12"]
179
+ */
180
+ readonly addressPrefixes: string[];
181
+ /**
182
+ * Optional description of the IPAM pool
183
+ * @example "Production IP address pool for East US region"
184
+ */
185
+ readonly description?: string;
186
+ /**
187
+ * Optional friendly display name
188
+ * @example "East US Production Pool"
189
+ */
190
+ readonly displayName?: string;
191
+ /**
192
+ * Name of parent pool for hierarchical pools
193
+ * Leave empty/undefined for root pools
194
+ * @example "root-pool"
195
+ */
196
+ readonly parentPoolName?: string;
197
+ /**
198
+ * The lifecycle rules to ignore changes
199
+ * @example ["tags"]
200
+ */
201
+ readonly ignoreChanges?: string[];
202
+ }
168
203
  /**
169
204
  * Properties for Virtual Network Manager body
170
205
  */
@@ -330,6 +365,27 @@ export declare class VirtualNetworkManager extends AzapiResource {
330
365
  * });
331
366
  */
332
367
  addSecurityAdminConfiguration(id: string, props: AddSecurityAdminConfigurationProps): SecurityAdminConfiguration;
368
+ /**
369
+ * Convenience method to create an IpamPool
370
+ *
371
+ * This is a helper method that creates an IpamPool with the networkManagerId
372
+ * automatically set to this Network Manager's ID. You can also create IpamPools
373
+ * directly using: new IpamPool(scope, id, { networkManagerId: vnm.id, ...props })
374
+ *
375
+ * @param id - The unique identifier for the IPAM pool construct
376
+ * @param props - IpamPool properties (networkManagerId will be set automatically)
377
+ * @returns The created IpamPool instance
378
+ *
379
+ * @example
380
+ * const ipamPool = networkManager.addIpamPool("prod-pool", {
381
+ * name: "production-pool",
382
+ * location: "eastus",
383
+ * addressPrefixes: ["10.0.0.0/8"],
384
+ * description: "Production IP address pool",
385
+ * displayName: "Production Pool"
386
+ * });
387
+ */
388
+ addIpamPool(id: string, props: AddIpamPoolProps): IpamPool;
333
389
  /**
334
390
  * Applies ignore changes lifecycle rules if specified in props
335
391
  */
@@ -24,6 +24,7 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
24
24
  */
25
25
  const cdktf = require("cdktf");
26
26
  const connectivity_configuration_1 = require("./connectivity-configuration");
27
+ const ipam_pool_1 = require("./ipam-pool");
27
28
  const network_group_1 = require("./network-group");
28
29
  const security_admin_configuration_1 = require("./security-admin-configuration");
29
30
  const virtual_network_manager_schemas_1 = require("./virtual-network-manager-schemas");
@@ -260,6 +261,32 @@ class VirtualNetworkManager extends azapi_resource_1.AzapiResource {
260
261
  networkManagerId: this.id,
261
262
  });
262
263
  }
264
+ /**
265
+ * Convenience method to create an IpamPool
266
+ *
267
+ * This is a helper method that creates an IpamPool with the networkManagerId
268
+ * automatically set to this Network Manager's ID. You can also create IpamPools
269
+ * directly using: new IpamPool(scope, id, { networkManagerId: vnm.id, ...props })
270
+ *
271
+ * @param id - The unique identifier for the IPAM pool construct
272
+ * @param props - IpamPool properties (networkManagerId will be set automatically)
273
+ * @returns The created IpamPool instance
274
+ *
275
+ * @example
276
+ * const ipamPool = networkManager.addIpamPool("prod-pool", {
277
+ * name: "production-pool",
278
+ * location: "eastus",
279
+ * addressPrefixes: ["10.0.0.0/8"],
280
+ * description: "Production IP address pool",
281
+ * displayName: "Production Pool"
282
+ * });
283
+ */
284
+ addIpamPool(id, props) {
285
+ return new ipam_pool_1.IpamPool(this, id, {
286
+ ...props,
287
+ networkManagerId: this.id,
288
+ });
289
+ }
263
290
  // =============================================================================
264
291
  // PRIVATE HELPER METHODS
265
292
  // =============================================================================
@@ -276,8 +303,8 @@ class VirtualNetworkManager extends azapi_resource_1.AzapiResource {
276
303
  }
277
304
  exports.VirtualNetworkManager = VirtualNetworkManager;
278
305
  _a = JSII_RTTI_SYMBOL_1;
279
- VirtualNetworkManager[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualNetworkManager", version: "1.3.1" };
306
+ VirtualNetworkManager[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualNetworkManager", version: "1.4.0" };
280
307
  (() => {
281
308
  azapi_resource_1.AzapiResource.registerSchemas(virtual_network_manager_schemas_1.VIRTUAL_NETWORK_MANAGER_TYPE, virtual_network_manager_schemas_1.ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS);
282
309
  })();
283
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-manager.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/lib/virtual-network-manager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Virtual Network Manager implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Virtual Network Managers that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2023-11-01 (Maintenance)\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 * - Convenience methods for creating child resources\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ConnectivityConfiguration } from \"./connectivity-configuration\";\nimport {\n  ConnectivityGroupItem,\n  Hub,\n} from \"./connectivity-configuration-schemas\";\nimport { NetworkGroup } from \"./network-group\";\nimport { SecurityAdminConfiguration } from \"./security-admin-configuration\";\nimport {\n  ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS,\n  VIRTUAL_NETWORK_MANAGER_TYPE,\n} from \"./virtual-network-manager-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 * Scope configuration for Virtual Network Manager\n */\nexport interface NetworkManagerScopes {\n  /**\n   * Array of management group IDs that define the scope\n   * @example [\"/providers/Microsoft.Management/managementGroups/mg1\"]\n   */\n  readonly managementGroups?: string[];\n\n  /**\n   * Array of subscription IDs that define the scope\n   * @example [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n   */\n  readonly subscriptions?: string[];\n}\n\n/**\n * Properties for the Azure Virtual Network Manager\n *\n * Extends AzapiResourceProps with Virtual Network Manager specific properties\n */\nexport interface VirtualNetworkManagerProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the resource group where the network manager will be created\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/my-rg\"\n   */\n  readonly resourceGroupId: string;\n\n  /**\n   * Defines the scope of management (management groups and/or subscriptions)\n   * At least one of managementGroups or subscriptions must be specified\n   */\n  readonly networkManagerScopes: NetworkManagerScopes;\n\n  /**\n   * Array of features enabled for the network manager\n   * Valid values: \"Connectivity\", \"SecurityAdmin\", \"Routing\"\n   * @example [\"Connectivity\", \"SecurityAdmin\"]\n   */\n  readonly networkManagerScopeAccesses: (\n    | \"Connectivity\"\n    | \"SecurityAdmin\"\n    | \"Routing\"\n  )[];\n\n  /**\n   * Optional description of the network manager\n   * @example \"Central network management for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a NetworkGroup via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddNetworkGroupProps extends AzapiResourceProps {\n  /**\n   * Optional description of the network group\n   * @example \"Production virtual networks for region East US\"\n   */\n  readonly description?: string;\n\n  /**\n   * Type of members in this network group\n   * @default undefined (can contain both VirtualNetwork and Subnet members)\n   * @example \"VirtualNetwork\"\n   * @example \"Subnet\"\n   */\n  readonly memberType?: \"VirtualNetwork\" | \"Subnet\";\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a ConnectivityConfiguration via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddConnectivityConfigurationProps extends AzapiResourceProps {\n  /**\n   * Optional description of the connectivity configuration\n   * @example \"Hub-and-spoke topology for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * Connectivity topology type\n   * - HubAndSpoke: Central hub with spoke VNets\n   * - Mesh: All VNets can communicate directly\n   * @example \"HubAndSpoke\"\n   * @example \"Mesh\"\n   */\n  readonly connectivityTopology: \"HubAndSpoke\" | \"Mesh\";\n\n  /**\n   * Network groups to apply this configuration to\n   * Each item specifies a network group and how it should connect\n   */\n  readonly appliesToGroups: ConnectivityGroupItem[];\n\n  /**\n   * Hub VNets for hub-and-spoke topology\n   * Required when connectivityTopology is \"HubAndSpoke\"\n   * @example [{ resourceId: \"/subscriptions/.../virtualNetworks/hub-vnet\", resourceType: \"Microsoft.Network/virtualNetworks\" }]\n   */\n  readonly hubs?: Hub[];\n\n  /**\n   * Enable global mesh connectivity\n   * Allows mesh connectivity across regions\n   * @default false\n   */\n  readonly isGlobal?: boolean;\n\n  /**\n   * Delete existing peerings when applying this configuration\n   * @default false\n   */\n  readonly deleteExistingPeering?: boolean;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a SecurityAdminConfiguration via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddSecurityAdminConfigurationProps extends AzapiResourceProps {\n  /**\n   * Optional description of the security admin configuration\n   * @example \"Organization-wide security rules for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * Services to apply the security admin configuration on\n   * @example [\"None\"]\n   * @example [\"All\"]\n   */\n  readonly applyOnNetworkIntentPolicyBasedServices?: string[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for Virtual Network Manager body\n */\nexport interface VirtualNetworkManagerProperties {\n  readonly networkManagerScopes: NetworkManagerScopes;\n  readonly networkManagerScopeAccesses: string[];\n  readonly description?: string;\n}\n\n/**\n * The resource body interface for Azure Virtual Network Manager API calls\n */\nexport interface VirtualNetworkManagerBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties: VirtualNetworkManagerProperties;\n}\n\n/**\n * Azure Virtual Network Manager implementation\n *\n * This class provides a single, version-aware implementation that handles\n * version resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * @example\n * // Basic usage with automatic version resolution:\n * const networkManager = new VirtualNetworkManager(this, \"manager\", {\n *   name: \"my-network-manager\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   networkManagerScopes: {\n *     subscriptions: [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n *   },\n *   networkManagerScopeAccesses: [\"Connectivity\", \"SecurityAdmin\"]\n * });\n *\n * @example\n * // Usage with explicit version pinning:\n * const networkManager = new VirtualNetworkManager(this, \"manager\", {\n *   name: \"my-network-manager\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2024-05-01\",\n *   networkManagerScopes: {\n *     subscriptions: [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n *   },\n *   networkManagerScopeAccesses: [\"Connectivity\", \"SecurityAdmin\"]\n * });\n *\n * @stability stable\n */\nexport class VirtualNetworkManager extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      VIRTUAL_NETWORK_MANAGER_TYPE,\n      ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Virtual Network Manager instance\n   */\n  public readonly props: VirtualNetworkManagerProps;\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  public readonly scopeOutput: cdktf.TerraformOutput;\n  public readonly scopeAccessesOutput: cdktf.TerraformOutput;\n\n  // Public properties that match the standard interface\n  public readonly resourceName: string;\n\n  /**\n   * Creates a new Azure Virtual Network Manager 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 Manager 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 Manager\n   */\n  constructor(scope: Construct, id: string, props: VirtualNetworkManagerProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n    this.resourceName = `\\${${this.terraformResource.fqn}.name}`;\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 Manager\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: this.resourceName,\n      description: \"The name of the Virtual Network Manager\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Virtual Network Manager\",\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 Manager\",\n    });\n\n    this.scopeOutput = new cdktf.TerraformOutput(this, \"scope\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.networkManagerScopes}`,\n      description: \"The management scope of the Virtual Network Manager\",\n    });\n\n    this.scopeAccessesOutput = new cdktf.TerraformOutput(\n      this,\n      \"scopeAccesses\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.networkManagerScopeAccesses}`,\n        description: \"The enabled features of the Virtual Network Manager\",\n      },\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    this.scopeOutput.overrideLogicalId(\"scope\");\n    this.scopeAccessesOutput.overrideLogicalId(\"scopeAccesses\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Resolves the parent resource ID for the Network Manager\n   * Network Managers are scoped to resource groups\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as VirtualNetworkManagerProps;\n    return typedProps.resourceGroupId;\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 Managers\n   */\n  protected resourceType(): string {\n    return \"Microsoft.Network/networkManagers\";\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   * 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 VirtualNetworkManagerProps;\n    return {\n      location: typedProps.location,\n      tags: this.allTags(),\n      properties: {\n        networkManagerScopes: typedProps.networkManagerScopes,\n        networkManagerScopeAccesses: typedProps.networkManagerScopeAccesses,\n        description: typedProps.description,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL NETWORK MANAGER OPERATIONS\n  // =============================================================================\n\n  /**\n   * Add a tag to the Virtual Network Manager\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    // Apply the tag directly to the resource\n    this.terraformResource.addOverride(`tags.${key}`, value);\n  }\n\n  /**\n   * Remove a tag from the Virtual Network Manager\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      // Remove the tag from the resource\n      this.terraformResource.addOverride(`tags.${key}`, null);\n    }\n  }\n\n  // =============================================================================\n  // CONVENIENCE METHODS FOR CHILD RESOURCES (OPTION A - HYBRID APPROACH)\n  // =============================================================================\n\n  /**\n   * Convenience method to create a NetworkGroup\n   *\n   * This is a helper method that creates a NetworkGroup with the networkManagerId\n   * automatically set to this Network Manager's ID. You can also create NetworkGroups\n   * directly using: new NetworkGroup(scope, id, { networkManagerId: vnm.id, ...props })\n   *\n   * @param id - The unique identifier for the network group construct\n   * @param props - NetworkGroup properties (networkManagerId will be set automatically)\n   * @returns The created NetworkGroup instance\n   *\n   * @example\n   * const prodGroup = networkManager.addNetworkGroup(\"prod-group\", {\n   *   name: \"production-vnets\",\n   *   description: \"Production virtual networks\",\n   *   memberType: \"VirtualNetwork\"\n   * });\n   */\n  public addNetworkGroup(\n    id: string,\n    props: AddNetworkGroupProps,\n  ): NetworkGroup {\n    return new NetworkGroup(this, id, {\n      ...props,\n      networkManagerId: this.id,\n    });\n  }\n\n  /**\n   * Convenience method to create a ConnectivityConfiguration\n   *\n   * This is a helper method that creates a ConnectivityConfiguration with the\n   * networkManagerId automatically set to this Network Manager's ID.\n   *\n   * @param id - The unique identifier for the connectivity configuration construct\n   * @param props - ConnectivityConfiguration properties (networkManagerId will be set automatically)\n   * @returns The created ConnectivityConfiguration instance\n   *\n   * @example\n   * const hubSpoke = networkManager.addConnectivityConfiguration(\"hub-spoke\", {\n   *   name: \"production-hub-spoke\",\n   *   connectivityTopology: \"HubAndSpoke\",\n   *   appliesToGroups: [{ networkGroupId: prodGroup.id }],\n   *   hubs: [{ resourceId: hubVnet.id, resourceType: \"Microsoft.Network/virtualNetworks\" }]\n   * });\n   */\n  public addConnectivityConfiguration(\n    id: string,\n    props: AddConnectivityConfigurationProps,\n  ): ConnectivityConfiguration {\n    return new ConnectivityConfiguration(this, id, {\n      ...props,\n      networkManagerId: this.id,\n    });\n  }\n\n  /**\n   * Convenience method to create a SecurityAdminConfiguration\n   *\n   * This is a helper method that creates a SecurityAdminConfiguration with the\n   * networkManagerId automatically set to this Network Manager's ID.\n   *\n   * @param id - The unique identifier for the security admin configuration construct\n   * @param props - SecurityAdminConfiguration properties (networkManagerId will be set automatically)\n   * @returns The created SecurityAdminConfiguration instance\n   *\n   * @example\n   * const securityConfig = networkManager.addSecurityAdminConfiguration(\"security\", {\n   *   name: \"production-security\",\n   *   description: \"High-priority security rules for production\"\n   * });\n   */\n  public addSecurityAdminConfiguration(\n    id: string,\n    props: AddSecurityAdminConfigurationProps,\n  ): SecurityAdminConfiguration {\n    return new SecurityAdminConfiguration(this, id, {\n      ...props,\n      networkManagerId: this.id,\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"]}
310
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"virtual-network-manager.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/lib/virtual-network-manager.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Virtual Network Manager implementation using AzapiResource framework\n *\n * This class provides a unified implementation for Azure Virtual Network Managers that\n * automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2023-11-01 (Maintenance)\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 * - Convenience methods for creating child resources\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { ConnectivityConfiguration } from \"./connectivity-configuration\";\nimport {\n  ConnectivityGroupItem,\n  Hub,\n} from \"./connectivity-configuration-schemas\";\nimport { IpamPool } from \"./ipam-pool\";\nimport { NetworkGroup } from \"./network-group\";\nimport { SecurityAdminConfiguration } from \"./security-admin-configuration\";\nimport {\n  ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS,\n  VIRTUAL_NETWORK_MANAGER_TYPE,\n} from \"./virtual-network-manager-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 * Scope configuration for Virtual Network Manager\n */\nexport interface NetworkManagerScopes {\n  /**\n   * Array of management group IDs that define the scope\n   * @example [\"/providers/Microsoft.Management/managementGroups/mg1\"]\n   */\n  readonly managementGroups?: string[];\n\n  /**\n   * Array of subscription IDs that define the scope\n   * @example [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n   */\n  readonly subscriptions?: string[];\n}\n\n/**\n * Properties for the Azure Virtual Network Manager\n *\n * Extends AzapiResourceProps with Virtual Network Manager specific properties\n */\nexport interface VirtualNetworkManagerProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the resource group where the network manager will be created\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/my-rg\"\n   */\n  readonly resourceGroupId: string;\n\n  /**\n   * Defines the scope of management (management groups and/or subscriptions)\n   * At least one of managementGroups or subscriptions must be specified\n   */\n  readonly networkManagerScopes: NetworkManagerScopes;\n\n  /**\n   * Array of features enabled for the network manager\n   * Valid values: \"Connectivity\", \"SecurityAdmin\", \"Routing\"\n   * @example [\"Connectivity\", \"SecurityAdmin\"]\n   */\n  readonly networkManagerScopeAccesses: (\n    | \"Connectivity\"\n    | \"SecurityAdmin\"\n    | \"Routing\"\n  )[];\n\n  /**\n   * Optional description of the network manager\n   * @example \"Central network management for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * Useful for properties that are externally managed\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a NetworkGroup via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddNetworkGroupProps extends AzapiResourceProps {\n  /**\n   * Optional description of the network group\n   * @example \"Production virtual networks for region East US\"\n   */\n  readonly description?: string;\n\n  /**\n   * Type of members in this network group\n   * @default undefined (can contain both VirtualNetwork and Subnet members)\n   * @example \"VirtualNetwork\"\n   * @example \"Subnet\"\n   */\n  readonly memberType?: \"VirtualNetwork\" | \"Subnet\";\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a ConnectivityConfiguration via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddConnectivityConfigurationProps extends AzapiResourceProps {\n  /**\n   * Optional description of the connectivity configuration\n   * @example \"Hub-and-spoke topology for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * Connectivity topology type\n   * - HubAndSpoke: Central hub with spoke VNets\n   * - Mesh: All VNets can communicate directly\n   * @example \"HubAndSpoke\"\n   * @example \"Mesh\"\n   */\n  readonly connectivityTopology: \"HubAndSpoke\" | \"Mesh\";\n\n  /**\n   * Network groups to apply this configuration to\n   * Each item specifies a network group and how it should connect\n   */\n  readonly appliesToGroups: ConnectivityGroupItem[];\n\n  /**\n   * Hub VNets for hub-and-spoke topology\n   * Required when connectivityTopology is \"HubAndSpoke\"\n   * @example [{ resourceId: \"/subscriptions/.../virtualNetworks/hub-vnet\", resourceType: \"Microsoft.Network/virtualNetworks\" }]\n   */\n  readonly hubs?: Hub[];\n\n  /**\n   * Enable global mesh connectivity\n   * Allows mesh connectivity across regions\n   * @default false\n   */\n  readonly isGlobal?: boolean;\n\n  /**\n   * Delete existing peerings when applying this configuration\n   * @default false\n   */\n  readonly deleteExistingPeering?: boolean;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding a SecurityAdminConfiguration via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddSecurityAdminConfigurationProps extends AzapiResourceProps {\n  /**\n   * Optional description of the security admin configuration\n   * @example \"Organization-wide security rules for production workloads\"\n   */\n  readonly description?: string;\n\n  /**\n   * Services to apply the security admin configuration on\n   * @example [\"None\"]\n   * @example [\"All\"]\n   */\n  readonly applyOnNetworkIntentPolicyBasedServices?: string[];\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for adding an IpamPool via the convenience method\n * This interface excludes networkManagerId as it's automatically set\n */\nexport interface AddIpamPoolProps extends AzapiResourceProps {\n  /**\n   * IP address prefixes for the pool\n   * Must be valid CIDR notation (e.g., \"10.0.0.0/8\")\n   * Multiple prefixes must not overlap\n   * @example [\"10.0.0.0/8\", \"172.16.0.0/12\"]\n   */\n  readonly addressPrefixes: string[];\n\n  /**\n   * Optional description of the IPAM pool\n   * @example \"Production IP address pool for East US region\"\n   */\n  readonly description?: string;\n\n  /**\n   * Optional friendly display name\n   * @example \"East US Production Pool\"\n   */\n  readonly displayName?: string;\n\n  /**\n   * Name of parent pool for hierarchical pools\n   * Leave empty/undefined for root pools\n   * @example \"root-pool\"\n   */\n  readonly parentPoolName?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for Virtual Network Manager body\n */\nexport interface VirtualNetworkManagerProperties {\n  readonly networkManagerScopes: NetworkManagerScopes;\n  readonly networkManagerScopeAccesses: string[];\n  readonly description?: string;\n}\n\n/**\n * The resource body interface for Azure Virtual Network Manager API calls\n */\nexport interface VirtualNetworkManagerBody {\n  readonly location: string;\n  readonly tags?: { [key: string]: string };\n  readonly properties: VirtualNetworkManagerProperties;\n}\n\n/**\n * Azure Virtual Network Manager implementation\n *\n * This class provides a single, version-aware implementation that handles\n * version resolution, schema validation, and property transformation while maintaining\n * full backward compatibility.\n *\n * @example\n * // Basic usage with automatic version resolution:\n * const networkManager = new VirtualNetworkManager(this, \"manager\", {\n *   name: \"my-network-manager\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   networkManagerScopes: {\n *     subscriptions: [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n *   },\n *   networkManagerScopeAccesses: [\"Connectivity\", \"SecurityAdmin\"]\n * });\n *\n * @example\n * // Usage with explicit version pinning:\n * const networkManager = new VirtualNetworkManager(this, \"manager\", {\n *   name: \"my-network-manager\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2024-05-01\",\n *   networkManagerScopes: {\n *     subscriptions: [\"/subscriptions/00000000-0000-0000-0000-000000000000\"]\n *   },\n *   networkManagerScopeAccesses: [\"Connectivity\", \"SecurityAdmin\"]\n * });\n *\n * @stability stable\n */\nexport class VirtualNetworkManager extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      VIRTUAL_NETWORK_MANAGER_TYPE,\n      ALL_VIRTUAL_NETWORK_MANAGER_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Virtual Network Manager instance\n   */\n  public readonly props: VirtualNetworkManagerProps;\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  public readonly scopeOutput: cdktf.TerraformOutput;\n  public readonly scopeAccessesOutput: cdktf.TerraformOutput;\n\n  // Public properties that match the standard interface\n  public readonly resourceName: string;\n\n  /**\n   * Creates a new Azure Virtual Network Manager 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 Manager 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 Manager\n   */\n  constructor(scope: Construct, id: string, props: VirtualNetworkManagerProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Extract properties from the AZAPI resource outputs using Terraform interpolation\n    this.resourceName = `\\${${this.terraformResource.fqn}.name}`;\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 Manager\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: this.resourceName,\n      description: \"The name of the Virtual Network Manager\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.location}`,\n      description: \"The location of the Virtual Network Manager\",\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 Manager\",\n    });\n\n    this.scopeOutput = new cdktf.TerraformOutput(this, \"scope\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.networkManagerScopes}`,\n      description: \"The management scope of the Virtual Network Manager\",\n    });\n\n    this.scopeAccessesOutput = new cdktf.TerraformOutput(\n      this,\n      \"scopeAccesses\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.networkManagerScopeAccesses}`,\n        description: \"The enabled features of the Virtual Network Manager\",\n      },\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    this.scopeOutput.overrideLogicalId(\"scope\");\n    this.scopeAccessesOutput.overrideLogicalId(\"scopeAccesses\");\n\n    // Apply ignore changes if specified\n    this._applyIgnoreChanges();\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Resolves the parent resource ID for the Network Manager\n   * Network Managers are scoped to resource groups\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as VirtualNetworkManagerProps;\n    return typedProps.resourceGroupId;\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 Managers\n   */\n  protected resourceType(): string {\n    return \"Microsoft.Network/networkManagers\";\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   * 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 VirtualNetworkManagerProps;\n    return {\n      location: typedProps.location,\n      tags: this.allTags(),\n      properties: {\n        networkManagerScopes: typedProps.networkManagerScopes,\n        networkManagerScopeAccesses: typedProps.networkManagerScopeAccesses,\n        description: typedProps.description,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR VIRTUAL NETWORK MANAGER OPERATIONS\n  // =============================================================================\n\n  /**\n   * Add a tag to the Virtual Network Manager\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    // Apply the tag directly to the resource\n    this.terraformResource.addOverride(`tags.${key}`, value);\n  }\n\n  /**\n   * Remove a tag from the Virtual Network Manager\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      // Remove the tag from the resource\n      this.terraformResource.addOverride(`tags.${key}`, null);\n    }\n  }\n\n  // =============================================================================\n  // CONVENIENCE METHODS FOR CHILD RESOURCES (OPTION A - HYBRID APPROACH)\n  // =============================================================================\n\n  /**\n   * Convenience method to create a NetworkGroup\n   *\n   * This is a helper method that creates a NetworkGroup with the networkManagerId\n   * automatically set to this Network Manager's ID. You can also create NetworkGroups\n   * directly using: new NetworkGroup(scope, id, { networkManagerId: vnm.id, ...props })\n   *\n   * @param id - The unique identifier for the network group construct\n   * @param props - NetworkGroup properties (networkManagerId will be set automatically)\n   * @returns The created NetworkGroup instance\n   *\n   * @example\n   * const prodGroup = networkManager.addNetworkGroup(\"prod-group\", {\n   *   name: \"production-vnets\",\n   *   description: \"Production virtual networks\",\n   *   memberType: \"VirtualNetwork\"\n   * });\n   */\n  public addNetworkGroup(\n    id: string,\n    props: AddNetworkGroupProps,\n  ): NetworkGroup {\n    return new NetworkGroup(this, id, {\n      ...props,\n      networkManagerId: this.id,\n    });\n  }\n\n  /**\n   * Convenience method to create a ConnectivityConfiguration\n   *\n   * This is a helper method that creates a ConnectivityConfiguration with the\n   * networkManagerId automatically set to this Network Manager's ID.\n   *\n   * @param id - The unique identifier for the connectivity configuration construct\n   * @param props - ConnectivityConfiguration properties (networkManagerId will be set automatically)\n   * @returns The created ConnectivityConfiguration instance\n   *\n   * @example\n   * const hubSpoke = networkManager.addConnectivityConfiguration(\"hub-spoke\", {\n   *   name: \"production-hub-spoke\",\n   *   connectivityTopology: \"HubAndSpoke\",\n   *   appliesToGroups: [{ networkGroupId: prodGroup.id }],\n   *   hubs: [{ resourceId: hubVnet.id, resourceType: \"Microsoft.Network/virtualNetworks\" }]\n   * });\n   */\n  public addConnectivityConfiguration(\n    id: string,\n    props: AddConnectivityConfigurationProps,\n  ): ConnectivityConfiguration {\n    return new ConnectivityConfiguration(this, id, {\n      ...props,\n      networkManagerId: this.id,\n    });\n  }\n\n  /**\n   * Convenience method to create a SecurityAdminConfiguration\n   *\n   * This is a helper method that creates a SecurityAdminConfiguration with the\n   * networkManagerId automatically set to this Network Manager's ID.\n   *\n   * @param id - The unique identifier for the security admin configuration construct\n   * @param props - SecurityAdminConfiguration properties (networkManagerId will be set automatically)\n   * @returns The created SecurityAdminConfiguration instance\n   *\n   * @example\n   * const securityConfig = networkManager.addSecurityAdminConfiguration(\"security\", {\n   *   name: \"production-security\",\n   *   description: \"High-priority security rules for production\"\n   * });\n   */\n  public addSecurityAdminConfiguration(\n    id: string,\n    props: AddSecurityAdminConfigurationProps,\n  ): SecurityAdminConfiguration {\n    return new SecurityAdminConfiguration(this, id, {\n      ...props,\n      networkManagerId: this.id,\n    });\n  }\n\n  /**\n   * Convenience method to create an IpamPool\n   *\n   * This is a helper method that creates an IpamPool with the networkManagerId\n   * automatically set to this Network Manager's ID. You can also create IpamPools\n   * directly using: new IpamPool(scope, id, { networkManagerId: vnm.id, ...props })\n   *\n   * @param id - The unique identifier for the IPAM pool construct\n   * @param props - IpamPool properties (networkManagerId will be set automatically)\n   * @returns The created IpamPool instance\n   *\n   * @example\n   * const ipamPool = networkManager.addIpamPool(\"prod-pool\", {\n   *   name: \"production-pool\",\n   *   location: \"eastus\",\n   *   addressPrefixes: [\"10.0.0.0/8\"],\n   *   description: \"Production IP address pool\",\n   *   displayName: \"Production Pool\"\n   * });\n   */\n  public addIpamPool(id: string, props: AddIpamPoolProps): IpamPool {\n    return new IpamPool(this, id, {\n      ...props,\n      networkManagerId: this.id,\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,6 @@
1
+ /**
2
+ * CIDR Validator Tests
3
+ *
4
+ * Unit tests for the CIDR validation utility
5
+ */
6
+ export {};