@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
|
+
/**
|
|
3
|
+
* API schemas for Azure Policy Set Definition (Initiative) across all supported versions
|
|
4
|
+
*
|
|
5
|
+
* This file defines the complete API schemas for Microsoft.Authorization/policySetDefinitions
|
|
6
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
7
|
+
* framework for validation, transformation, and version management.
|
|
8
|
+
*
|
|
9
|
+
* Policy Set Definitions (also known as Initiatives) are collections of policy definitions
|
|
10
|
+
* that allow you to group policies and assign them together as a single unit.
|
|
11
|
+
*/
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.POLICY_SET_DEFINITION_TYPE = exports.ALL_POLICY_SET_DEFINITION_VERSIONS = exports.POLICY_SET_DEFINITION_VERSION_2021_06_01 = exports.POLICY_SET_DEFINITION_VERSION_2023_04_01 = exports.POLICY_SET_DEFINITION_SCHEMA_2021_06_01 = exports.POLICY_SET_DEFINITION_SCHEMA_2023_04_01 = void 0;
|
|
14
|
+
const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
|
|
15
|
+
// =============================================================================
|
|
16
|
+
// COMMON PROPERTY DEFINITIONS
|
|
17
|
+
// =============================================================================
|
|
18
|
+
/**
|
|
19
|
+
* Common property definitions shared across all Policy Set Definition versions
|
|
20
|
+
*/
|
|
21
|
+
const COMMON_PROPERTIES = {
|
|
22
|
+
name: {
|
|
23
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
24
|
+
required: false,
|
|
25
|
+
description: "The name of the policy set definition resource. Automatically generated as a GUID if not provided.",
|
|
26
|
+
validation: [],
|
|
27
|
+
},
|
|
28
|
+
displayName: {
|
|
29
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
30
|
+
required: true,
|
|
31
|
+
description: "The display name of the policy set definition shown in the Azure portal",
|
|
32
|
+
validation: [
|
|
33
|
+
{
|
|
34
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
35
|
+
message: "Display name is required for policy set definitions",
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
|
|
39
|
+
value: { minLength: 1, maxLength: 128 },
|
|
40
|
+
message: "Display name must be between 1 and 128 characters",
|
|
41
|
+
},
|
|
42
|
+
],
|
|
43
|
+
},
|
|
44
|
+
description: {
|
|
45
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
46
|
+
required: false,
|
|
47
|
+
description: "The description of the policy set definition explaining its purpose and scope",
|
|
48
|
+
validation: [
|
|
49
|
+
{
|
|
50
|
+
ruleType: version_interfaces_1.ValidationRuleType.VALUE_RANGE,
|
|
51
|
+
value: { minLength: 0, maxLength: 512 },
|
|
52
|
+
message: "Description must not exceed 512 characters",
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
},
|
|
56
|
+
policyType: {
|
|
57
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
58
|
+
required: false,
|
|
59
|
+
defaultValue: "Custom",
|
|
60
|
+
description: "The type of policy set definition. Valid values: BuiltIn, Custom, Static",
|
|
61
|
+
validation: [
|
|
62
|
+
{
|
|
63
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
64
|
+
value: "^(BuiltIn|Custom|Static)$",
|
|
65
|
+
message: "Policy type must be BuiltIn, Custom, or Static",
|
|
66
|
+
},
|
|
67
|
+
],
|
|
68
|
+
},
|
|
69
|
+
metadata: {
|
|
70
|
+
dataType: version_interfaces_1.PropertyType.OBJECT,
|
|
71
|
+
required: false,
|
|
72
|
+
description: "Metadata object for categorization including category, version, preview, and deprecated flags",
|
|
73
|
+
},
|
|
74
|
+
parameters: {
|
|
75
|
+
dataType: version_interfaces_1.PropertyType.OBJECT,
|
|
76
|
+
required: false,
|
|
77
|
+
description: "Parameter definitions that can be used by policy definitions in the set",
|
|
78
|
+
},
|
|
79
|
+
policyDefinitions: {
|
|
80
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
81
|
+
required: true,
|
|
82
|
+
description: "Array of policy definition references included in this policy set",
|
|
83
|
+
validation: [
|
|
84
|
+
{
|
|
85
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
86
|
+
message: "Policy definitions array is required for policy set definitions",
|
|
87
|
+
},
|
|
88
|
+
{
|
|
89
|
+
ruleType: version_interfaces_1.ValidationRuleType.TYPE_CHECK,
|
|
90
|
+
value: version_interfaces_1.PropertyType.ARRAY,
|
|
91
|
+
message: "Policy definitions must be an array of policy definition references",
|
|
92
|
+
},
|
|
93
|
+
],
|
|
94
|
+
},
|
|
95
|
+
policyDefinitionGroups: {
|
|
96
|
+
dataType: version_interfaces_1.PropertyType.ARRAY,
|
|
97
|
+
required: false,
|
|
98
|
+
description: "Groups for organizing policy definitions within the policy set",
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
// =============================================================================
|
|
102
|
+
// VERSION-SPECIFIC SCHEMAS
|
|
103
|
+
// =============================================================================
|
|
104
|
+
/**
|
|
105
|
+
* API Schema for Policy Set Definition version 2023-04-01
|
|
106
|
+
*
|
|
107
|
+
* This is the latest stable version for Policy Set Definitions.
|
|
108
|
+
* It includes support for:
|
|
109
|
+
* - Policy definition references with parameters
|
|
110
|
+
* - Policy definition groups for organization
|
|
111
|
+
* - Metadata for categorization
|
|
112
|
+
* - Parameter definitions for the initiative
|
|
113
|
+
*/
|
|
114
|
+
exports.POLICY_SET_DEFINITION_SCHEMA_2023_04_01 = {
|
|
115
|
+
resourceType: "Microsoft.Authorization/policySetDefinitions",
|
|
116
|
+
version: "2023-04-01",
|
|
117
|
+
properties: {
|
|
118
|
+
...COMMON_PROPERTIES,
|
|
119
|
+
},
|
|
120
|
+
required: ["displayName", "policyDefinitions"],
|
|
121
|
+
optional: [
|
|
122
|
+
"name",
|
|
123
|
+
"description",
|
|
124
|
+
"policyType",
|
|
125
|
+
"metadata",
|
|
126
|
+
"parameters",
|
|
127
|
+
"policyDefinitionGroups",
|
|
128
|
+
],
|
|
129
|
+
deprecated: [],
|
|
130
|
+
transformationRules: {},
|
|
131
|
+
validationRules: [
|
|
132
|
+
{
|
|
133
|
+
property: "displayName",
|
|
134
|
+
rules: [
|
|
135
|
+
{
|
|
136
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
137
|
+
message: "Display name is required for policy set definitions",
|
|
138
|
+
},
|
|
139
|
+
],
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
property: "policyDefinitions",
|
|
143
|
+
rules: [
|
|
144
|
+
{
|
|
145
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
146
|
+
message: "Policy definitions array is required for policy set definitions",
|
|
147
|
+
},
|
|
148
|
+
],
|
|
149
|
+
},
|
|
150
|
+
],
|
|
151
|
+
};
|
|
152
|
+
/**
|
|
153
|
+
* API Schema for Policy Set Definition version 2021-06-01
|
|
154
|
+
*
|
|
155
|
+
* This is a stable version for backward compatibility.
|
|
156
|
+
* It includes support for:
|
|
157
|
+
* - Policy definition references with parameters
|
|
158
|
+
* - Policy definition groups for organization
|
|
159
|
+
* - Metadata for categorization
|
|
160
|
+
* - Parameter definitions for the initiative
|
|
161
|
+
*/
|
|
162
|
+
exports.POLICY_SET_DEFINITION_SCHEMA_2021_06_01 = {
|
|
163
|
+
resourceType: "Microsoft.Authorization/policySetDefinitions",
|
|
164
|
+
version: "2021-06-01",
|
|
165
|
+
properties: {
|
|
166
|
+
...COMMON_PROPERTIES,
|
|
167
|
+
},
|
|
168
|
+
required: ["displayName", "policyDefinitions"],
|
|
169
|
+
optional: [
|
|
170
|
+
"name",
|
|
171
|
+
"description",
|
|
172
|
+
"policyType",
|
|
173
|
+
"metadata",
|
|
174
|
+
"parameters",
|
|
175
|
+
"policyDefinitionGroups",
|
|
176
|
+
],
|
|
177
|
+
deprecated: [],
|
|
178
|
+
transformationRules: {},
|
|
179
|
+
validationRules: [
|
|
180
|
+
{
|
|
181
|
+
property: "displayName",
|
|
182
|
+
rules: [
|
|
183
|
+
{
|
|
184
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
185
|
+
message: "Display name is required for policy set definitions",
|
|
186
|
+
},
|
|
187
|
+
],
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
property: "policyDefinitions",
|
|
191
|
+
rules: [
|
|
192
|
+
{
|
|
193
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
194
|
+
message: "Policy definitions array is required for policy set definitions",
|
|
195
|
+
},
|
|
196
|
+
],
|
|
197
|
+
},
|
|
198
|
+
],
|
|
199
|
+
};
|
|
200
|
+
// =============================================================================
|
|
201
|
+
// VERSION CONFIGURATIONS
|
|
202
|
+
// =============================================================================
|
|
203
|
+
/**
|
|
204
|
+
* Version configuration for Policy Set Definition 2023-04-01
|
|
205
|
+
*/
|
|
206
|
+
exports.POLICY_SET_DEFINITION_VERSION_2023_04_01 = {
|
|
207
|
+
version: "2023-04-01",
|
|
208
|
+
schema: exports.POLICY_SET_DEFINITION_SCHEMA_2023_04_01,
|
|
209
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
210
|
+
releaseDate: "2023-04-01",
|
|
211
|
+
deprecationDate: undefined,
|
|
212
|
+
sunsetDate: undefined,
|
|
213
|
+
breakingChanges: [],
|
|
214
|
+
migrationGuide: "/docs/policy-set-definition/migration-2023-04-01",
|
|
215
|
+
changeLog: [
|
|
216
|
+
{
|
|
217
|
+
changeType: "updated",
|
|
218
|
+
description: "Latest stable API version for Policy Set Definitions with enhanced validation",
|
|
219
|
+
breaking: false,
|
|
220
|
+
},
|
|
221
|
+
],
|
|
222
|
+
};
|
|
223
|
+
/**
|
|
224
|
+
* Version configuration for Policy Set Definition 2021-06-01
|
|
225
|
+
*/
|
|
226
|
+
exports.POLICY_SET_DEFINITION_VERSION_2021_06_01 = {
|
|
227
|
+
version: "2021-06-01",
|
|
228
|
+
schema: exports.POLICY_SET_DEFINITION_SCHEMA_2021_06_01,
|
|
229
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
230
|
+
releaseDate: "2021-06-01",
|
|
231
|
+
deprecationDate: undefined,
|
|
232
|
+
sunsetDate: undefined,
|
|
233
|
+
breakingChanges: [],
|
|
234
|
+
migrationGuide: "/docs/policy-set-definition/migration-2021-06-01",
|
|
235
|
+
changeLog: [
|
|
236
|
+
{
|
|
237
|
+
changeType: "updated",
|
|
238
|
+
description: "Stable API version for backward compatibility",
|
|
239
|
+
breaking: false,
|
|
240
|
+
},
|
|
241
|
+
],
|
|
242
|
+
};
|
|
243
|
+
/**
|
|
244
|
+
* All supported Policy Set Definition versions for registration
|
|
245
|
+
* Ordered with latest stable version first
|
|
246
|
+
*/
|
|
247
|
+
exports.ALL_POLICY_SET_DEFINITION_VERSIONS = [
|
|
248
|
+
exports.POLICY_SET_DEFINITION_VERSION_2023_04_01,
|
|
249
|
+
exports.POLICY_SET_DEFINITION_VERSION_2021_06_01,
|
|
250
|
+
];
|
|
251
|
+
/**
|
|
252
|
+
* Resource type constant
|
|
253
|
+
*/
|
|
254
|
+
exports.POLICY_SET_DEFINITION_TYPE = "Microsoft.Authorization/policySetDefinitions";
|
|
255
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"policy-set-definition-schemas.js","sourceRoot":"","sources":["../../../src/azure-policysetdefinition/lib/policy-set-definition-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure Policy Set Definition (Initiative) across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Authorization/policySetDefinitions\n * across all supported API versions. The schemas are used by the AzapiResource\n * framework for validation, transformation, and version management.\n *\n * Policy Set Definitions (also known as Initiatives) are collections of policy definitions\n * that allow you to group policies and assign them together as a single unit.\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all Policy Set Definition versions\n */\nconst COMMON_PROPERTIES: { [key: string]: PropertyDefinition } = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The name of the policy set definition resource. Automatically generated as a GUID if not provided.\",\n    validation: [],\n  },\n  displayName: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"The display name of the policy set definition shown in the Azure portal\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Display name is required for policy set definitions\",\n      },\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 1, maxLength: 128 },\n        message: \"Display name must be between 1 and 128 characters\",\n      },\n    ],\n  },\n  description: {\n    dataType: PropertyType.STRING,\n    required: false,\n    description:\n      \"The description of the policy set definition explaining its purpose and scope\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.VALUE_RANGE,\n        value: { minLength: 0, maxLength: 512 },\n        message: \"Description must not exceed 512 characters\",\n      },\n    ],\n  },\n  policyType: {\n    dataType: PropertyType.STRING,\n    required: false,\n    defaultValue: \"Custom\",\n    description:\n      \"The type of policy set definition. Valid values: BuiltIn, Custom, Static\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^(BuiltIn|Custom|Static)$\",\n        message: \"Policy type must be BuiltIn, Custom, or Static\",\n      },\n    ],\n  },\n  metadata: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    description:\n      \"Metadata object for categorization including category, version, preview, and deprecated flags\",\n  },\n  parameters: {\n    dataType: PropertyType.OBJECT,\n    required: false,\n    description:\n      \"Parameter definitions that can be used by policy definitions in the set\",\n  },\n  policyDefinitions: {\n    dataType: PropertyType.ARRAY,\n    required: true,\n    description:\n      \"Array of policy definition references included in this policy set\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message:\n          \"Policy definitions array is required for policy set definitions\",\n      },\n      {\n        ruleType: ValidationRuleType.TYPE_CHECK,\n        value: PropertyType.ARRAY,\n        message:\n          \"Policy definitions must be an array of policy definition references\",\n      },\n    ],\n  },\n  policyDefinitionGroups: {\n    dataType: PropertyType.ARRAY,\n    required: false,\n    description:\n      \"Groups for organizing policy definitions within the policy set\",\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Policy Set Definition version 2023-04-01\n *\n * This is the latest stable version for Policy Set Definitions.\n * It includes support for:\n * - Policy definition references with parameters\n * - Policy definition groups for organization\n * - Metadata for categorization\n * - Parameter definitions for the initiative\n */\nexport const POLICY_SET_DEFINITION_SCHEMA_2023_04_01: ApiSchema = {\n  resourceType: \"Microsoft.Authorization/policySetDefinitions\",\n  version: \"2023-04-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"displayName\", \"policyDefinitions\"],\n  optional: [\n    \"name\",\n    \"description\",\n    \"policyType\",\n    \"metadata\",\n    \"parameters\",\n    \"policyDefinitionGroups\",\n  ],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"displayName\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Display name is required for policy set definitions\",\n        },\n      ],\n    },\n    {\n      property: \"policyDefinitions\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message:\n            \"Policy definitions array is required for policy set definitions\",\n        },\n      ],\n    },\n  ],\n};\n\n/**\n * API Schema for Policy Set Definition version 2021-06-01\n *\n * This is a stable version for backward compatibility.\n * It includes support for:\n * - Policy definition references with parameters\n * - Policy definition groups for organization\n * - Metadata for categorization\n * - Parameter definitions for the initiative\n */\nexport const POLICY_SET_DEFINITION_SCHEMA_2021_06_01: ApiSchema = {\n  resourceType: \"Microsoft.Authorization/policySetDefinitions\",\n  version: \"2021-06-01\",\n  properties: {\n    ...COMMON_PROPERTIES,\n  },\n  required: [\"displayName\", \"policyDefinitions\"],\n  optional: [\n    \"name\",\n    \"description\",\n    \"policyType\",\n    \"metadata\",\n    \"parameters\",\n    \"policyDefinitionGroups\",\n  ],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"displayName\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Display name is required for policy set definitions\",\n        },\n      ],\n    },\n    {\n      property: \"policyDefinitions\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message:\n            \"Policy definitions array is required for policy set definitions\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Policy Set Definition 2023-04-01\n */\nexport const POLICY_SET_DEFINITION_VERSION_2023_04_01: VersionConfig = {\n  version: \"2023-04-01\",\n  schema: POLICY_SET_DEFINITION_SCHEMA_2023_04_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2023-04-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/policy-set-definition/migration-2023-04-01\",\n  changeLog: [\n    {\n      changeType: \"updated\",\n      description:\n        \"Latest stable API version for Policy Set Definitions with enhanced validation\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * Version configuration for Policy Set Definition 2021-06-01\n */\nexport const POLICY_SET_DEFINITION_VERSION_2021_06_01: VersionConfig = {\n  version: \"2021-06-01\",\n  schema: POLICY_SET_DEFINITION_SCHEMA_2021_06_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2021-06-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/policy-set-definition/migration-2021-06-01\",\n  changeLog: [\n    {\n      changeType: \"updated\",\n      description: \"Stable API version for backward compatibility\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Policy Set Definition versions for registration\n * Ordered with latest stable version first\n */\nexport const ALL_POLICY_SET_DEFINITION_VERSIONS: VersionConfig[] = [\n  POLICY_SET_DEFINITION_VERSION_2023_04_01,\n  POLICY_SET_DEFINITION_VERSION_2021_06_01,\n];\n\n/**\n * Resource type constant\n */\nexport const POLICY_SET_DEFINITION_TYPE =\n  \"Microsoft.Authorization/policySetDefinitions\";\n"]}
|