@microsoft/terraform-cdk-constructs 1.3.0 → 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 (76) hide show
  1. package/.jsii +22673 -19618
  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.d.ts +7 -0
  18. package/lib/azure-policyassignment/lib/policy-assignment.js +11 -2
  19. package/lib/azure-policydefinition/lib/policy-definition.d.ts +21 -0
  20. package/lib/azure-policydefinition/lib/policy-definition.js +40 -3
  21. package/lib/azure-policydefinition/test/policy-definition.spec.js +211 -1
  22. package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
  23. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  24. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  25. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  26. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  27. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  28. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  29. package/lib/azure-subnet/lib/subnet.js +1 -1
  30. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  31. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  32. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  33. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
  34. package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
  35. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
  36. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
  37. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
  38. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
  39. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
  40. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
  41. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
  42. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
  43. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  44. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  45. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  46. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  47. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  48. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.d.ts +225 -0
  49. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
  50. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
  51. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
  52. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
  53. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
  54. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
  55. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
  56. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
  57. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
  58. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
  59. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
  60. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
  61. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  62. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +28 -0
  63. package/lib/core-azure/lib/azapi/azapi-resource.js +60 -10
  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/testing/index.js +2 -2
  74. package/lib/testing/lib/cleanup.js +1 -1
  75. package/lib/testing/lib/metadata.js +1 -1
  76. package/package.json +1 -1
@@ -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.0" };
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 {};
@@ -0,0 +1,292 @@
1
+ "use strict";
2
+ /**
3
+ * CIDR Validator Tests
4
+ *
5
+ * Unit tests for the CIDR validation utility
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ const cidr_validator_1 = require("../lib/utils/cidr-validator");
9
+ describe("CIDR Validator Functions", () => {
10
+ describe("isValidCidr", () => {
11
+ it("should return true for valid CIDR formats", () => {
12
+ expect((0, cidr_validator_1.isValidCidr)("10.0.0.0/8")).toBe(true);
13
+ expect((0, cidr_validator_1.isValidCidr)("172.16.0.0/12")).toBe(true);
14
+ expect((0, cidr_validator_1.isValidCidr)("192.168.0.0/16")).toBe(true);
15
+ expect((0, cidr_validator_1.isValidCidr)("0.0.0.0/0")).toBe(true);
16
+ expect((0, cidr_validator_1.isValidCidr)("255.255.255.255/32")).toBe(true);
17
+ });
18
+ it("should return false for invalid CIDR formats", () => {
19
+ expect((0, cidr_validator_1.isValidCidr)("")).toBe(false);
20
+ expect((0, cidr_validator_1.isValidCidr)("not-a-cidr")).toBe(false);
21
+ expect((0, cidr_validator_1.isValidCidr)("10.0.0.0")).toBe(false);
22
+ expect((0, cidr_validator_1.isValidCidr)("10.0.0.0/")).toBe(false);
23
+ expect((0, cidr_validator_1.isValidCidr)("256.0.0.0/24")).toBe(false);
24
+ expect((0, cidr_validator_1.isValidCidr)("10.0.0.0/33")).toBe(false);
25
+ });
26
+ });
27
+ describe("isPrivateRange", () => {
28
+ it("should return true for RFC 1918 private IP ranges", () => {
29
+ expect((0, cidr_validator_1.isPrivateRange)("10.0.0.0/8")).toBe(true);
30
+ expect((0, cidr_validator_1.isPrivateRange)("10.50.0.0/16")).toBe(true);
31
+ expect((0, cidr_validator_1.isPrivateRange)("172.16.0.0/12")).toBe(true);
32
+ expect((0, cidr_validator_1.isPrivateRange)("172.20.0.0/16")).toBe(true);
33
+ expect((0, cidr_validator_1.isPrivateRange)("192.168.0.0/16")).toBe(true);
34
+ expect((0, cidr_validator_1.isPrivateRange)("192.168.1.0/24")).toBe(true);
35
+ });
36
+ it("should return false for public IP ranges", () => {
37
+ expect((0, cidr_validator_1.isPrivateRange)("8.8.8.0/24")).toBe(false);
38
+ expect((0, cidr_validator_1.isPrivateRange)("1.1.1.0/24")).toBe(false);
39
+ expect((0, cidr_validator_1.isPrivateRange)("172.32.0.0/16")).toBe(false);
40
+ expect((0, cidr_validator_1.isPrivateRange)("11.0.0.0/8")).toBe(false);
41
+ });
42
+ it("should return false for invalid CIDR", () => {
43
+ expect((0, cidr_validator_1.isPrivateRange)("invalid")).toBe(false);
44
+ });
45
+ });
46
+ describe("cidrsOverlap", () => {
47
+ it("should detect overlapping CIDRs", () => {
48
+ expect((0, cidr_validator_1.cidrsOverlap)("10.0.0.0/16", "10.0.1.0/24")).toBe(true);
49
+ expect((0, cidr_validator_1.cidrsOverlap)("10.0.0.0/8", "10.1.0.0/16")).toBe(true);
50
+ expect((0, cidr_validator_1.cidrsOverlap)("192.168.0.0/24", "192.168.0.128/25")).toBe(true);
51
+ });
52
+ it("should detect non-overlapping CIDRs", () => {
53
+ expect((0, cidr_validator_1.cidrsOverlap)("10.0.0.0/16", "10.1.0.0/16")).toBe(false);
54
+ expect((0, cidr_validator_1.cidrsOverlap)("192.168.0.0/24", "192.168.1.0/24")).toBe(false);
55
+ expect((0, cidr_validator_1.cidrsOverlap)("172.16.0.0/16", "192.168.0.0/16")).toBe(false);
56
+ });
57
+ });
58
+ describe("isSubnet", () => {
59
+ it("should return true when child is subnet of parent", () => {
60
+ expect((0, cidr_validator_1.isSubnet)("10.1.0.0/16", "10.0.0.0/8")).toBe(true);
61
+ expect((0, cidr_validator_1.isSubnet)("10.0.1.0/24", "10.0.0.0/16")).toBe(true);
62
+ expect((0, cidr_validator_1.isSubnet)("192.168.1.0/24", "192.168.0.0/16")).toBe(true);
63
+ });
64
+ it("should return false when child is not subnet of parent", () => {
65
+ expect((0, cidr_validator_1.isSubnet)("10.0.1.0/24", "10.0.0.0/24")).toBe(false);
66
+ expect((0, cidr_validator_1.isSubnet)("10.1.0.0/24", "10.0.0.0/16")).toBe(false);
67
+ expect((0, cidr_validator_1.isSubnet)("192.168.1.0/24", "192.168.0.0/24")).toBe(false);
68
+ });
69
+ it("should return true when child equals parent", () => {
70
+ expect((0, cidr_validator_1.isSubnet)("10.0.0.0/24", "10.0.0.0/24")).toBe(true);
71
+ });
72
+ });
73
+ describe("calculateAddressCount", () => {
74
+ it("should calculate correct address count for various prefixes", () => {
75
+ expect((0, cidr_validator_1.calculateAddressCount)("10.0.0.0/8")).toBe(16777216);
76
+ expect((0, cidr_validator_1.calculateAddressCount)("10.0.0.0/16")).toBe(65536);
77
+ expect((0, cidr_validator_1.calculateAddressCount)("10.0.0.0/24")).toBe(256);
78
+ expect((0, cidr_validator_1.calculateAddressCount)("10.0.0.0/32")).toBe(1);
79
+ expect((0, cidr_validator_1.calculateAddressCount)("0.0.0.0/0")).toBe(4294967296);
80
+ });
81
+ });
82
+ describe("isValidPrefixLength", () => {
83
+ it("should return true for prefix within range", () => {
84
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/24", 8, 29)).toBe(true);
85
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/8", 8, 29)).toBe(true);
86
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/29", 8, 29)).toBe(true);
87
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/16", 16, 16)).toBe(true);
88
+ });
89
+ it("should return false for prefix outside range", () => {
90
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/7", 8, 29)).toBe(false);
91
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/30", 8, 29)).toBe(false);
92
+ expect((0, cidr_validator_1.isValidPrefixLength)("10.0.0.0/32", 8, 29)).toBe(false);
93
+ });
94
+ it("should return false for invalid CIDR", () => {
95
+ expect((0, cidr_validator_1.isValidPrefixLength)("invalid", 8, 29)).toBe(false);
96
+ });
97
+ });
98
+ describe("validateCidr", () => {
99
+ it("should validate valid CIDR formats", () => {
100
+ const validCidrs = [
101
+ "10.0.0.0/8",
102
+ "172.16.0.0/12",
103
+ "192.168.0.0/16",
104
+ "10.0.0.0/24",
105
+ "0.0.0.0/0",
106
+ "255.255.255.255/32",
107
+ ];
108
+ validCidrs.forEach((cidr) => {
109
+ const result = (0, cidr_validator_1.validateCidr)(cidr);
110
+ expect(result.valid).toBe(true);
111
+ expect(result.errors).toHaveLength(0);
112
+ });
113
+ });
114
+ it("should detect invalid CIDR formats", () => {
115
+ const invalidCidrs = [
116
+ "",
117
+ "not-a-cidr",
118
+ "10.0.0.0",
119
+ "10.0.0.0/",
120
+ "10.0.0/24",
121
+ "10.0.0.0.0/24",
122
+ "256.0.0.0/24",
123
+ "10.0.0.0/33",
124
+ "10.0.0.0/-1",
125
+ ];
126
+ invalidCidrs.forEach((cidr) => {
127
+ const result = (0, cidr_validator_1.validateCidr)(cidr);
128
+ expect(result.valid).toBe(false);
129
+ expect(result.errors.length).toBeGreaterThan(0);
130
+ });
131
+ });
132
+ it("should warn about misaligned network addresses", () => {
133
+ const result = (0, cidr_validator_1.validateCidr)("10.0.0.1/24");
134
+ expect(result.valid).toBe(true);
135
+ expect(result.warnings.length).toBeGreaterThan(0);
136
+ expect(result.warnings[0]).toContain("not aligned to network boundary");
137
+ });
138
+ it("should validate properly aligned network addresses without warnings", () => {
139
+ const result = (0, cidr_validator_1.validateCidr)("10.0.0.0/24");
140
+ expect(result.valid).toBe(true);
141
+ expect(result.warnings).toHaveLength(0);
142
+ });
143
+ });
144
+ describe("parseCidr", () => {
145
+ it("should parse valid CIDR notation", () => {
146
+ const parsed = (0, cidr_validator_1.parseCidr)("10.0.0.0/24");
147
+ expect(parsed.cidr).toBe("10.0.0.0/24");
148
+ expect(parsed.network).toBe("10.0.0.0");
149
+ expect(parsed.prefix).toBe(24);
150
+ expect(parsed.firstIp).toBe("10.0.0.0");
151
+ expect(parsed.lastIp).toBe("10.0.0.255");
152
+ expect(parsed.totalAddresses).toBe(256);
153
+ expect(parsed.netmask).toBe("255.255.255.0");
154
+ });
155
+ it("should parse /8 CIDR correctly", () => {
156
+ const parsed = (0, cidr_validator_1.parseCidr)("10.0.0.0/8");
157
+ expect(parsed.network).toBe("10.0.0.0");
158
+ expect(parsed.prefix).toBe(8);
159
+ expect(parsed.firstIp).toBe("10.0.0.0");
160
+ expect(parsed.lastIp).toBe("10.255.255.255");
161
+ expect(parsed.totalAddresses).toBe(16777216);
162
+ expect(parsed.netmask).toBe("255.0.0.0");
163
+ });
164
+ it("should parse /32 CIDR correctly", () => {
165
+ const parsed = (0, cidr_validator_1.parseCidr)("192.168.1.1/32");
166
+ expect(parsed.network).toBe("192.168.1.1");
167
+ expect(parsed.prefix).toBe(32);
168
+ expect(parsed.firstIp).toBe("192.168.1.1");
169
+ expect(parsed.lastIp).toBe("192.168.1.1");
170
+ expect(parsed.totalAddresses).toBe(1);
171
+ expect(parsed.netmask).toBe("255.255.255.255");
172
+ });
173
+ it("should throw error for invalid CIDR", () => {
174
+ expect(() => {
175
+ (0, cidr_validator_1.parseCidr)("invalid");
176
+ }).toThrow("Invalid CIDR");
177
+ });
178
+ });
179
+ describe("checkOverlap", () => {
180
+ it("should detect overlapping CIDRs", () => {
181
+ expect((0, cidr_validator_1.checkOverlap)("10.0.0.0/16", "10.0.1.0/24")).toBe(true);
182
+ expect((0, cidr_validator_1.checkOverlap)("10.0.0.0/8", "10.1.0.0/16")).toBe(true);
183
+ expect((0, cidr_validator_1.checkOverlap)("192.168.0.0/24", "192.168.0.128/25")).toBe(true);
184
+ });
185
+ it("should detect non-overlapping CIDRs", () => {
186
+ expect((0, cidr_validator_1.checkOverlap)("10.0.0.0/16", "10.1.0.0/16")).toBe(false);
187
+ expect((0, cidr_validator_1.checkOverlap)("192.168.0.0/24", "192.168.1.0/24")).toBe(false);
188
+ expect((0, cidr_validator_1.checkOverlap)("172.16.0.0/16", "192.168.0.0/16")).toBe(false);
189
+ });
190
+ it("should detect adjacent non-overlapping CIDRs", () => {
191
+ expect((0, cidr_validator_1.checkOverlap)("10.0.0.0/24", "10.0.1.0/24")).toBe(false);
192
+ });
193
+ });
194
+ describe("validateNoOverlaps", () => {
195
+ it("should validate non-overlapping CIDR array", () => {
196
+ const cidrs = ["10.0.0.0/24", "10.0.1.0/24", "10.0.2.0/24"];
197
+ const result = (0, cidr_validator_1.validateNoOverlaps)(cidrs);
198
+ expect(result.valid).toBe(true);
199
+ expect(result.errors).toHaveLength(0);
200
+ });
201
+ it("should detect overlaps in CIDR array", () => {
202
+ const cidrs = ["10.0.0.0/16", "10.0.1.0/24", "10.0.2.0/24"];
203
+ const result = (0, cidr_validator_1.validateNoOverlaps)(cidrs);
204
+ expect(result.valid).toBe(false);
205
+ expect(result.errors.length).toBeGreaterThan(0);
206
+ expect(result.errors[0]).toContain("overlap");
207
+ });
208
+ it("should detect invalid CIDRs in array", () => {
209
+ const cidrs = ["10.0.0.0/24", "invalid-cidr"];
210
+ const result = (0, cidr_validator_1.validateNoOverlaps)(cidrs);
211
+ expect(result.valid).toBe(false);
212
+ expect(result.errors.length).toBeGreaterThan(0);
213
+ });
214
+ });
215
+ describe("isContained", () => {
216
+ it("should detect child CIDR contained in parent", () => {
217
+ expect((0, cidr_validator_1.isContained)("10.0.0.0/16", "10.0.1.0/24")).toBe(true);
218
+ expect((0, cidr_validator_1.isContained)("10.0.0.0/8", "10.0.0.0/16")).toBe(true);
219
+ expect((0, cidr_validator_1.isContained)("192.168.0.0/16", "192.168.1.0/24")).toBe(true);
220
+ });
221
+ it("should detect child CIDR not contained in parent", () => {
222
+ expect((0, cidr_validator_1.isContained)("10.0.0.0/24", "10.0.1.0/24")).toBe(false);
223
+ expect((0, cidr_validator_1.isContained)("10.0.0.0/16", "10.1.0.0/24")).toBe(false);
224
+ expect((0, cidr_validator_1.isContained)("192.168.0.0/24", "192.168.1.0/24")).toBe(false);
225
+ });
226
+ it("should handle parent and child being the same", () => {
227
+ expect((0, cidr_validator_1.isContained)("10.0.0.0/24", "10.0.0.0/24")).toBe(true);
228
+ });
229
+ });
230
+ describe("validateContainment", () => {
231
+ it("should validate all children contained in parent", () => {
232
+ const parent = "10.0.0.0/16";
233
+ const children = ["10.0.1.0/24", "10.0.2.0/24", "10.0.3.0/24"];
234
+ const result = (0, cidr_validator_1.validateContainment)(parent, children);
235
+ expect(result.valid).toBe(true);
236
+ expect(result.errors).toHaveLength(0);
237
+ });
238
+ it("should detect children not contained in parent", () => {
239
+ const parent = "10.0.0.0/16";
240
+ const children = ["10.0.1.0/24", "10.1.0.0/24", "192.168.0.0/24"];
241
+ const result = (0, cidr_validator_1.validateContainment)(parent, children);
242
+ expect(result.valid).toBe(false);
243
+ expect(result.errors.length).toBeGreaterThan(0);
244
+ expect(result.errors.some((e) => e.includes("not contained"))).toBe(true);
245
+ });
246
+ it("should detect invalid parent CIDR", () => {
247
+ const result = (0, cidr_validator_1.validateContainment)("invalid", ["10.0.0.0/24"]);
248
+ expect(result.valid).toBe(false);
249
+ expect(result.errors[0]).toContain("Invalid parent CIDR");
250
+ });
251
+ it("should detect invalid child CIDRs", () => {
252
+ const parent = "10.0.0.0/16";
253
+ const children = ["10.0.1.0/24", "invalid-cidr"];
254
+ const result = (0, cidr_validator_1.validateContainment)(parent, children);
255
+ expect(result.valid).toBe(false);
256
+ expect(result.errors.some((e) => e.includes("Invalid child CIDR"))).toBe(true);
257
+ });
258
+ });
259
+ describe("ipToNumber and numberToIp", () => {
260
+ it("should convert IP to number and back", () => {
261
+ const testIps = ["0.0.0.0", "10.0.0.1", "192.168.1.1", "255.255.255.255"];
262
+ testIps.forEach((ip) => {
263
+ const num = (0, cidr_validator_1.ipToNumber)(ip);
264
+ const converted = (0, cidr_validator_1.numberToIp)(num);
265
+ expect(converted).toBe(ip);
266
+ });
267
+ });
268
+ it("should handle specific IP conversions", () => {
269
+ expect((0, cidr_validator_1.ipToNumber)("10.0.0.1")).toBe(167772161);
270
+ expect((0, cidr_validator_1.numberToIp)(167772161)).toBe("10.0.0.1");
271
+ expect((0, cidr_validator_1.ipToNumber)("192.168.1.1")).toBe(3232235777);
272
+ expect((0, cidr_validator_1.numberToIp)(3232235777)).toBe("192.168.1.1");
273
+ });
274
+ });
275
+ describe("prefixToMask", () => {
276
+ it("should convert prefix to correct netmask", () => {
277
+ const prefixTests = [
278
+ { prefix: 0, mask: "0.0.0.0" },
279
+ { prefix: 8, mask: "255.0.0.0" },
280
+ { prefix: 16, mask: "255.255.0.0" },
281
+ { prefix: 24, mask: "255.255.255.0" },
282
+ { prefix: 32, mask: "255.255.255.255" },
283
+ ];
284
+ prefixTests.forEach(({ prefix, mask }) => {
285
+ const maskNum = (0, cidr_validator_1.prefixToMask)(prefix);
286
+ const maskIp = (0, cidr_validator_1.numberToIp)(maskNum);
287
+ expect(maskIp).toBe(mask);
288
+ });
289
+ });
290
+ });
291
+ });
292
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cidr-validator.spec.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/test/cidr-validator.spec.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * CIDR Validator Tests\n *\n * Unit tests for the CIDR validation utility\n */\n\nimport {\n  isValidCidr,\n  isPrivateRange,\n  cidrsOverlap,\n  isSubnet,\n  calculateAddressCount,\n  isValidPrefixLength,\n  validateCidr,\n  parseCidr,\n  checkOverlap,\n  validateNoOverlaps,\n  isContained,\n  validateContainment,\n  ipToNumber,\n  numberToIp,\n  prefixToMask,\n} from \"../lib/utils/cidr-validator\";\n\ndescribe(\"CIDR Validator Functions\", () => {\n  describe(\"isValidCidr\", () => {\n    it(\"should return true for valid CIDR formats\", () => {\n      expect(isValidCidr(\"10.0.0.0/8\")).toBe(true);\n      expect(isValidCidr(\"172.16.0.0/12\")).toBe(true);\n      expect(isValidCidr(\"192.168.0.0/16\")).toBe(true);\n      expect(isValidCidr(\"0.0.0.0/0\")).toBe(true);\n      expect(isValidCidr(\"255.255.255.255/32\")).toBe(true);\n    });\n\n    it(\"should return false for invalid CIDR formats\", () => {\n      expect(isValidCidr(\"\")).toBe(false);\n      expect(isValidCidr(\"not-a-cidr\")).toBe(false);\n      expect(isValidCidr(\"10.0.0.0\")).toBe(false);\n      expect(isValidCidr(\"10.0.0.0/\")).toBe(false);\n      expect(isValidCidr(\"256.0.0.0/24\")).toBe(false);\n      expect(isValidCidr(\"10.0.0.0/33\")).toBe(false);\n    });\n  });\n\n  describe(\"isPrivateRange\", () => {\n    it(\"should return true for RFC 1918 private IP ranges\", () => {\n      expect(isPrivateRange(\"10.0.0.0/8\")).toBe(true);\n      expect(isPrivateRange(\"10.50.0.0/16\")).toBe(true);\n      expect(isPrivateRange(\"172.16.0.0/12\")).toBe(true);\n      expect(isPrivateRange(\"172.20.0.0/16\")).toBe(true);\n      expect(isPrivateRange(\"192.168.0.0/16\")).toBe(true);\n      expect(isPrivateRange(\"192.168.1.0/24\")).toBe(true);\n    });\n\n    it(\"should return false for public IP ranges\", () => {\n      expect(isPrivateRange(\"8.8.8.0/24\")).toBe(false);\n      expect(isPrivateRange(\"1.1.1.0/24\")).toBe(false);\n      expect(isPrivateRange(\"172.32.0.0/16\")).toBe(false);\n      expect(isPrivateRange(\"11.0.0.0/8\")).toBe(false);\n    });\n\n    it(\"should return false for invalid CIDR\", () => {\n      expect(isPrivateRange(\"invalid\")).toBe(false);\n    });\n  });\n\n  describe(\"cidrsOverlap\", () => {\n    it(\"should detect overlapping CIDRs\", () => {\n      expect(cidrsOverlap(\"10.0.0.0/16\", \"10.0.1.0/24\")).toBe(true);\n      expect(cidrsOverlap(\"10.0.0.0/8\", \"10.1.0.0/16\")).toBe(true);\n      expect(cidrsOverlap(\"192.168.0.0/24\", \"192.168.0.128/25\")).toBe(true);\n    });\n\n    it(\"should detect non-overlapping CIDRs\", () => {\n      expect(cidrsOverlap(\"10.0.0.0/16\", \"10.1.0.0/16\")).toBe(false);\n      expect(cidrsOverlap(\"192.168.0.0/24\", \"192.168.1.0/24\")).toBe(false);\n      expect(cidrsOverlap(\"172.16.0.0/16\", \"192.168.0.0/16\")).toBe(false);\n    });\n  });\n\n  describe(\"isSubnet\", () => {\n    it(\"should return true when child is subnet of parent\", () => {\n      expect(isSubnet(\"10.1.0.0/16\", \"10.0.0.0/8\")).toBe(true);\n      expect(isSubnet(\"10.0.1.0/24\", \"10.0.0.0/16\")).toBe(true);\n      expect(isSubnet(\"192.168.1.0/24\", \"192.168.0.0/16\")).toBe(true);\n    });\n\n    it(\"should return false when child is not subnet of parent\", () => {\n      expect(isSubnet(\"10.0.1.0/24\", \"10.0.0.0/24\")).toBe(false);\n      expect(isSubnet(\"10.1.0.0/24\", \"10.0.0.0/16\")).toBe(false);\n      expect(isSubnet(\"192.168.1.0/24\", \"192.168.0.0/24\")).toBe(false);\n    });\n\n    it(\"should return true when child equals parent\", () => {\n      expect(isSubnet(\"10.0.0.0/24\", \"10.0.0.0/24\")).toBe(true);\n    });\n  });\n\n  describe(\"calculateAddressCount\", () => {\n    it(\"should calculate correct address count for various prefixes\", () => {\n      expect(calculateAddressCount(\"10.0.0.0/8\")).toBe(16777216);\n      expect(calculateAddressCount(\"10.0.0.0/16\")).toBe(65536);\n      expect(calculateAddressCount(\"10.0.0.0/24\")).toBe(256);\n      expect(calculateAddressCount(\"10.0.0.0/32\")).toBe(1);\n      expect(calculateAddressCount(\"0.0.0.0/0\")).toBe(4294967296);\n    });\n  });\n\n  describe(\"isValidPrefixLength\", () => {\n    it(\"should return true for prefix within range\", () => {\n      expect(isValidPrefixLength(\"10.0.0.0/24\", 8, 29)).toBe(true);\n      expect(isValidPrefixLength(\"10.0.0.0/8\", 8, 29)).toBe(true);\n      expect(isValidPrefixLength(\"10.0.0.0/29\", 8, 29)).toBe(true);\n      expect(isValidPrefixLength(\"10.0.0.0/16\", 16, 16)).toBe(true);\n    });\n\n    it(\"should return false for prefix outside range\", () => {\n      expect(isValidPrefixLength(\"10.0.0.0/7\", 8, 29)).toBe(false);\n      expect(isValidPrefixLength(\"10.0.0.0/30\", 8, 29)).toBe(false);\n      expect(isValidPrefixLength(\"10.0.0.0/32\", 8, 29)).toBe(false);\n    });\n\n    it(\"should return false for invalid CIDR\", () => {\n      expect(isValidPrefixLength(\"invalid\", 8, 29)).toBe(false);\n    });\n  });\n\n  describe(\"validateCidr\", () => {\n    it(\"should validate valid CIDR formats\", () => {\n      const validCidrs = [\n        \"10.0.0.0/8\",\n        \"172.16.0.0/12\",\n        \"192.168.0.0/16\",\n        \"10.0.0.0/24\",\n        \"0.0.0.0/0\",\n        \"255.255.255.255/32\",\n      ];\n\n      validCidrs.forEach((cidr) => {\n        const result = validateCidr(cidr);\n        expect(result.valid).toBe(true);\n        expect(result.errors).toHaveLength(0);\n      });\n    });\n\n    it(\"should detect invalid CIDR formats\", () => {\n      const invalidCidrs = [\n        \"\",\n        \"not-a-cidr\",\n        \"10.0.0.0\",\n        \"10.0.0.0/\",\n        \"10.0.0/24\",\n        \"10.0.0.0.0/24\",\n        \"256.0.0.0/24\",\n        \"10.0.0.0/33\",\n        \"10.0.0.0/-1\",\n      ];\n\n      invalidCidrs.forEach((cidr) => {\n        const result = validateCidr(cidr);\n        expect(result.valid).toBe(false);\n        expect(result.errors.length).toBeGreaterThan(0);\n      });\n    });\n\n    it(\"should warn about misaligned network addresses\", () => {\n      const result = validateCidr(\"10.0.0.1/24\");\n      expect(result.valid).toBe(true);\n      expect(result.warnings.length).toBeGreaterThan(0);\n      expect(result.warnings[0]).toContain(\"not aligned to network boundary\");\n    });\n\n    it(\"should validate properly aligned network addresses without warnings\", () => {\n      const result = validateCidr(\"10.0.0.0/24\");\n      expect(result.valid).toBe(true);\n      expect(result.warnings).toHaveLength(0);\n    });\n  });\n\n  describe(\"parseCidr\", () => {\n    it(\"should parse valid CIDR notation\", () => {\n      const parsed = parseCidr(\"10.0.0.0/24\");\n\n      expect(parsed.cidr).toBe(\"10.0.0.0/24\");\n      expect(parsed.network).toBe(\"10.0.0.0\");\n      expect(parsed.prefix).toBe(24);\n      expect(parsed.firstIp).toBe(\"10.0.0.0\");\n      expect(parsed.lastIp).toBe(\"10.0.0.255\");\n      expect(parsed.totalAddresses).toBe(256);\n      expect(parsed.netmask).toBe(\"255.255.255.0\");\n    });\n\n    it(\"should parse /8 CIDR correctly\", () => {\n      const parsed = parseCidr(\"10.0.0.0/8\");\n\n      expect(parsed.network).toBe(\"10.0.0.0\");\n      expect(parsed.prefix).toBe(8);\n      expect(parsed.firstIp).toBe(\"10.0.0.0\");\n      expect(parsed.lastIp).toBe(\"10.255.255.255\");\n      expect(parsed.totalAddresses).toBe(16777216);\n      expect(parsed.netmask).toBe(\"255.0.0.0\");\n    });\n\n    it(\"should parse /32 CIDR correctly\", () => {\n      const parsed = parseCidr(\"192.168.1.1/32\");\n\n      expect(parsed.network).toBe(\"192.168.1.1\");\n      expect(parsed.prefix).toBe(32);\n      expect(parsed.firstIp).toBe(\"192.168.1.1\");\n      expect(parsed.lastIp).toBe(\"192.168.1.1\");\n      expect(parsed.totalAddresses).toBe(1);\n      expect(parsed.netmask).toBe(\"255.255.255.255\");\n    });\n\n    it(\"should throw error for invalid CIDR\", () => {\n      expect(() => {\n        parseCidr(\"invalid\");\n      }).toThrow(\"Invalid CIDR\");\n    });\n  });\n\n  describe(\"checkOverlap\", () => {\n    it(\"should detect overlapping CIDRs\", () => {\n      expect(checkOverlap(\"10.0.0.0/16\", \"10.0.1.0/24\")).toBe(true);\n      expect(checkOverlap(\"10.0.0.0/8\", \"10.1.0.0/16\")).toBe(true);\n      expect(checkOverlap(\"192.168.0.0/24\", \"192.168.0.128/25\")).toBe(true);\n    });\n\n    it(\"should detect non-overlapping CIDRs\", () => {\n      expect(checkOverlap(\"10.0.0.0/16\", \"10.1.0.0/16\")).toBe(false);\n      expect(checkOverlap(\"192.168.0.0/24\", \"192.168.1.0/24\")).toBe(false);\n      expect(checkOverlap(\"172.16.0.0/16\", \"192.168.0.0/16\")).toBe(false);\n    });\n\n    it(\"should detect adjacent non-overlapping CIDRs\", () => {\n      expect(checkOverlap(\"10.0.0.0/24\", \"10.0.1.0/24\")).toBe(false);\n    });\n  });\n\n  describe(\"validateNoOverlaps\", () => {\n    it(\"should validate non-overlapping CIDR array\", () => {\n      const cidrs = [\"10.0.0.0/24\", \"10.0.1.0/24\", \"10.0.2.0/24\"];\n\n      const result = validateNoOverlaps(cidrs);\n      expect(result.valid).toBe(true);\n      expect(result.errors).toHaveLength(0);\n    });\n\n    it(\"should detect overlaps in CIDR array\", () => {\n      const cidrs = [\"10.0.0.0/16\", \"10.0.1.0/24\", \"10.0.2.0/24\"];\n\n      const result = validateNoOverlaps(cidrs);\n      expect(result.valid).toBe(false);\n      expect(result.errors.length).toBeGreaterThan(0);\n      expect(result.errors[0]).toContain(\"overlap\");\n    });\n\n    it(\"should detect invalid CIDRs in array\", () => {\n      const cidrs = [\"10.0.0.0/24\", \"invalid-cidr\"];\n\n      const result = validateNoOverlaps(cidrs);\n      expect(result.valid).toBe(false);\n      expect(result.errors.length).toBeGreaterThan(0);\n    });\n  });\n\n  describe(\"isContained\", () => {\n    it(\"should detect child CIDR contained in parent\", () => {\n      expect(isContained(\"10.0.0.0/16\", \"10.0.1.0/24\")).toBe(true);\n      expect(isContained(\"10.0.0.0/8\", \"10.0.0.0/16\")).toBe(true);\n      expect(isContained(\"192.168.0.0/16\", \"192.168.1.0/24\")).toBe(true);\n    });\n\n    it(\"should detect child CIDR not contained in parent\", () => {\n      expect(isContained(\"10.0.0.0/24\", \"10.0.1.0/24\")).toBe(false);\n      expect(isContained(\"10.0.0.0/16\", \"10.1.0.0/24\")).toBe(false);\n      expect(isContained(\"192.168.0.0/24\", \"192.168.1.0/24\")).toBe(false);\n    });\n\n    it(\"should handle parent and child being the same\", () => {\n      expect(isContained(\"10.0.0.0/24\", \"10.0.0.0/24\")).toBe(true);\n    });\n  });\n\n  describe(\"validateContainment\", () => {\n    it(\"should validate all children contained in parent\", () => {\n      const parent = \"10.0.0.0/16\";\n      const children = [\"10.0.1.0/24\", \"10.0.2.0/24\", \"10.0.3.0/24\"];\n\n      const result = validateContainment(parent, children);\n      expect(result.valid).toBe(true);\n      expect(result.errors).toHaveLength(0);\n    });\n\n    it(\"should detect children not contained in parent\", () => {\n      const parent = \"10.0.0.0/16\";\n      const children = [\"10.0.1.0/24\", \"10.1.0.0/24\", \"192.168.0.0/24\"];\n\n      const result = validateContainment(parent, children);\n      expect(result.valid).toBe(false);\n      expect(result.errors.length).toBeGreaterThan(0);\n      expect(\n        result.errors.some((e: string) => e.includes(\"not contained\")),\n      ).toBe(true);\n    });\n\n    it(\"should detect invalid parent CIDR\", () => {\n      const result = validateContainment(\"invalid\", [\"10.0.0.0/24\"]);\n      expect(result.valid).toBe(false);\n      expect(result.errors[0]).toContain(\"Invalid parent CIDR\");\n    });\n\n    it(\"should detect invalid child CIDRs\", () => {\n      const parent = \"10.0.0.0/16\";\n      const children = [\"10.0.1.0/24\", \"invalid-cidr\"];\n\n      const result = validateContainment(parent, children);\n      expect(result.valid).toBe(false);\n      expect(\n        result.errors.some((e: string) => e.includes(\"Invalid child CIDR\")),\n      ).toBe(true);\n    });\n  });\n\n  describe(\"ipToNumber and numberToIp\", () => {\n    it(\"should convert IP to number and back\", () => {\n      const testIps = [\"0.0.0.0\", \"10.0.0.1\", \"192.168.1.1\", \"255.255.255.255\"];\n\n      testIps.forEach((ip) => {\n        const num = ipToNumber(ip);\n        const converted = numberToIp(num);\n        expect(converted).toBe(ip);\n      });\n    });\n\n    it(\"should handle specific IP conversions\", () => {\n      expect(ipToNumber(\"10.0.0.1\")).toBe(167772161);\n      expect(numberToIp(167772161)).toBe(\"10.0.0.1\");\n\n      expect(ipToNumber(\"192.168.1.1\")).toBe(3232235777);\n      expect(numberToIp(3232235777)).toBe(\"192.168.1.1\");\n    });\n  });\n\n  describe(\"prefixToMask\", () => {\n    it(\"should convert prefix to correct netmask\", () => {\n      const prefixTests = [\n        { prefix: 0, mask: \"0.0.0.0\" },\n        { prefix: 8, mask: \"255.0.0.0\" },\n        { prefix: 16, mask: \"255.255.0.0\" },\n        { prefix: 24, mask: \"255.255.255.0\" },\n        { prefix: 32, mask: \"255.255.255.255\" },\n      ];\n\n      prefixTests.forEach(({ prefix, mask }) => {\n        const maskNum = prefixToMask(prefix);\n        const maskIp = numberToIp(maskNum);\n        expect(maskIp).toBe(mask);\n      });\n    });\n  });\n});\n"]}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * IPAM Pool Static CIDR Tests
3
+ *
4
+ * Unit tests for the IPAM Pool Static CIDR construct
5
+ */
6
+ export {};