@microsoft/terraform-cdk-constructs 1.7.1 → 1.9.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 +46476 -27231
- package/API.md +68443 -28286
- 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-dnszone/lib/index.d.ts +1 -0
- package/lib/azure-dnszone/lib/index.js +2 -1
- package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
- package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
- package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
- package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
- package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
- package/lib/azure-dnszone/lib/records/index.js +38 -0
- package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
- package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
- package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
- package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
- package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
- package/lib/azure-loganalyticsworkspace/index.js +23 -0
- package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
- package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
- 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-networkwatcher/index.d.ts +14 -0
- package/lib/azure-networkwatcher/index.js +31 -0
- package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
- package/lib/azure-networkwatcher/lib/index.js +22 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
- package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
- package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-policysetdefinition/index.d.ts +10 -0
- package/lib/azure-policysetdefinition/index.js +27 -0
- package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
- package/lib/azure-policysetdefinition/lib/index.js +22 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
- package/lib/azure-privatednszone/lib/index.d.ts +1 -0
- package/lib/azure-privatednszone/lib/index.js +2 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
- package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
- package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
- package/lib/azure-privatednszone/lib/records/index.js +26 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
- 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-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
- package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
- 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/virtual-network-manager.js +1 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
- 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/index.d.ts +23 -0
- package/lib/index.js +25 -2
- 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,255 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.PolicySetDefinition = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Policy Set Definition (Initiative) implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for Azure Policy Set Definitions
|
|
10
|
+
* that automatically handles version management, schema validation, and property
|
|
11
|
+
* transformation across all supported API versions.
|
|
12
|
+
*
|
|
13
|
+
* Policy Set Definitions (also known as Initiatives in Azure Portal) allow you to
|
|
14
|
+
* group multiple policy definitions together and assign them as a single unit.
|
|
15
|
+
*
|
|
16
|
+
* Supported API Versions:
|
|
17
|
+
* - 2023-04-01 (Active, Latest)
|
|
18
|
+
* - 2021-06-01 (Active, Backward Compatibility)
|
|
19
|
+
*
|
|
20
|
+
* Features:
|
|
21
|
+
* - Automatic latest version resolution when no version is specified
|
|
22
|
+
* - Explicit version pinning for stability requirements
|
|
23
|
+
* - Schema-driven validation and transformation
|
|
24
|
+
* - Full JSII compliance for multi-language support
|
|
25
|
+
* - Support for policy definition references with parameters
|
|
26
|
+
* - Policy definition groups for organization
|
|
27
|
+
* - Initiative-level parameter definitions
|
|
28
|
+
*/
|
|
29
|
+
const crypto_1 = require("crypto");
|
|
30
|
+
const cdktf = require("cdktf");
|
|
31
|
+
const policy_set_definition_schemas_1 = require("./policy-set-definition-schemas");
|
|
32
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
33
|
+
/**
|
|
34
|
+
* Unified Azure Policy Set Definition (Initiative) implementation
|
|
35
|
+
*
|
|
36
|
+
* This class provides a single, version-aware implementation for managing Azure
|
|
37
|
+
* Policy Set Definitions. It automatically handles version resolution, schema validation,
|
|
38
|
+
* and property transformation.
|
|
39
|
+
*
|
|
40
|
+
* Policy Set Definitions allow you to group multiple policy definitions together
|
|
41
|
+
* and assign them as a single unit (also known as "Initiatives" in Azure Portal).
|
|
42
|
+
*
|
|
43
|
+
* Note: Policy set definitions are created at subscription or management group scope.
|
|
44
|
+
* They do not have a location property as they are not region-specific.
|
|
45
|
+
*
|
|
46
|
+
* @example
|
|
47
|
+
* const initiative = new PolicySetDefinition(this, "security-initiative", {
|
|
48
|
+
* displayName: "Security Baseline",
|
|
49
|
+
* scope: "/subscriptions/00000000-0000-0000-0000-000000000000",
|
|
50
|
+
* policyDefinitions: [
|
|
51
|
+
* {
|
|
52
|
+
* policyDefinitionId: "/providers/Microsoft.Authorization/policyDefinitions/abc123",
|
|
53
|
+
* policyDefinitionReferenceId: "auditVMsWithoutExtensions",
|
|
54
|
+
* },
|
|
55
|
+
* ],
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* @stability stable
|
|
59
|
+
*/
|
|
60
|
+
class PolicySetDefinition extends azapi_resource_1.AzapiResource {
|
|
61
|
+
/**
|
|
62
|
+
* Creates a new Azure Policy Set Definition using the AzapiResource framework
|
|
63
|
+
*
|
|
64
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
65
|
+
* validation, and resource creation.
|
|
66
|
+
*
|
|
67
|
+
* @param scope - The scope in which to define this construct
|
|
68
|
+
* @param id - The unique identifier for this instance
|
|
69
|
+
* @param props - Configuration properties for the Policy Set Definition
|
|
70
|
+
*/
|
|
71
|
+
constructor(scope, id, props) {
|
|
72
|
+
// Validate required properties
|
|
73
|
+
if (!props.displayName || props.displayName.trim() === "") {
|
|
74
|
+
throw new Error("displayName is required for policy set definitions");
|
|
75
|
+
}
|
|
76
|
+
if (!props.policyDefinitions || props.policyDefinitions.length === 0) {
|
|
77
|
+
throw new Error("At least one policy definition reference is required in policyDefinitions");
|
|
78
|
+
}
|
|
79
|
+
// Validate policy definition references
|
|
80
|
+
props.policyDefinitions.forEach((policyDef, index) => {
|
|
81
|
+
if (!policyDef.policyDefinitionId) {
|
|
82
|
+
throw new Error(`policyDefinitionId is required for policy definition at index ${index}`);
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
// Validate policy definition groups if provided
|
|
86
|
+
if (props.policyDefinitionGroups) {
|
|
87
|
+
const groupNames = new Set();
|
|
88
|
+
props.policyDefinitionGroups.forEach((group, index) => {
|
|
89
|
+
if (!group.name) {
|
|
90
|
+
throw new Error(`name is required for policy definition group at index ${index}`);
|
|
91
|
+
}
|
|
92
|
+
if (groupNames.has(group.name)) {
|
|
93
|
+
throw new Error(`Duplicate group name '${group.name}' in policyDefinitionGroups`);
|
|
94
|
+
}
|
|
95
|
+
groupNames.add(group.name);
|
|
96
|
+
});
|
|
97
|
+
// Validate that policy definitions reference valid groups
|
|
98
|
+
const validGroupNames = Array.from(groupNames);
|
|
99
|
+
props.policyDefinitions.forEach((policyDef, index) => {
|
|
100
|
+
if (policyDef.groupNames) {
|
|
101
|
+
policyDef.groupNames.forEach((groupName) => {
|
|
102
|
+
if (!validGroupNames.includes(groupName)) {
|
|
103
|
+
throw new Error(`Policy definition at index ${index} references unknown group '${groupName}'. Valid groups are: ${validGroupNames.join(", ")}`);
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
super(scope, id, props);
|
|
110
|
+
this.props = props;
|
|
111
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
112
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
113
|
+
value: this.id,
|
|
114
|
+
description: "The ID of the Policy Set Definition",
|
|
115
|
+
});
|
|
116
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
117
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
118
|
+
description: "The name of the Policy Set Definition",
|
|
119
|
+
});
|
|
120
|
+
this.policySetDefinitionIdOutput = new cdktf.TerraformOutput(this, "policy_set_definition_id", {
|
|
121
|
+
value: this.id,
|
|
122
|
+
description: "The Policy Set Definition ID (same as id, for use in policy assignments)",
|
|
123
|
+
});
|
|
124
|
+
// Override logical IDs to match original naming convention
|
|
125
|
+
this.idOutput.overrideLogicalId("id");
|
|
126
|
+
this.nameOutput.overrideLogicalId("name");
|
|
127
|
+
this.policySetDefinitionIdOutput.overrideLogicalId("policy_set_definition_id");
|
|
128
|
+
}
|
|
129
|
+
// =============================================================================
|
|
130
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
131
|
+
// =============================================================================
|
|
132
|
+
/**
|
|
133
|
+
* Gets the default API version to use when no explicit version is specified
|
|
134
|
+
* Returns the most recent stable version as the default
|
|
135
|
+
*/
|
|
136
|
+
defaultVersion() {
|
|
137
|
+
return "2023-04-01";
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Gets the Azure resource type for Policy Set Definitions
|
|
141
|
+
*/
|
|
142
|
+
resourceType() {
|
|
143
|
+
return policy_set_definition_schemas_1.POLICY_SET_DEFINITION_TYPE;
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Gets the API schema for the resolved version
|
|
147
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
148
|
+
*/
|
|
149
|
+
apiSchema() {
|
|
150
|
+
return this.resolveSchema();
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Overrides the name resolution to generate deterministic GUIDs for policy set definitions
|
|
154
|
+
*
|
|
155
|
+
* Policy set definitions can use custom names or auto-generated GUIDs.
|
|
156
|
+
* This implementation generates a deterministic UUID based on the policy set definition's
|
|
157
|
+
* key properties if no name is provided.
|
|
158
|
+
*/
|
|
159
|
+
resolveName(props) {
|
|
160
|
+
const typedProps = props;
|
|
161
|
+
// If name is provided, use it
|
|
162
|
+
if (typedProps.name) {
|
|
163
|
+
return typedProps.name;
|
|
164
|
+
}
|
|
165
|
+
// Generate a deterministic GUID based on display name and scope
|
|
166
|
+
const hashInput = [typedProps.displayName, typedProps.scope].join("|");
|
|
167
|
+
const hash = (0, crypto_1.createHash)("sha256").update(hashInput).digest("hex");
|
|
168
|
+
// Convert hash to UUID format (8-4-4-4-12)
|
|
169
|
+
return [
|
|
170
|
+
hash.substring(0, 8),
|
|
171
|
+
hash.substring(8, 12),
|
|
172
|
+
hash.substring(12, 16),
|
|
173
|
+
hash.substring(16, 20),
|
|
174
|
+
hash.substring(20, 32),
|
|
175
|
+
].join("-");
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Creates the resource body for the Azure API call
|
|
179
|
+
* Transforms the input properties into the JSON format expected by Azure REST API
|
|
180
|
+
*
|
|
181
|
+
* Note: Policy set definitions do not have a location property as they are
|
|
182
|
+
* scope-specific resources deployed at subscription or management group level.
|
|
183
|
+
*/
|
|
184
|
+
createResourceBody(props) {
|
|
185
|
+
const typedProps = props;
|
|
186
|
+
const body = {
|
|
187
|
+
properties: {
|
|
188
|
+
displayName: typedProps.displayName,
|
|
189
|
+
policyType: typedProps.policyType || "Custom",
|
|
190
|
+
policyDefinitions: typedProps.policyDefinitions,
|
|
191
|
+
},
|
|
192
|
+
};
|
|
193
|
+
// Add optional properties only if specified
|
|
194
|
+
if (typedProps.description) {
|
|
195
|
+
body.properties.description = typedProps.description;
|
|
196
|
+
}
|
|
197
|
+
if (typedProps.metadata) {
|
|
198
|
+
body.properties.metadata = typedProps.metadata;
|
|
199
|
+
}
|
|
200
|
+
if (typedProps.parameters) {
|
|
201
|
+
body.properties.parameters = typedProps.parameters;
|
|
202
|
+
}
|
|
203
|
+
if (typedProps.policyDefinitionGroups &&
|
|
204
|
+
typedProps.policyDefinitionGroups.length > 0) {
|
|
205
|
+
body.properties.policyDefinitionGroups =
|
|
206
|
+
typedProps.policyDefinitionGroups;
|
|
207
|
+
}
|
|
208
|
+
return body;
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Resolves the parent resource ID for Policy Set Definition
|
|
212
|
+
* Policy Set Definitions are created at subscription or management group scope
|
|
213
|
+
*
|
|
214
|
+
* @param props - The resource properties
|
|
215
|
+
* @returns The parent resource ID (the scope)
|
|
216
|
+
*/
|
|
217
|
+
resolveParentId(props) {
|
|
218
|
+
return props.scope;
|
|
219
|
+
}
|
|
220
|
+
// =============================================================================
|
|
221
|
+
// PUBLIC METHODS FOR POLICY SET DEFINITION OPERATIONS
|
|
222
|
+
// =============================================================================
|
|
223
|
+
/**
|
|
224
|
+
* Get the full resource identifier for use in policy assignments
|
|
225
|
+
* Alias for the id property
|
|
226
|
+
*/
|
|
227
|
+
get policySetDefinitionId() {
|
|
228
|
+
return this.id;
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Get the display name of the policy set definition
|
|
232
|
+
*/
|
|
233
|
+
get displayName() {
|
|
234
|
+
return this.props.displayName;
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Get the policy type
|
|
238
|
+
*/
|
|
239
|
+
get policyType() {
|
|
240
|
+
return this.props.policyType || "Custom";
|
|
241
|
+
}
|
|
242
|
+
/**
|
|
243
|
+
* Get the number of policy definitions in this set
|
|
244
|
+
*/
|
|
245
|
+
get policyDefinitionCount() {
|
|
246
|
+
return this.props.policyDefinitions.length;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
exports.PolicySetDefinition = PolicySetDefinition;
|
|
250
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
251
|
+
PolicySetDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicySetDefinition", version: "1.9.0" };
|
|
252
|
+
(() => {
|
|
253
|
+
azapi_resource_1.AzapiResource.registerSchemas(policy_set_definition_schemas_1.POLICY_SET_DEFINITION_TYPE, policy_set_definition_schemas_1.ALL_POLICY_SET_DEFINITION_VERSIONS);
|
|
254
|
+
})();
|
|
255
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-set-definition.js","sourceRoot":"","sources":["../../../src/azure-policysetdefinition/lib/policy-set-definition.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Policy Set Definition (Initiative) implementation using AzapiResource framework\n *\n * This class provides a version-aware implementation for Azure Policy Set Definitions\n * that automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Policy Set Definitions (also known as Initiatives in Azure Portal) allow you to\n * group multiple policy definitions together and assign them as a single unit.\n *\n * Supported API Versions:\n * - 2023-04-01 (Active, Latest)\n * - 2021-06-01 (Active, Backward Compatibility)\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 JSII compliance for multi-language support\n * - Support for policy definition references with parameters\n * - Policy definition groups for organization\n * - Initiative-level parameter definitions\n */\n\nimport { createHash } from \"crypto\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_POLICY_SET_DEFINITION_VERSIONS,\n  POLICY_SET_DEFINITION_TYPE,\n} from \"./policy-set-definition-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 * A reference to a policy definition within a policy set\n *\n * This defines which policy definitions are included in the initiative\n * and how they are configured with parameters.\n */\nexport interface PolicyDefinitionReference {\n  /**\n   * The ID of the policy definition to include in the set\n   *\n   * This can be:\n   * - A built-in policy: /providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionId}\n   * - A custom policy at subscription level: /subscriptions/{subscriptionId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionId}\n   * - A custom policy at management group level: /providers/Microsoft.Management/managementGroups/{managementGroupId}/providers/Microsoft.Authorization/policyDefinitions/{policyDefinitionId}\n   *\n   * @example \"/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d\"\n   */\n  readonly policyDefinitionId: string;\n\n  /**\n   * A unique identifier for this policy definition reference within the set\n   *\n   * This ID is used to reference this specific policy in the initiative\n   * and must be unique within the policy set definition.\n   *\n   * @example \"auditVMsWithoutTags\"\n   */\n  readonly policyDefinitionReferenceId?: string;\n\n  /**\n   * Parameter values for this policy definition\n   *\n   * These values override the default parameter values in the policy definition.\n   * Parameters can reference initiative-level parameters using the format:\n   * { \"value\": \"[parameters('initiativeParameterName')]\" }\n   *\n   * @example { \"tagName\": { \"value\": \"environment\" }, \"tagValue\": { \"value\": \"[parameters('requiredTagValue')]\" } }\n   */\n  readonly parameters?: { [key: string]: PolicyParameterValue };\n\n  /**\n   * Group names that this policy definition belongs to\n   *\n   * Groups help organize policies within an initiative and can be used\n   * for compliance reporting and management.\n   *\n   * @example [\"Security\", \"Compliance\"]\n   */\n  readonly groupNames?: string[];\n}\n\n/**\n * A group for organizing policy definitions within a policy set\n *\n * Groups provide a way to categorize and organize policies within an initiative\n * for better management and compliance reporting.\n */\nexport interface PolicyDefinitionGroup {\n  /**\n   * The name of the group (must be unique within the policy set)\n   *\n   * This name is referenced by policy definitions to indicate membership.\n   *\n   * @example \"Security\"\n   */\n  readonly name: string;\n\n  /**\n   * The display name of the group shown in Azure Portal\n   *\n   * @example \"Security Policies\"\n   */\n  readonly displayName?: string;\n\n  /**\n   * The category this group belongs to\n   *\n   * Categories help organize groups and are displayed in the Azure Portal.\n   *\n   * @example \"Security Center\"\n   */\n  readonly category?: string;\n\n  /**\n   * A description of the group's purpose\n   *\n   * @example \"Policies related to security configuration and compliance\"\n   */\n  readonly description?: string;\n\n  /**\n   * Additional metadata for the group\n   */\n  readonly additionalMetadataId?: string;\n}\n\n/**\n * Metadata for the policy set definition\n *\n * Metadata provides additional information about the policy set\n * without affecting its evaluation logic.\n */\nexport interface PolicySetMetadata {\n  /**\n   * The category of the policy set for Azure Portal organization\n   *\n   * @example \"Security Center\"\n   */\n  readonly category?: string;\n\n  /**\n   * The version of the policy set definition\n   *\n   * @example \"1.0.0\"\n   */\n  readonly version?: string;\n\n  /**\n   * Whether this policy set is in preview\n   *\n   * @default false\n   */\n  readonly preview?: boolean;\n\n  /**\n   * Whether this policy set is deprecated\n   *\n   * @default false\n   */\n  readonly deprecated?: boolean;\n}\n\n/**\n * Metadata for a policy set parameter\n *\n * Provides additional information for Azure Portal integration.\n */\nexport interface PolicySetParameterMetadata {\n  /**\n   * Strong type for Azure Portal resource picker integration\n   */\n  readonly strongType?: string;\n\n  /**\n   * Display name in Azure Portal\n   */\n  readonly displayName?: string;\n\n  /**\n   * Description in Azure Portal\n   */\n  readonly description?: string;\n}\n\n/**\n * Parameter definition for the policy set\n *\n * These parameters can be referenced by policy definitions within the set.\n */\nexport interface PolicySetParameterDefinition {\n  /**\n   * The data type of the parameter\n   */\n  readonly type:\n    | \"String\"\n    | \"Array\"\n    | \"Object\"\n    | \"Boolean\"\n    | \"Integer\"\n    | \"Float\"\n    | \"DateTime\";\n\n  /**\n   * Display name for the parameter in Azure Portal\n   */\n  readonly displayName?: string;\n\n  /**\n   * Description of the parameter\n   */\n  readonly description?: string;\n\n  /**\n   * Default value for the parameter\n   */\n  readonly defaultValue?: any;\n\n  /**\n   * Allowed values for the parameter\n   */\n  readonly allowedValues?: any[];\n\n  /**\n   * Metadata for the parameter (e.g., strongType for Azure Portal integration)\n   */\n  readonly metadata?: PolicySetParameterMetadata;\n}\n\n/**\n * A parameter value, either a direct value or a reference\n */\nexport interface PolicyParameterValue {\n  /**\n   * The value of the parameter\n   *\n   * Can be a direct value or a reference to an initiative parameter\n   * using the format: \"[parameters('parameterName')]\"\n   */\n  readonly value: any;\n}\n\n/**\n * Properties for the unified Azure Policy Set Definition\n *\n * Extends AzapiResourceProps with Policy Set Definition specific properties\n */\nexport interface PolicySetDefinitionProps extends AzapiResourceProps {\n  /**\n   * The scope at which to create the policy set definition\n   *\n   * This can be:\n   * - A subscription: /subscriptions/{subscriptionId}\n   * - A management group: /providers/Microsoft.Management/managementGroups/{managementGroupId}\n   *\n   * @example \"/subscriptions/00000000-0000-0000-0000-000000000000\"\n   * @example \"/providers/Microsoft.Management/managementGroups/my-management-group\"\n   */\n  readonly scope: string;\n\n  /**\n   * The display name of the policy set definition\n   *\n   * This is the name shown in the Azure Portal.\n   * Required property.\n   *\n   * @example \"Security Baseline Initiative\"\n   */\n  readonly displayName: string;\n\n  /**\n   * Description of the policy set definition\n   *\n   * @example \"This initiative applies a set of security policies to ensure baseline compliance.\"\n   */\n  readonly description?: string;\n\n  /**\n   * The type of policy set definition\n   *\n   * @default \"Custom\"\n   */\n  readonly policyType?: \"BuiltIn\" | \"Custom\" | \"Static\";\n\n  /**\n   * Metadata for the policy set definition\n   *\n   * Includes category, version, preview, and deprecated flags.\n   */\n  readonly metadata?: PolicySetMetadata;\n\n  /**\n   * Parameter definitions for the policy set\n   *\n   * These parameters can be referenced by policy definitions in the set\n   * using the format: \"[parameters('parameterName')]\"\n   */\n  readonly parameters?: { [key: string]: PolicySetParameterDefinition };\n\n  /**\n   * Array of policy definition references\n   *\n   * Each reference specifies a policy definition to include in the set\n   * along with its parameter values and group memberships.\n   * Required property.\n   */\n  readonly policyDefinitions: PolicyDefinitionReference[];\n\n  /**\n   * Groups for organizing policy definitions in the set\n   *\n   * Groups help categorize policies for management and compliance reporting.\n   */\n  readonly policyDefinitionGroups?: PolicyDefinitionGroup[];\n}\n\n/**\n * Properties interface for Azure Policy Set Definition\n * This is required for JSII compliance to support multi-language code generation\n */\nexport interface PolicySetDefinitionProperties {\n  /**\n   * The display name of the policy set definition\n   */\n  readonly displayName: string;\n\n  /**\n   * Description of the policy set definition\n   */\n  readonly description?: string;\n\n  /**\n   * The type of policy set definition\n   */\n  readonly policyType?: string;\n\n  /**\n   * Metadata for the policy set definition\n   */\n  readonly metadata?: PolicySetMetadata;\n\n  /**\n   * Parameter definitions for the policy set\n   */\n  readonly parameters?: { [key: string]: PolicySetParameterDefinition };\n\n  /**\n   * Array of policy definition references\n   */\n  readonly policyDefinitions: PolicyDefinitionReference[];\n\n  /**\n   * Groups for organizing policy definitions\n   */\n  readonly policyDefinitionGroups?: PolicyDefinitionGroup[];\n}\n\n/**\n * The resource body interface for Azure Policy Set Definition API calls\n * This matches the Azure REST API schema for policy set definitions\n */\nexport interface PolicySetDefinitionBody {\n  /**\n   * The properties of the policy set definition\n   */\n  readonly properties: PolicySetDefinitionProperties;\n}\n\n/**\n * Unified Azure Policy Set Definition (Initiative) implementation\n *\n * This class provides a single, version-aware implementation for managing Azure\n * Policy Set Definitions. It automatically handles version resolution, schema validation,\n * and property transformation.\n *\n * Policy Set Definitions allow you to group multiple policy definitions together\n * and assign them as a single unit (also known as \"Initiatives\" in Azure Portal).\n *\n * Note: Policy set definitions are created at subscription or management group scope.\n * They do not have a location property as they are not region-specific.\n *\n * @example\n * const initiative = new PolicySetDefinition(this, \"security-initiative\", {\n *   displayName: \"Security Baseline\",\n *   scope: \"/subscriptions/00000000-0000-0000-0000-000000000000\",\n *   policyDefinitions: [\n *     {\n *       policyDefinitionId: \"/providers/Microsoft.Authorization/policyDefinitions/abc123\",\n *       policyDefinitionReferenceId: \"auditVMsWithoutExtensions\",\n *     },\n *   ],\n * });\n *\n * @stability stable\n */\nexport class PolicySetDefinition extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      POLICY_SET_DEFINITION_TYPE,\n      ALL_POLICY_SET_DEFINITION_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Policy Set Definition instance\n   */\n  public readonly props: PolicySetDefinitionProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly policySetDefinitionIdOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Policy Set Definition using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\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 Policy Set Definition\n   */\n  constructor(scope: Construct, id: string, props: PolicySetDefinitionProps) {\n    // Validate required properties\n    if (!props.displayName || props.displayName.trim() === \"\") {\n      throw new Error(\"displayName is required for policy set definitions\");\n    }\n\n    if (!props.policyDefinitions || props.policyDefinitions.length === 0) {\n      throw new Error(\n        \"At least one policy definition reference is required in policyDefinitions\",\n      );\n    }\n\n    // Validate policy definition references\n    props.policyDefinitions.forEach((policyDef, index) => {\n      if (!policyDef.policyDefinitionId) {\n        throw new Error(\n          `policyDefinitionId is required for policy definition at index ${index}`,\n        );\n      }\n    });\n\n    // Validate policy definition groups if provided\n    if (props.policyDefinitionGroups) {\n      const groupNames = new Set<string>();\n      props.policyDefinitionGroups.forEach((group, index) => {\n        if (!group.name) {\n          throw new Error(\n            `name is required for policy definition group at index ${index}`,\n          );\n        }\n        if (groupNames.has(group.name)) {\n          throw new Error(\n            `Duplicate group name '${group.name}' in policyDefinitionGroups`,\n          );\n        }\n        groupNames.add(group.name);\n      });\n\n      // Validate that policy definitions reference valid groups\n      const validGroupNames = Array.from(groupNames);\n      props.policyDefinitions.forEach((policyDef, index) => {\n        if (policyDef.groupNames) {\n          policyDef.groupNames.forEach((groupName) => {\n            if (!validGroupNames.includes(groupName)) {\n              throw new Error(\n                `Policy definition at index ${index} references unknown group '${groupName}'. Valid groups are: ${validGroupNames.join(\", \")}`,\n              );\n            }\n          });\n        }\n      });\n    }\n\n    super(scope, id, props);\n\n    this.props = props;\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 Policy Set Definition\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Policy Set Definition\",\n    });\n\n    this.policySetDefinitionIdOutput = new cdktf.TerraformOutput(\n      this,\n      \"policy_set_definition_id\",\n      {\n        value: this.id,\n        description:\n          \"The Policy Set Definition ID (same as id, for use in policy assignments)\",\n      },\n    );\n\n    // Override logical IDs to match original naming convention\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.policySetDefinitionIdOutput.overrideLogicalId(\n      \"policy_set_definition_id\",\n    );\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\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 \"2023-04-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Policy Set Definitions\n   */\n  protected resourceType(): string {\n    return POLICY_SET_DEFINITION_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Overrides the name resolution to generate deterministic GUIDs for policy set definitions\n   *\n   * Policy set definitions can use custom names or auto-generated GUIDs.\n   * This implementation generates a deterministic UUID based on the policy set definition's\n   * key properties if no name is provided.\n   */\n  protected resolveName(props: AzapiResourceProps): string {\n    const typedProps = props as PolicySetDefinitionProps;\n\n    // If name is provided, use it\n    if (typedProps.name) {\n      return typedProps.name;\n    }\n\n    // Generate a deterministic GUID based on display name and scope\n    const hashInput = [typedProps.displayName, typedProps.scope].join(\"|\");\n\n    const hash = createHash(\"sha256\").update(hashInput).digest(\"hex\");\n\n    // Convert hash to UUID format (8-4-4-4-12)\n    return [\n      hash.substring(0, 8),\n      hash.substring(8, 12),\n      hash.substring(12, 16),\n      hash.substring(16, 20),\n      hash.substring(20, 32),\n    ].join(\"-\");\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   * Note: Policy set definitions do not have a location property as they are\n   * scope-specific resources deployed at subscription or management group level.\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as PolicySetDefinitionProps;\n\n    const body: any = {\n      properties: {\n        displayName: typedProps.displayName,\n        policyType: typedProps.policyType || \"Custom\",\n        policyDefinitions: typedProps.policyDefinitions,\n      },\n    };\n\n    // Add optional properties only if specified\n    if (typedProps.description) {\n      body.properties.description = typedProps.description;\n    }\n\n    if (typedProps.metadata) {\n      body.properties.metadata = typedProps.metadata;\n    }\n\n    if (typedProps.parameters) {\n      body.properties.parameters = typedProps.parameters;\n    }\n\n    if (\n      typedProps.policyDefinitionGroups &&\n      typedProps.policyDefinitionGroups.length > 0\n    ) {\n      body.properties.policyDefinitionGroups =\n        typedProps.policyDefinitionGroups;\n    }\n\n    return body;\n  }\n\n  /**\n   * Resolves the parent resource ID for Policy Set Definition\n   * Policy Set Definitions are created at subscription or management group scope\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID (the scope)\n   */\n  protected resolveParentId(props: any): string {\n    return (props as PolicySetDefinitionProps).scope;\n  }\n\n  // =============================================================================\n  // PUBLIC METHODS FOR POLICY SET DEFINITION OPERATIONS\n  // =============================================================================\n\n  /**\n   * Get the full resource identifier for use in policy assignments\n   * Alias for the id property\n   */\n  public get policySetDefinitionId(): string {\n    return this.id;\n  }\n\n  /**\n   * Get the display name of the policy set definition\n   */\n  public get displayName(): string {\n    return this.props.displayName;\n  }\n\n  /**\n   * Get the policy type\n   */\n  public get policyType(): string {\n    return this.props.policyType || \"Custom\";\n  }\n\n  /**\n   * Get the number of policy definitions in this set\n   */\n  public get policyDefinitionCount(): number {\n    return this.props.policyDefinitions.length;\n  }\n}\n"]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Policy Set Definition (Initiative)
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the PolicySetDefinition construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* Run with: npm run integration:nostream
|
|
8
|
+
*/
|
|
9
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Policy Set Definition (Initiative)
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the PolicySetDefinition construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* Run with: npm run integration:nostream
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
const cdktf_1 = require("cdktf");
|
|
12
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
13
|
+
const data_azapi_client_config_1 = require("../../core-azure/lib/azapi/providers-azapi/data-azapi-client-config");
|
|
14
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
15
|
+
const testing_1 = require("../../testing");
|
|
16
|
+
const policy_set_definition_1 = require("../lib/policy-set-definition");
|
|
17
|
+
/**
|
|
18
|
+
* Example stack demonstrating Policy Set Definition usage
|
|
19
|
+
*/
|
|
20
|
+
class PolicySetDefinitionExampleStack extends cdktf_1.TerraformStack {
|
|
21
|
+
constructor(scope, id) {
|
|
22
|
+
super(scope, id);
|
|
23
|
+
// Configure AZAPI provider
|
|
24
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
25
|
+
// Create a client config to get the current subscription ID
|
|
26
|
+
const clientConfig = new data_azapi_client_config_1.DataAzapiClientConfig(this, "client_config", {});
|
|
27
|
+
// Use the current subscription for policy definitions
|
|
28
|
+
const subscriptionId = `/subscriptions/\${${clientConfig.fqn}.subscription_id}`;
|
|
29
|
+
// Basic Policy Set Definition with built-in policies
|
|
30
|
+
new policy_set_definition_1.PolicySetDefinition(this, "basic-initiative", {
|
|
31
|
+
displayName: "Basic Security Initiative",
|
|
32
|
+
description: "A simple initiative to demonstrate Policy Set Definition construct",
|
|
33
|
+
scope: subscriptionId,
|
|
34
|
+
policyDefinitions: [
|
|
35
|
+
{
|
|
36
|
+
// Audit VMs that do not use managed disks
|
|
37
|
+
policyDefinitionId: "/providers/Microsoft.Authorization/policyDefinitions/06a78e20-9358-41c9-923c-fb736d382a4d",
|
|
38
|
+
policyDefinitionReferenceId: "auditManagedDisks",
|
|
39
|
+
},
|
|
40
|
+
],
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
describe("Policy Set Definition Integration Test", () => {
|
|
45
|
+
it("should deploy, validate idempotency, and cleanup Policy Set Definition resources", () => {
|
|
46
|
+
const app = cdktf_1.Testing.app();
|
|
47
|
+
const stack = new PolicySetDefinitionExampleStack(app, "test-policy-set-definition");
|
|
48
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
49
|
+
// This will:
|
|
50
|
+
// 1. Run terraform apply to deploy resources
|
|
51
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
52
|
+
// 3. Run terraform destroy to cleanup resources
|
|
53
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized);
|
|
54
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
55
|
+
});
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9saWN5LXNldC1kZWZpbml0aW9uLmludGVnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6dXJlLXBvbGljeXNldGRlZmluaXRpb24vdGVzdC9wb2xpY3ktc2V0LWRlZmluaXRpb24uaW50ZWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7O0dBT0c7O0FBRUgsaUNBQWdEO0FBRWhELDJDQUF5QztBQUN6QyxrSEFBNEc7QUFDNUcsa0ZBQW9GO0FBQ3BGLDJDQUE4RDtBQUM5RCx3RUFBbUU7QUFFbkU7O0dBRUc7QUFDSCxNQUFNLCtCQUFnQyxTQUFRLHNCQUFjO0lBQzFELFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsMkJBQTJCO1FBQzNCLElBQUksd0JBQWEsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRXJDLDREQUE0RDtRQUM1RCxNQUFNLFlBQVksR0FBRyxJQUFJLGdEQUFxQixDQUFDLElBQUksRUFBRSxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFMUUsc0RBQXNEO1FBQ3RELE1BQU0sY0FBYyxHQUFHLHFCQUFxQixZQUFZLENBQUMsR0FBRyxtQkFBbUIsQ0FBQztRQUVoRixxREFBcUQ7UUFDckQsSUFBSSwyQ0FBbUIsQ0FBQyxJQUFJLEVBQUUsa0JBQWtCLEVBQUU7WUFDaEQsV0FBVyxFQUFFLDJCQUEyQjtZQUN4QyxXQUFXLEVBQ1Qsb0VBQW9FO1lBQ3RFLEtBQUssRUFBRSxjQUFjO1lBQ3JCLGlCQUFpQixFQUFFO2dCQUNqQjtvQkFDRSwwQ0FBMEM7b0JBQzFDLGtCQUFrQixFQUNoQiwyRkFBMkY7b0JBQzdGLDJCQUEyQixFQUFFLG1CQUFtQjtpQkFDakQ7YUFDRjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQUVELFFBQVEsQ0FBQyx3Q0FBd0MsRUFBRSxHQUFHLEVBQUU7SUFDdEQsRUFBRSxDQUFDLGtGQUFrRixFQUFFLEdBQUcsRUFBRTtRQUMxRixNQUFNLEdBQUcsR0FBRyxlQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSwrQkFBK0IsQ0FDL0MsR0FBRyxFQUNILDRCQUE0QixDQUM3QixDQUFDO1FBQ0YsTUFBTSxXQUFXLEdBQUcsZUFBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUU3QyxhQUFhO1FBQ2IsNkNBQTZDO1FBQzdDLG1FQUFtRTtRQUNuRSxnREFBZ0Q7UUFDaEQsSUFBQSx1Q0FBNkIsRUFBQyxXQUFXLENBQUMsQ0FBQztJQUM3QyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQywrQ0FBK0M7QUFDN0QsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVncmF0aW9uIHRlc3QgZm9yIEF6dXJlIFBvbGljeSBTZXQgRGVmaW5pdGlvbiAoSW5pdGlhdGl2ZSlcbiAqXG4gKiBUaGlzIHRlc3QgZGVtb25zdHJhdGVzIGJhc2ljIHVzYWdlIG9mIHRoZSBQb2xpY3lTZXREZWZpbml0aW9uIGNvbnN0cnVjdFxuICogYW5kIHZhbGlkYXRlcyBkZXBsb3ltZW50LCBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAuXG4gKlxuICogUnVuIHdpdGg6IG5wbSBydW4gaW50ZWdyYXRpb246bm9zdHJlYW1cbiAqL1xuXG5pbXBvcnQgeyBUZXN0aW5nLCBUZXJyYWZvcm1TdGFjayB9IGZyb20gXCJjZGt0ZlwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCBcImNka3RmL2xpYi90ZXN0aW5nL2FkYXB0ZXJzL2plc3RcIjtcbmltcG9ydCB7IERhdGFBemFwaUNsaWVudENvbmZpZyB9IGZyb20gXCIuLi8uLi9jb3JlLWF6dXJlL2xpYi9hemFwaS9wcm92aWRlcnMtYXphcGkvZGF0YS1hemFwaS1jbGllbnQtY29uZmlnXCI7XG5pbXBvcnQgeyBBemFwaVByb3ZpZGVyIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliL2F6YXBpL3Byb3ZpZGVycy1hemFwaS9wcm92aWRlclwiO1xuaW1wb3J0IHsgVGVycmFmb3JtQXBwbHlDaGVja0FuZERlc3Ryb3kgfSBmcm9tIFwiLi4vLi4vdGVzdGluZ1wiO1xuaW1wb3J0IHsgUG9saWN5U2V0RGVmaW5pdGlvbiB9IGZyb20gXCIuLi9saWIvcG9saWN5LXNldC1kZWZpbml0aW9uXCI7XG5cbi8qKlxuICogRXhhbXBsZSBzdGFjayBkZW1vbnN0cmF0aW5nIFBvbGljeSBTZXQgRGVmaW5pdGlvbiB1c2FnZVxuICovXG5jbGFzcyBQb2xpY3lTZXREZWZpbml0aW9uRXhhbXBsZVN0YWNrIGV4dGVuZHMgVGVycmFmb3JtU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIC8vIENvbmZpZ3VyZSBBWkFQSSBwcm92aWRlclxuICAgIG5ldyBBemFwaVByb3ZpZGVyKHRoaXMsIFwiYXphcGlcIiwge30pO1xuXG4gICAgLy8gQ3JlYXRlIGEgY2xpZW50IGNvbmZpZyB0byBnZXQgdGhlIGN1cnJlbnQgc3Vic2NyaXB0aW9uIElEXG4gICAgY29uc3QgY2xpZW50Q29uZmlnID0gbmV3IERhdGFBemFwaUNsaWVudENvbmZpZyh0aGlzLCBcImNsaWVudF9jb25maWdcIiwge30pO1xuXG4gICAgLy8gVXNlIHRoZSBjdXJyZW50IHN1YnNjcmlwdGlvbiBmb3IgcG9saWN5IGRlZmluaXRpb25zXG4gICAgY29uc3Qgc3Vic2NyaXB0aW9uSWQgPSBgL3N1YnNjcmlwdGlvbnMvXFwkeyR7Y2xpZW50Q29uZmlnLmZxbn0uc3Vic2NyaXB0aW9uX2lkfWA7XG5cbiAgICAvLyBCYXNpYyBQb2xpY3kgU2V0IERlZmluaXRpb24gd2l0aCBidWlsdC1pbiBwb2xpY2llc1xuICAgIG5ldyBQb2xpY3lTZXREZWZpbml0aW9uKHRoaXMsIFwiYmFzaWMtaW5pdGlhdGl2ZVwiLCB7XG4gICAgICBkaXNwbGF5TmFtZTogXCJCYXNpYyBTZWN1cml0eSBJbml0aWF0aXZlXCIsXG4gICAgICBkZXNjcmlwdGlvbjpcbiAgICAgICAgXCJBIHNpbXBsZSBpbml0aWF0aXZlIHRvIGRlbW9uc3RyYXRlIFBvbGljeSBTZXQgRGVmaW5pdGlvbiBjb25zdHJ1Y3RcIixcbiAgICAgIHNjb3BlOiBzdWJzY3JpcHRpb25JZCxcbiAgICAgIHBvbGljeURlZmluaXRpb25zOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAvLyBBdWRpdCBWTXMgdGhhdCBkbyBub3QgdXNlIG1hbmFnZWQgZGlza3NcbiAgICAgICAgICBwb2xpY3lEZWZpbml0aW9uSWQ6XG4gICAgICAgICAgICBcIi9wcm92aWRlcnMvTWljcm9zb2Z0LkF1dGhvcml6YXRpb24vcG9saWN5RGVmaW5pdGlvbnMvMDZhNzhlMjAtOTM1OC00MWM5LTkyM2MtZmI3MzZkMzgyYTRkXCIsXG4gICAgICAgICAgcG9saWN5RGVmaW5pdGlvblJlZmVyZW5jZUlkOiBcImF1ZGl0TWFuYWdlZERpc2tzXCIsXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pO1xuICB9XG59XG5cbmRlc2NyaWJlKFwiUG9saWN5IFNldCBEZWZpbml0aW9uIEludGVncmF0aW9uIFRlc3RcIiwgKCkgPT4ge1xuICBpdChcInNob3VsZCBkZXBsb3ksIHZhbGlkYXRlIGlkZW1wb3RlbmN5LCBhbmQgY2xlYW51cCBQb2xpY3kgU2V0IERlZmluaXRpb24gcmVzb3VyY2VzXCIsICgpID0+IHtcbiAgICBjb25zdCBhcHAgPSBUZXN0aW5nLmFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IFBvbGljeVNldERlZmluaXRpb25FeGFtcGxlU3RhY2soXG4gICAgICBhcHAsXG4gICAgICBcInRlc3QtcG9saWN5LXNldC1kZWZpbml0aW9uXCIsXG4gICAgKTtcbiAgICBjb25zdCBzeW50aGVzaXplZCA9IFRlc3RpbmcuZnVsbFN5bnRoKHN0YWNrKTtcblxuICAgIC8vIFRoaXMgd2lsbDpcbiAgICAvLyAxLiBSdW4gdGVycmFmb3JtIGFwcGx5IHRvIGRlcGxveSByZXNvdXJjZXNcbiAgICAvLyAyLiBSdW4gdGVycmFmb3JtIHBsYW4gdG8gY2hlY2sgaWRlbXBvdGVuY3kgKG5vIGNoYW5nZXMgZXhwZWN0ZWQpXG4gICAgLy8gMy4gUnVuIHRlcnJhZm9ybSBkZXN0cm95IHRvIGNsZWFudXAgcmVzb3VyY2VzXG4gICAgVGVycmFmb3JtQXBwbHlDaGVja0FuZERlc3Ryb3koc3ludGhlc2l6ZWQpO1xuICB9LCA2MDAwMDApOyAvLyAxMCBtaW51dGUgdGltZW91dCBmb3IgZGVwbG95bWVudCBhbmQgY2xlYW51cFxufSk7XG4iXX0=
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comprehensive tests for the PolicySetDefinition implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the PolicySetDefinition class using the AzapiResource framework.
|
|
5
|
+
* Tests cover automatic version resolution, explicit version pinning, schema validation,
|
|
6
|
+
* property configurations, and resource creation.
|
|
7
|
+
*/
|
|
8
|
+
export {};
|