@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.
- package/.jsii +22673 -19618
- package/API.md +25592 -20586
- package/lib/azure-actiongroup/lib/action-group.js +1 -1
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
- package/lib/azure-aks/lib/aks-cluster.js +1 -1
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
- package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
- package/lib/azure-dnszone/lib/dns-zone.js +1 -1
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-networkinterface/lib/network-interface.js +1 -1
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
- package/lib/azure-policyassignment/lib/policy-assignment.d.ts +7 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +11 -2
- package/lib/azure-policydefinition/lib/policy-definition.d.ts +21 -0
- package/lib/azure-policydefinition/lib/policy-definition.js +40 -3
- package/lib/azure-policydefinition/test/policy-definition.spec.js +211 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
- package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
- package/lib/azure-roledefinition/lib/role-definition.js +1 -1
- package/lib/azure-storageaccount/lib/storage-account.js +1 -1
- package/lib/azure-subnet/lib/subnet.js +1 -1
- package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
- package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
- package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.d.ts +225 -0
- package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
- package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
- package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
- package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.d.ts +28 -0
- package/lib/core-azure/lib/azapi/azapi-resource.js +60 -10
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
- package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
- package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.js +1 -1
- package/lib/testing/lib/metadata.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure Virtual Network Manager IPAM Pool Static CIDR implementation using AzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a unified implementation for explicitly allocating static CIDR blocks
|
|
5
|
+
* within an IPAM pool. Static CIDRs allow precise control over IP address space allocation
|
|
6
|
+
* and enable manual CIDR reservation within the pool's address space.
|
|
7
|
+
*
|
|
8
|
+
* Supported API Versions:
|
|
9
|
+
* - 2023-11-01 (Maintenance)
|
|
10
|
+
* - 2024-05-01 (Active, Latest)
|
|
11
|
+
*
|
|
12
|
+
* Features:
|
|
13
|
+
* - Automatic latest version resolution when no version is specified
|
|
14
|
+
* - Explicit version pinning for stability requirements
|
|
15
|
+
* - Schema-driven validation and transformation
|
|
16
|
+
* - CIDR format validation at construct creation time
|
|
17
|
+
* - Automatic IP address count calculation from CIDR prefix
|
|
18
|
+
* - Full backward compatibility
|
|
19
|
+
* - JSII compliance for multi-language support
|
|
20
|
+
*/
|
|
21
|
+
import * as cdktf from "cdktf";
|
|
22
|
+
import { Construct } from "constructs";
|
|
23
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
24
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
25
|
+
/**
|
|
26
|
+
* Properties for the Azure Virtual Network Manager IPAM Pool Static CIDR
|
|
27
|
+
*
|
|
28
|
+
* Extends AzapiResourceProps with Static CIDR specific properties
|
|
29
|
+
*/
|
|
30
|
+
export interface IpamPoolStaticCidrProps extends AzapiResourceProps {
|
|
31
|
+
/**
|
|
32
|
+
* Resource ID of the parent IPAM Pool
|
|
33
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/networkManagers/vnm/ipamPools/prod-pool"
|
|
34
|
+
*/
|
|
35
|
+
readonly ipamPoolId: string;
|
|
36
|
+
/**
|
|
37
|
+
* Array of IP address prefixes in CIDR notation
|
|
38
|
+
* Must be valid CIDR format (e.g., ["10.0.0.0/24"])
|
|
39
|
+
* Must be contained within the parent pool's address space
|
|
40
|
+
* @example ["10.0.1.0/24"]
|
|
41
|
+
*/
|
|
42
|
+
readonly addressPrefixes: string[];
|
|
43
|
+
/**
|
|
44
|
+
* Optional description of the static CIDR allocation
|
|
45
|
+
* @example "Reserved for production web servers"
|
|
46
|
+
*/
|
|
47
|
+
readonly description?: string;
|
|
48
|
+
/**
|
|
49
|
+
* The lifecycle rules to ignore changes
|
|
50
|
+
* @example ["tags"]
|
|
51
|
+
*/
|
|
52
|
+
readonly ignoreChanges?: string[];
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Properties for Static CIDR body
|
|
56
|
+
*/
|
|
57
|
+
export interface IpamPoolStaticCidrProperties {
|
|
58
|
+
readonly addressPrefixes: string[];
|
|
59
|
+
readonly description?: string;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* The resource body interface for Azure Static CIDR API calls
|
|
63
|
+
*/
|
|
64
|
+
export interface IpamPoolStaticCidrBody {
|
|
65
|
+
readonly properties: IpamPoolStaticCidrProperties;
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Azure Virtual Network Manager IPAM Pool Static CIDR implementation
|
|
69
|
+
*
|
|
70
|
+
* Static CIDRs explicitly allocate IP address blocks within an IPAM pool,
|
|
71
|
+
* providing precise control over address space reservations. This is useful
|
|
72
|
+
* for manual IP address management or reserving specific ranges for particular
|
|
73
|
+
* purposes within the larger pool.
|
|
74
|
+
*
|
|
75
|
+
* @example
|
|
76
|
+
* // Allocate a static CIDR block in a pool:
|
|
77
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "web-servers", {
|
|
78
|
+
* name: "web-servers-cidr",
|
|
79
|
+
* ipamPoolId: ipamPool.id,
|
|
80
|
+
* addressPrefixes: ["10.0.1.0/24"],
|
|
81
|
+
* description: "Reserved for production web servers"
|
|
82
|
+
* });
|
|
83
|
+
*
|
|
84
|
+
* @example
|
|
85
|
+
* // Allocate with explicit IP count:
|
|
86
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "database-servers", {
|
|
87
|
+
* name: "db-servers-cidr",
|
|
88
|
+
* ipamPoolId: ipamPool.id,
|
|
89
|
+
* addressPrefixes: ["10.0.2.0/24"],
|
|
90
|
+
* description: "Reserved for database servers",
|
|
91
|
+
* apiVersion: "2024-05-01"
|
|
92
|
+
* });
|
|
93
|
+
*
|
|
94
|
+
* @stability stable
|
|
95
|
+
*/
|
|
96
|
+
export declare class IpamPoolStaticCidr extends AzapiResource {
|
|
97
|
+
/**
|
|
98
|
+
* Validates address prefix for correct CIDR format
|
|
99
|
+
* Throws descriptive errors if validation fails
|
|
100
|
+
*
|
|
101
|
+
* @param addressPrefix - CIDR block to validate
|
|
102
|
+
* @throws Error if validation fails
|
|
103
|
+
*/
|
|
104
|
+
private static validateAddressPrefix;
|
|
105
|
+
/**
|
|
106
|
+
* The input properties for this Static CIDR instance
|
|
107
|
+
*/
|
|
108
|
+
readonly props: IpamPoolStaticCidrProps;
|
|
109
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
110
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
111
|
+
readonly addressPrefixOutput: cdktf.TerraformOutput;
|
|
112
|
+
readonly resourceName: string;
|
|
113
|
+
private readonly _calculatedAddressCount;
|
|
114
|
+
/**
|
|
115
|
+
* Creates a new Azure Virtual Network Manager IPAM Pool Static CIDR using the AzapiResource framework
|
|
116
|
+
*
|
|
117
|
+
* @param scope - The scope in which to define this construct
|
|
118
|
+
* @param id - The unique identifier for this instance
|
|
119
|
+
* @param props - Configuration properties for the Static CIDR
|
|
120
|
+
*/
|
|
121
|
+
constructor(scope: Construct, id: string, props: IpamPoolStaticCidrProps);
|
|
122
|
+
/**
|
|
123
|
+
* Resolves the parent resource ID for the Static CIDR
|
|
124
|
+
* Static CIDRs are scoped to IPAM Pools
|
|
125
|
+
*/
|
|
126
|
+
protected resolveParentId(props: any): string;
|
|
127
|
+
/**
|
|
128
|
+
* Gets the default API version to use when no explicit version is specified
|
|
129
|
+
*/
|
|
130
|
+
protected defaultVersion(): string;
|
|
131
|
+
/**
|
|
132
|
+
* Gets the Azure resource type for Static CIDRs
|
|
133
|
+
*/
|
|
134
|
+
protected resourceType(): string;
|
|
135
|
+
/**
|
|
136
|
+
* Gets the API schema for the resolved version
|
|
137
|
+
*/
|
|
138
|
+
protected apiSchema(): ApiSchema;
|
|
139
|
+
/**
|
|
140
|
+
* Creates the resource body for the Azure API call
|
|
141
|
+
* Note: Child resources do not include location or tags
|
|
142
|
+
*/
|
|
143
|
+
protected createResourceBody(props: any): any;
|
|
144
|
+
/**
|
|
145
|
+
* Get the address prefixes of this Static CIDR
|
|
146
|
+
* Returns the input addressPrefixes array
|
|
147
|
+
*/
|
|
148
|
+
get addressPrefixes(): string[];
|
|
149
|
+
/**
|
|
150
|
+
* Get the calculated number of IP addresses in this CIDR block
|
|
151
|
+
* This is automatically calculated from the CIDR prefix at construct creation time
|
|
152
|
+
*
|
|
153
|
+
* @returns Total count of IP addresses in the CIDR block
|
|
154
|
+
*
|
|
155
|
+
* @example
|
|
156
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "cidr", {
|
|
157
|
+
* addressPrefixes: ["10.0.1.0/24"]
|
|
158
|
+
* });
|
|
159
|
+
* console.log(staticCidr.calculatedAddressCount); // 256
|
|
160
|
+
*/
|
|
161
|
+
get calculatedAddressCount(): number;
|
|
162
|
+
/**
|
|
163
|
+
* Get the provisioning state of the Static CIDR
|
|
164
|
+
*/
|
|
165
|
+
get provisioningState(): string;
|
|
166
|
+
/**
|
|
167
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
168
|
+
*/
|
|
169
|
+
private _applyIgnoreChanges;
|
|
170
|
+
}
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.IpamPoolStaticCidr = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Azure Virtual Network Manager IPAM Pool Static CIDR implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a unified implementation for explicitly allocating static CIDR blocks
|
|
10
|
+
* within an IPAM pool. Static CIDRs allow precise control over IP address space allocation
|
|
11
|
+
* and enable manual CIDR reservation within the pool's address space.
|
|
12
|
+
*
|
|
13
|
+
* Supported API Versions:
|
|
14
|
+
* - 2023-11-01 (Maintenance)
|
|
15
|
+
* - 2024-05-01 (Active, Latest)
|
|
16
|
+
*
|
|
17
|
+
* Features:
|
|
18
|
+
* - Automatic latest version resolution when no version is specified
|
|
19
|
+
* - Explicit version pinning for stability requirements
|
|
20
|
+
* - Schema-driven validation and transformation
|
|
21
|
+
* - CIDR format validation at construct creation time
|
|
22
|
+
* - Automatic IP address count calculation from CIDR prefix
|
|
23
|
+
* - Full backward compatibility
|
|
24
|
+
* - JSII compliance for multi-language support
|
|
25
|
+
*/
|
|
26
|
+
const cdktf = require("cdktf");
|
|
27
|
+
const ipam_pool_static_cidr_schemas_1 = require("./ipam-pool-static-cidr-schemas");
|
|
28
|
+
const cidr_validator_1 = require("./utils/cidr-validator");
|
|
29
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
30
|
+
/**
|
|
31
|
+
* Azure Virtual Network Manager IPAM Pool Static CIDR implementation
|
|
32
|
+
*
|
|
33
|
+
* Static CIDRs explicitly allocate IP address blocks within an IPAM pool,
|
|
34
|
+
* providing precise control over address space reservations. This is useful
|
|
35
|
+
* for manual IP address management or reserving specific ranges for particular
|
|
36
|
+
* purposes within the larger pool.
|
|
37
|
+
*
|
|
38
|
+
* @example
|
|
39
|
+
* // Allocate a static CIDR block in a pool:
|
|
40
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "web-servers", {
|
|
41
|
+
* name: "web-servers-cidr",
|
|
42
|
+
* ipamPoolId: ipamPool.id,
|
|
43
|
+
* addressPrefixes: ["10.0.1.0/24"],
|
|
44
|
+
* description: "Reserved for production web servers"
|
|
45
|
+
* });
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* // Allocate with explicit IP count:
|
|
49
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "database-servers", {
|
|
50
|
+
* name: "db-servers-cidr",
|
|
51
|
+
* ipamPoolId: ipamPool.id,
|
|
52
|
+
* addressPrefixes: ["10.0.2.0/24"],
|
|
53
|
+
* description: "Reserved for database servers",
|
|
54
|
+
* apiVersion: "2024-05-01"
|
|
55
|
+
* });
|
|
56
|
+
*
|
|
57
|
+
* @stability stable
|
|
58
|
+
*/
|
|
59
|
+
class IpamPoolStaticCidr extends azapi_resource_1.AzapiResource {
|
|
60
|
+
/**
|
|
61
|
+
* Validates address prefix for correct CIDR format
|
|
62
|
+
* Throws descriptive errors if validation fails
|
|
63
|
+
*
|
|
64
|
+
* @param addressPrefix - CIDR block to validate
|
|
65
|
+
* @throws Error if validation fails
|
|
66
|
+
*/
|
|
67
|
+
static validateAddressPrefix(addressPrefix) {
|
|
68
|
+
if (!addressPrefix) {
|
|
69
|
+
throw new Error("Address prefix is required");
|
|
70
|
+
}
|
|
71
|
+
const validation = (0, cidr_validator_1.validateCidr)(addressPrefix);
|
|
72
|
+
if (!validation.valid) {
|
|
73
|
+
throw new Error(`Invalid address prefix: ${addressPrefix}. ${validation.errors.join(", ")}`);
|
|
74
|
+
}
|
|
75
|
+
// Log warnings if any (e.g., misaligned network address)
|
|
76
|
+
if (validation.warnings.length > 0) {
|
|
77
|
+
console.warn(`Warning for address prefix ${addressPrefix}: ${validation.warnings.join(", ")}`);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Creates a new Azure Virtual Network Manager IPAM Pool Static CIDR using the AzapiResource framework
|
|
82
|
+
*
|
|
83
|
+
* @param scope - The scope in which to define this construct
|
|
84
|
+
* @param id - The unique identifier for this instance
|
|
85
|
+
* @param props - Configuration properties for the Static CIDR
|
|
86
|
+
*/
|
|
87
|
+
constructor(scope, id, props) {
|
|
88
|
+
// Validate CIDR formats before construction
|
|
89
|
+
if (!props.addressPrefixes || props.addressPrefixes.length === 0) {
|
|
90
|
+
throw new Error("At least one address prefix is required");
|
|
91
|
+
}
|
|
92
|
+
props.addressPrefixes.forEach((prefix) => {
|
|
93
|
+
IpamPoolStaticCidr.validateAddressPrefix(prefix);
|
|
94
|
+
});
|
|
95
|
+
super(scope, id, props);
|
|
96
|
+
this.props = props;
|
|
97
|
+
// Calculate address count from first CIDR prefix
|
|
98
|
+
this._calculatedAddressCount = (0, cidr_validator_1.calculateAddressCount)(props.addressPrefixes[0]);
|
|
99
|
+
// Extract properties from the AZAPI resource outputs using Terraform interpolation
|
|
100
|
+
this.resourceName = `\${${this.terraformResource.fqn}.name}`;
|
|
101
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
102
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
103
|
+
value: this.id,
|
|
104
|
+
description: "The ID of the Static CIDR",
|
|
105
|
+
});
|
|
106
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
107
|
+
value: this.resourceName,
|
|
108
|
+
description: "The name of the Static CIDR",
|
|
109
|
+
});
|
|
110
|
+
this.addressPrefixOutput = new cdktf.TerraformOutput(this, "addressPrefixes", {
|
|
111
|
+
value: JSON.stringify(props.addressPrefixes),
|
|
112
|
+
description: "The address prefixes of the Static CIDR",
|
|
113
|
+
});
|
|
114
|
+
// Override logical IDs to match naming convention
|
|
115
|
+
this.idOutput.overrideLogicalId("id");
|
|
116
|
+
this.nameOutput.overrideLogicalId("name");
|
|
117
|
+
this.addressPrefixOutput.overrideLogicalId("addressPrefixes");
|
|
118
|
+
// Apply ignore changes if specified
|
|
119
|
+
this._applyIgnoreChanges();
|
|
120
|
+
}
|
|
121
|
+
// =============================================================================
|
|
122
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
123
|
+
// =============================================================================
|
|
124
|
+
/**
|
|
125
|
+
* Resolves the parent resource ID for the Static CIDR
|
|
126
|
+
* Static CIDRs are scoped to IPAM Pools
|
|
127
|
+
*/
|
|
128
|
+
resolveParentId(props) {
|
|
129
|
+
const typedProps = props;
|
|
130
|
+
return typedProps.ipamPoolId;
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Gets the default API version to use when no explicit version is specified
|
|
134
|
+
*/
|
|
135
|
+
defaultVersion() {
|
|
136
|
+
return "2024-05-01";
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Gets the Azure resource type for Static CIDRs
|
|
140
|
+
*/
|
|
141
|
+
resourceType() {
|
|
142
|
+
return ipam_pool_static_cidr_schemas_1.STATIC_CIDR_TYPE;
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Gets the API schema for the resolved version
|
|
146
|
+
*/
|
|
147
|
+
apiSchema() {
|
|
148
|
+
return this.resolveSchema();
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Creates the resource body for the Azure API call
|
|
152
|
+
* Note: Child resources do not include location or tags
|
|
153
|
+
*/
|
|
154
|
+
createResourceBody(props) {
|
|
155
|
+
const typedProps = props;
|
|
156
|
+
return {
|
|
157
|
+
properties: {
|
|
158
|
+
addressPrefixes: typedProps.addressPrefixes,
|
|
159
|
+
description: typedProps.description,
|
|
160
|
+
},
|
|
161
|
+
};
|
|
162
|
+
}
|
|
163
|
+
// =============================================================================
|
|
164
|
+
// PUBLIC METHODS FOR STATIC CIDR OPERATIONS
|
|
165
|
+
// =============================================================================
|
|
166
|
+
/**
|
|
167
|
+
* Get the address prefixes of this Static CIDR
|
|
168
|
+
* Returns the input addressPrefixes array
|
|
169
|
+
*/
|
|
170
|
+
get addressPrefixes() {
|
|
171
|
+
return this.props.addressPrefixes;
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Get the calculated number of IP addresses in this CIDR block
|
|
175
|
+
* This is automatically calculated from the CIDR prefix at construct creation time
|
|
176
|
+
*
|
|
177
|
+
* @returns Total count of IP addresses in the CIDR block
|
|
178
|
+
*
|
|
179
|
+
* @example
|
|
180
|
+
* const staticCidr = new IpamPoolStaticCidr(this, "cidr", {
|
|
181
|
+
* addressPrefixes: ["10.0.1.0/24"]
|
|
182
|
+
* });
|
|
183
|
+
* console.log(staticCidr.calculatedAddressCount); // 256
|
|
184
|
+
*/
|
|
185
|
+
get calculatedAddressCount() {
|
|
186
|
+
return this._calculatedAddressCount;
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Get the provisioning state of the Static CIDR
|
|
190
|
+
*/
|
|
191
|
+
get provisioningState() {
|
|
192
|
+
return `\${${this.terraformResource.fqn}.output.properties.provisioningState}`;
|
|
193
|
+
}
|
|
194
|
+
// =============================================================================
|
|
195
|
+
// PRIVATE HELPER METHODS
|
|
196
|
+
// =============================================================================
|
|
197
|
+
/**
|
|
198
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
199
|
+
*/
|
|
200
|
+
_applyIgnoreChanges() {
|
|
201
|
+
if (this.props.ignoreChanges && this.props.ignoreChanges.length > 0) {
|
|
202
|
+
this.terraformResource.addOverride("lifecycle", {
|
|
203
|
+
ignore_changes: this.props.ignoreChanges,
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
exports.IpamPoolStaticCidr = IpamPoolStaticCidr;
|
|
209
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
210
|
+
IpamPoolStaticCidr[_a] = { fqn: "@microsoft/terraform-cdk-constructs.IpamPoolStaticCidr", version: "1.4.0" };
|
|
211
|
+
(() => {
|
|
212
|
+
azapi_resource_1.AzapiResource.registerSchemas(ipam_pool_static_cidr_schemas_1.STATIC_CIDR_TYPE, ipam_pool_static_cidr_schemas_1.ALL_STATIC_CIDR_VERSIONS);
|
|
213
|
+
})();
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ipam-pool-static-cidr.js","sourceRoot":"","sources":["../../../src/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Azure Virtual Network Manager IPAM Pool Static CIDR implementation using AzapiResource framework\n *\n * This class provides a unified implementation for explicitly allocating static CIDR blocks\n * within an IPAM pool. Static CIDRs allow precise control over IP address space allocation\n * and enable manual CIDR reservation within the pool's address space.\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 * - CIDR format validation at construct creation time\n * - Automatic IP address count calculation from CIDR prefix\n * - Full backward compatibility\n * - JSII compliance for multi-language support\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_STATIC_CIDR_VERSIONS,\n  STATIC_CIDR_TYPE,\n} from \"./ipam-pool-static-cidr-schemas\";\nimport { calculateAddressCount, validateCidr } from \"./utils/cidr-validator\";\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 * Properties for the Azure Virtual Network Manager IPAM Pool Static CIDR\n *\n * Extends AzapiResourceProps with Static CIDR specific properties\n */\nexport interface IpamPoolStaticCidrProps extends AzapiResourceProps {\n  /**\n   * Resource ID of the parent IPAM Pool\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/networkManagers/vnm/ipamPools/prod-pool\"\n   */\n  readonly ipamPoolId: string;\n\n  /**\n   * Array of IP address prefixes in CIDR notation\n   * Must be valid CIDR format (e.g., [\"10.0.0.0/24\"])\n   * Must be contained within the parent pool's address space\n   * @example [\"10.0.1.0/24\"]\n   */\n  readonly addressPrefixes: string[];\n\n  /**\n   * Optional description of the static CIDR allocation\n   * @example \"Reserved for production web servers\"\n   */\n  readonly description?: string;\n\n  /**\n   * The lifecycle rules to ignore changes\n   * @example [\"tags\"]\n   */\n  readonly ignoreChanges?: string[];\n}\n\n/**\n * Properties for Static CIDR body\n */\nexport interface IpamPoolStaticCidrProperties {\n  readonly addressPrefixes: string[];\n  readonly description?: string;\n}\n\n/**\n * The resource body interface for Azure Static CIDR API calls\n */\nexport interface IpamPoolStaticCidrBody {\n  readonly properties: IpamPoolStaticCidrProperties;\n}\n\n/**\n * Azure Virtual Network Manager IPAM Pool Static CIDR implementation\n *\n * Static CIDRs explicitly allocate IP address blocks within an IPAM pool,\n * providing precise control over address space reservations. This is useful\n * for manual IP address management or reserving specific ranges for particular\n * purposes within the larger pool.\n *\n * @example\n * // Allocate a static CIDR block in a pool:\n * const staticCidr = new IpamPoolStaticCidr(this, \"web-servers\", {\n *   name: \"web-servers-cidr\",\n *   ipamPoolId: ipamPool.id,\n *   addressPrefixes: [\"10.0.1.0/24\"],\n *   description: \"Reserved for production web servers\"\n * });\n *\n * @example\n * // Allocate with explicit IP count:\n * const staticCidr = new IpamPoolStaticCidr(this, \"database-servers\", {\n *   name: \"db-servers-cidr\",\n *   ipamPoolId: ipamPool.id,\n *   addressPrefixes: [\"10.0.2.0/24\"],\n *   description: \"Reserved for database servers\",\n *   apiVersion: \"2024-05-01\"\n * });\n *\n * @stability stable\n */\nexport class IpamPoolStaticCidr extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(STATIC_CIDR_TYPE, ALL_STATIC_CIDR_VERSIONS);\n  }\n\n  /**\n   * Validates address prefix for correct CIDR format\n   * Throws descriptive errors if validation fails\n   *\n   * @param addressPrefix - CIDR block to validate\n   * @throws Error if validation fails\n   */\n  private static validateAddressPrefix(addressPrefix: string): void {\n    if (!addressPrefix) {\n      throw new Error(\"Address prefix is required\");\n    }\n\n    const validation = validateCidr(addressPrefix);\n    if (!validation.valid) {\n      throw new Error(\n        `Invalid address prefix: ${addressPrefix}. ${validation.errors.join(\", \")}`,\n      );\n    }\n\n    // Log warnings if any (e.g., misaligned network address)\n    if (validation.warnings.length > 0) {\n      console.warn(\n        `Warning for address prefix ${addressPrefix}: ${validation.warnings.join(\", \")}`,\n      );\n    }\n  }\n\n  /**\n   * The input properties for this Static CIDR instance\n   */\n  public readonly props: IpamPoolStaticCidrProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly addressPrefixOutput: cdktf.TerraformOutput;\n\n  // Public properties\n  public readonly resourceName: string;\n\n  // Store calculated address count\n  private readonly _calculatedAddressCount: number;\n\n  /**\n   * Creates a new Azure Virtual Network Manager IPAM Pool Static CIDR using the AzapiResource framework\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 Static CIDR\n   */\n  constructor(scope: Construct, id: string, props: IpamPoolStaticCidrProps) {\n    // Validate CIDR formats before construction\n    if (!props.addressPrefixes || props.addressPrefixes.length === 0) {\n      throw new Error(\"At least one address prefix is required\");\n    }\n    props.addressPrefixes.forEach((prefix) => {\n      IpamPoolStaticCidr.validateAddressPrefix(prefix);\n    });\n\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Calculate address count from first CIDR prefix\n    this._calculatedAddressCount = calculateAddressCount(\n      props.addressPrefixes[0],\n    );\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 Static CIDR\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: this.resourceName,\n      description: \"The name of the Static CIDR\",\n    });\n\n    this.addressPrefixOutput = new cdktf.TerraformOutput(\n      this,\n      \"addressPrefixes\",\n      {\n        value: JSON.stringify(props.addressPrefixes),\n        description: \"The address prefixes of the Static CIDR\",\n      },\n    );\n\n    // Override logical IDs to match naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.addressPrefixOutput.overrideLogicalId(\"addressPrefixes\");\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 Static CIDR\n   * Static CIDRs are scoped to IPAM Pools\n   */\n  protected resolveParentId(props: any): string {\n    const typedProps = props as IpamPoolStaticCidrProps;\n    return typedProps.ipamPoolId;\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   */\n  protected defaultVersion(): string {\n    return \"2024-05-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Static CIDRs\n   */\n  protected resourceType(): string {\n    return STATIC_CIDR_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   * Note: Child resources do not include location or tags\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as IpamPoolStaticCidrProps;\n\n    return {\n      properties: {\n        addressPrefixes: typedProps.addressPrefixes,\n        description: typedProps.description,\n      },\n    };\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR STATIC CIDR OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the address prefixes of this Static CIDR\n   * Returns the input addressPrefixes array\n   */\n  public get addressPrefixes(): string[] {\n    return this.props.addressPrefixes;\n  }\n\n  /**\n   * Get the calculated number of IP addresses in this CIDR block\n   * This is automatically calculated from the CIDR prefix at construct creation time\n   *\n   * @returns Total count of IP addresses in the CIDR block\n   *\n   * @example\n   * const staticCidr = new IpamPoolStaticCidr(this, \"cidr\", {\n   *   addressPrefixes: [\"10.0.1.0/24\"]\n   * });\n   * console.log(staticCidr.calculatedAddressCount); // 256\n   */\n  public get calculatedAddressCount(): number {\n    return this._calculatedAddressCount;\n  }\n\n  /**\n   * Get the provisioning state of the Static CIDR\n   */\n  public get provisioningState(): string {\n    return `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`;\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,175 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure Virtual Network Manager IPAM Pool implementation using AzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a unified implementation for Azure Virtual Network Manager IPAM Pools
|
|
5
|
+
* that automatically handles version management, schema validation, and property transformation
|
|
6
|
+
* across all supported API versions.
|
|
7
|
+
*
|
|
8
|
+
* Supported API Versions:
|
|
9
|
+
* - 2024-05-01 (Active, Latest)
|
|
10
|
+
*
|
|
11
|
+
* Features:
|
|
12
|
+
* - Automatic latest version resolution when no version is specified
|
|
13
|
+
* - Explicit version pinning for stability requirements
|
|
14
|
+
* - Schema-driven validation and transformation
|
|
15
|
+
* - CIDR validation and overlap detection
|
|
16
|
+
* - Hierarchical pool support
|
|
17
|
+
* - JSII compliance for multi-language support
|
|
18
|
+
*/
|
|
19
|
+
import * as cdktf from "cdktf";
|
|
20
|
+
import { Construct } from "constructs";
|
|
21
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
22
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
23
|
+
/**
|
|
24
|
+
* Properties for the Azure Virtual Network Manager IPAM Pool
|
|
25
|
+
*
|
|
26
|
+
* Extends AzapiResourceProps with IPAM Pool specific properties
|
|
27
|
+
*/
|
|
28
|
+
export interface IpamPoolProps extends AzapiResourceProps {
|
|
29
|
+
/**
|
|
30
|
+
* Resource ID of the parent Network Manager
|
|
31
|
+
* @example "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg/providers/Microsoft.Network/networkManagers/vnm"
|
|
32
|
+
*/
|
|
33
|
+
readonly networkManagerId: string;
|
|
34
|
+
/**
|
|
35
|
+
* IP address prefixes for the pool
|
|
36
|
+
* Must be valid CIDR notation (e.g., "10.0.0.0/8")
|
|
37
|
+
* Multiple prefixes must not overlap
|
|
38
|
+
* @example ["10.0.0.0/8", "172.16.0.0/12"]
|
|
39
|
+
*/
|
|
40
|
+
readonly addressPrefixes: string[];
|
|
41
|
+
/**
|
|
42
|
+
* Optional description of the IPAM pool
|
|
43
|
+
* @example "Production IP address pool for East US region"
|
|
44
|
+
*/
|
|
45
|
+
readonly description?: string;
|
|
46
|
+
/**
|
|
47
|
+
* Optional friendly display name
|
|
48
|
+
* @example "East US Production Pool"
|
|
49
|
+
*/
|
|
50
|
+
readonly displayName?: string;
|
|
51
|
+
/**
|
|
52
|
+
* Name of parent pool for hierarchical pools
|
|
53
|
+
* Leave empty/undefined for root pools
|
|
54
|
+
* @example "root-pool"
|
|
55
|
+
*/
|
|
56
|
+
readonly parentPoolName?: string;
|
|
57
|
+
/**
|
|
58
|
+
* The lifecycle rules to ignore changes
|
|
59
|
+
* @example ["tags"]
|
|
60
|
+
*/
|
|
61
|
+
readonly ignoreChanges?: string[];
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Properties for IPAM Pool body
|
|
65
|
+
*/
|
|
66
|
+
export interface IpamPoolProperties {
|
|
67
|
+
readonly addressPrefixes: string[];
|
|
68
|
+
readonly description?: string;
|
|
69
|
+
readonly displayName?: string;
|
|
70
|
+
readonly parentPoolName?: string;
|
|
71
|
+
}
|
|
72
|
+
/**
|
|
73
|
+
* The resource body interface for Azure IPAM Pool API calls
|
|
74
|
+
*/
|
|
75
|
+
export interface IpamPoolBody {
|
|
76
|
+
readonly location: string;
|
|
77
|
+
readonly tags?: Record<string, string>;
|
|
78
|
+
readonly properties: IpamPoolProperties;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Azure Virtual Network Manager IPAM Pool implementation
|
|
82
|
+
*
|
|
83
|
+
* IPAM Pools provide centralized IP address management for virtual networks,
|
|
84
|
+
* enabling automatic CIDR allocation, overlap prevention, and hierarchical
|
|
85
|
+
* address space organization. They are essential for managing IP addresses
|
|
86
|
+
* at scale across multiple virtual networks and subscriptions.
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* // Basic IPAM pool for production workloads:
|
|
90
|
+
* const ipamPool = new IpamPool(this, "prod-pool", {
|
|
91
|
+
* name: "production-pool",
|
|
92
|
+
* location: "eastus",
|
|
93
|
+
* networkManagerId: networkManager.id,
|
|
94
|
+
* addressPrefixes: ["10.0.0.0/8"],
|
|
95
|
+
* description: "Root IP address pool for production",
|
|
96
|
+
* displayName: "Production Pool"
|
|
97
|
+
* });
|
|
98
|
+
*
|
|
99
|
+
* @example
|
|
100
|
+
* // Hierarchical pool with parent reference:
|
|
101
|
+
* const childPool = new IpamPool(this, "eastus-pool", {
|
|
102
|
+
* name: "eastus-pool",
|
|
103
|
+
* location: "eastus",
|
|
104
|
+
* networkManagerId: networkManager.id,
|
|
105
|
+
* addressPrefixes: ["10.1.0.0/16"],
|
|
106
|
+
* parentPoolName: "production-pool",
|
|
107
|
+
* description: "East US regional pool"
|
|
108
|
+
* });
|
|
109
|
+
*
|
|
110
|
+
* @stability stable
|
|
111
|
+
*/
|
|
112
|
+
export declare class IpamPool extends AzapiResource {
|
|
113
|
+
/**
|
|
114
|
+
* Validates address prefixes for format and overlap
|
|
115
|
+
* Throws descriptive errors if validation fails
|
|
116
|
+
*
|
|
117
|
+
* @param prefixes - Array of CIDR blocks to validate
|
|
118
|
+
* @throws Error if validation fails
|
|
119
|
+
*/
|
|
120
|
+
private static validateAddressPrefixes;
|
|
121
|
+
/**
|
|
122
|
+
* The input properties for this IPAM Pool instance
|
|
123
|
+
*/
|
|
124
|
+
readonly props: IpamPoolProps;
|
|
125
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
126
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
127
|
+
readonly locationOutput: cdktf.TerraformOutput;
|
|
128
|
+
readonly resourceName: string;
|
|
129
|
+
/**
|
|
130
|
+
* Creates a new Azure Virtual Network Manager IPAM Pool using the AzapiResource framework
|
|
131
|
+
*
|
|
132
|
+
* @param scope - The scope in which to define this construct
|
|
133
|
+
* @param id - The unique identifier for this instance
|
|
134
|
+
* @param props - Configuration properties for the IPAM Pool
|
|
135
|
+
*/
|
|
136
|
+
constructor(scope: Construct, id: string, props: IpamPoolProps);
|
|
137
|
+
/**
|
|
138
|
+
* Resolves the parent resource ID for the IPAM Pool
|
|
139
|
+
* IPAM Pools are scoped to Network Managers
|
|
140
|
+
*/
|
|
141
|
+
protected resolveParentId(props: any): string;
|
|
142
|
+
/**
|
|
143
|
+
* Gets the default API version to use when no explicit version is specified
|
|
144
|
+
*/
|
|
145
|
+
protected defaultVersion(): string;
|
|
146
|
+
/**
|
|
147
|
+
* Gets the Azure resource type for IPAM Pools
|
|
148
|
+
*/
|
|
149
|
+
protected resourceType(): string;
|
|
150
|
+
/**
|
|
151
|
+
* Gets the API schema for the resolved version
|
|
152
|
+
*/
|
|
153
|
+
protected apiSchema(): ApiSchema;
|
|
154
|
+
/**
|
|
155
|
+
* Creates the resource body for the Azure API call
|
|
156
|
+
*/
|
|
157
|
+
protected createResourceBody(props: any): any;
|
|
158
|
+
/**
|
|
159
|
+
* Calculate total number of IP addresses in this pool
|
|
160
|
+
* Sums up all addresses from all CIDR blocks
|
|
161
|
+
*
|
|
162
|
+
* @returns Total count of IP addresses across all prefixes
|
|
163
|
+
*
|
|
164
|
+
* @example
|
|
165
|
+
* const pool = new IpamPool(this, "pool", {
|
|
166
|
+
* addressPrefixes: ["10.0.0.0/24", "10.1.0.0/24"]
|
|
167
|
+
* });
|
|
168
|
+
* console.log(pool.totalAddressCount); // 512 (256 + 256)
|
|
169
|
+
*/
|
|
170
|
+
get totalAddressCount(): number;
|
|
171
|
+
/**
|
|
172
|
+
* Applies ignore changes lifecycle rules if specified in props
|
|
173
|
+
*/
|
|
174
|
+
private _applyIgnoreChanges;
|
|
175
|
+
}
|