@cdktn/provider-azuread 15.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (158) hide show
  1. package/.jsii +112042 -0
  2. package/LICENSE +355 -0
  3. package/README.md +94 -0
  4. package/lib/access-package/index.d.ts +151 -0
  5. package/lib/access-package/index.js +354 -0
  6. package/lib/access-package-assignment-policy/index.d.ts +1098 -0
  7. package/lib/access-package-assignment-policy/index.js +2711 -0
  8. package/lib/access-package-catalog/index.d.ts +152 -0
  9. package/lib/access-package-catalog/index.js +357 -0
  10. package/lib/access-package-catalog-role-assignment/index.d.ts +140 -0
  11. package/lib/access-package-catalog-role-assignment/index.js +333 -0
  12. package/lib/access-package-resource-catalog-association/index.d.ts +131 -0
  13. package/lib/access-package-resource-catalog-association/index.js +307 -0
  14. package/lib/access-package-resource-package-association/index.d.ts +132 -0
  15. package/lib/access-package-resource-package-association/index.js +310 -0
  16. package/lib/administrative-unit/index.d.ts +165 -0
  17. package/lib/administrative-unit/index.js +385 -0
  18. package/lib/administrative-unit-member/index.d.ts +123 -0
  19. package/lib/administrative-unit-member/index.js +295 -0
  20. package/lib/administrative-unit-role-member/index.d.ts +131 -0
  21. package/lib/administrative-unit-role-member/index.js +307 -0
  22. package/lib/app-role-assignment/index.d.ts +134 -0
  23. package/lib/app-role-assignment/index.js +319 -0
  24. package/lib/application/index.d.ts +1352 -0
  25. package/lib/application/index.js +3262 -0
  26. package/lib/application-api-access/index.d.ts +152 -0
  27. package/lib/application-api-access/index.js +357 -0
  28. package/lib/application-app-role/index.d.ts +171 -0
  29. package/lib/application-app-role/index.js +390 -0
  30. package/lib/application-certificate/index.d.ts +196 -0
  31. package/lib/application-certificate/index.js +441 -0
  32. package/lib/application-fallback-public-client/index.d.ts +122 -0
  33. package/lib/application-fallback-public-client/index.js +292 -0
  34. package/lib/application-federated-identity-credential/index.d.ts +172 -0
  35. package/lib/application-federated-identity-credential/index.js +394 -0
  36. package/lib/application-flexible-federated-identity-credential/index.d.ts +172 -0
  37. package/lib/application-flexible-federated-identity-credential/index.js +394 -0
  38. package/lib/application-from-template/index.d.ts +134 -0
  39. package/lib/application-from-template/index.js +334 -0
  40. package/lib/application-identifier-uri/index.d.ts +121 -0
  41. package/lib/application-identifier-uri/index.js +289 -0
  42. package/lib/application-known-clients/index.d.ts +130 -0
  43. package/lib/application-known-clients/index.js +315 -0
  44. package/lib/application-optional-claims/index.d.ts +381 -0
  45. package/lib/application-optional-claims/index.js +918 -0
  46. package/lib/application-owner/index.d.ts +121 -0
  47. package/lib/application-owner/index.js +289 -0
  48. package/lib/application-password/index.d.ts +185 -0
  49. package/lib/application-password/index.js +410 -0
  50. package/lib/application-permission-scope/index.d.ts +193 -0
  51. package/lib/application-permission-scope/index.js +432 -0
  52. package/lib/application-pre-authorized/index.d.ts +140 -0
  53. package/lib/application-pre-authorized/index.js +333 -0
  54. package/lib/application-redirect-uris/index.d.ts +140 -0
  55. package/lib/application-redirect-uris/index.js +333 -0
  56. package/lib/application-registration/index.d.ts +278 -0
  57. package/lib/application-registration/index.js +610 -0
  58. package/lib/authentication-strength-policy/index.d.ts +141 -0
  59. package/lib/authentication-strength-policy/index.js +336 -0
  60. package/lib/claims-mapping-policy/index.d.ts +130 -0
  61. package/lib/claims-mapping-policy/index.js +315 -0
  62. package/lib/conditional-access-policy/index.d.ts +959 -0
  63. package/lib/conditional-access-policy/index.js +2705 -0
  64. package/lib/custom-directory-role/index.d.ts +216 -0
  65. package/lib/custom-directory-role/index.js +505 -0
  66. package/lib/data-azuread-access-package/index.d.ts +118 -0
  67. package/lib/data-azuread-access-package/index.js +272 -0
  68. package/lib/data-azuread-access-package-catalog/index.d.ts +108 -0
  69. package/lib/data-azuread-access-package-catalog/index.js +258 -0
  70. package/lib/data-azuread-access-package-catalog-role/index.d.ts +107 -0
  71. package/lib/data-azuread-access-package-catalog-role/index.js +254 -0
  72. package/lib/data-azuread-administrative-unit/index.d.ts +135 -0
  73. package/lib/data-azuread-administrative-unit/index.js +336 -0
  74. package/lib/data-azuread-application/index.d.ts +654 -0
  75. package/lib/data-azuread-application/index.js +1606 -0
  76. package/lib/data-azuread-application-published-app-ids/index.d.ts +85 -0
  77. package/lib/data-azuread-application-published-app-ids/index.js +206 -0
  78. package/lib/data-azuread-application-template/index.d.ts +111 -0
  79. package/lib/data-azuread-application-template/index.js +270 -0
  80. package/lib/data-azuread-client-config/index.d.ts +86 -0
  81. package/lib/data-azuread-client-config/index.js +216 -0
  82. package/lib/data-azuread-directory-object/index.d.ts +94 -0
  83. package/lib/data-azuread-directory-object/index.js +223 -0
  84. package/lib/data-azuread-directory-role-templates/index.d.ts +120 -0
  85. package/lib/data-azuread-directory-role-templates/index.js +293 -0
  86. package/lib/data-azuread-directory-roles/index.d.ts +122 -0
  87. package/lib/data-azuread-directory-roles/index.js +301 -0
  88. package/lib/data-azuread-domains/index.d.ts +190 -0
  89. package/lib/data-azuread-domains/index.js +435 -0
  90. package/lib/data-azuread-group/index.d.ts +207 -0
  91. package/lib/data-azuread-group/index.js +506 -0
  92. package/lib/data-azuread-group-role-management-policy/index.d.ts +105 -0
  93. package/lib/data-azuread-group-role-management-policy/index.js +248 -0
  94. package/lib/data-azuread-groups/index.d.ts +160 -0
  95. package/lib/data-azuread-groups/index.js +348 -0
  96. package/lib/data-azuread-named-location/index.d.ts +163 -0
  97. package/lib/data-azuread-named-location/index.js +398 -0
  98. package/lib/data-azuread-service-principal/index.d.ts +325 -0
  99. package/lib/data-azuread-service-principal/index.js +817 -0
  100. package/lib/data-azuread-service-principals/index.d.ts +183 -0
  101. package/lib/data-azuread-service-principals/index.js +430 -0
  102. package/lib/data-azuread-user/index.d.ts +177 -0
  103. package/lib/data-azuread-user/index.js +465 -0
  104. package/lib/data-azuread-users/index.d.ts +204 -0
  105. package/lib/data-azuread-users/index.js +468 -0
  106. package/lib/directory-role/index.d.ts +125 -0
  107. package/lib/directory-role/index.js +306 -0
  108. package/lib/directory-role-assignment/index.d.ts +143 -0
  109. package/lib/directory-role-assignment/index.js +331 -0
  110. package/lib/directory-role-eligibility-schedule-request/index.d.ts +141 -0
  111. package/lib/directory-role-eligibility-schedule-request/index.js +325 -0
  112. package/lib/directory-role-member/index.d.ts +123 -0
  113. package/lib/directory-role-member/index.js +295 -0
  114. package/lib/group/index.d.ts +392 -0
  115. package/lib/group/index.js +872 -0
  116. package/lib/group-member/index.d.ts +121 -0
  117. package/lib/group-member/index.js +289 -0
  118. package/lib/group-role-management-policy/index.d.ts +1043 -0
  119. package/lib/group-role-management-policy/index.js +2775 -0
  120. package/lib/group-without-members/index.d.ts +381 -0
  121. package/lib/group-without-members/index.js +851 -0
  122. package/lib/index.d.ts +79 -0
  123. package/lib/index.js +85 -0
  124. package/lib/invitation/index.d.ts +203 -0
  125. package/lib/invitation/index.js +490 -0
  126. package/lib/lazy-index.d.ts +4 -0
  127. package/lib/lazy-index.js +82 -0
  128. package/lib/named-location/index.d.ts +212 -0
  129. package/lib/named-location/index.js +571 -0
  130. package/lib/privileged-access-group-assignment-schedule/index.d.ts +218 -0
  131. package/lib/privileged-access-group-assignment-schedule/index.js +484 -0
  132. package/lib/privileged-access-group-eligibility-schedule/index.d.ts +218 -0
  133. package/lib/privileged-access-group-eligibility-schedule/index.js +484 -0
  134. package/lib/provider/index.d.ts +289 -0
  135. package/lib/provider/index.js +549 -0
  136. package/lib/service-principal/index.d.ts +547 -0
  137. package/lib/service-principal/index.js +1305 -0
  138. package/lib/service-principal-certificate/index.d.ts +187 -0
  139. package/lib/service-principal-certificate/index.js +415 -0
  140. package/lib/service-principal-claims-mapping-policy-assignment/index.d.ts +121 -0
  141. package/lib/service-principal-claims-mapping-policy-assignment/index.js +289 -0
  142. package/lib/service-principal-delegated-permission-grant/index.d.ts +151 -0
  143. package/lib/service-principal-delegated-permission-grant/index.js +354 -0
  144. package/lib/service-principal-password/index.d.ts +176 -0
  145. package/lib/service-principal-password/index.js +384 -0
  146. package/lib/service-principal-token-signing-certificate/index.d.ts +137 -0
  147. package/lib/service-principal-token-signing-certificate/index.js +329 -0
  148. package/lib/synchronization-job/index.d.ts +177 -0
  149. package/lib/synchronization-job/index.js +424 -0
  150. package/lib/synchronization-job-provision-on-demand/index.d.ts +254 -0
  151. package/lib/synchronization-job-provision-on-demand/index.js +590 -0
  152. package/lib/synchronization-secret/index.d.ts +184 -0
  153. package/lib/synchronization-secret/index.js +449 -0
  154. package/lib/user/index.d.ts +517 -0
  155. package/lib/user/index.js +1084 -0
  156. package/lib/user-flow-attribute/index.d.ts +141 -0
  157. package/lib/user-flow-attribute/index.js +340 -0
  158. package/package.json +155 -0
@@ -0,0 +1,484 @@
1
+ "use strict";
2
+ var _a, _b;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.PrivilegedAccessGroupEligibilitySchedule = exports.PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference = void 0;
5
+ exports.privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform = privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform;
6
+ exports.privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform = privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform;
7
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
8
+ const cdktn = require("cdktn");
9
+ function privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform(struct) {
10
+ if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
11
+ return struct;
12
+ }
13
+ if (cdktn.isComplexElement(struct)) {
14
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
15
+ }
16
+ return {
17
+ create: cdktn.stringToTerraform(struct.create),
18
+ delete: cdktn.stringToTerraform(struct.delete),
19
+ read: cdktn.stringToTerraform(struct.read),
20
+ update: cdktn.stringToTerraform(struct.update),
21
+ };
22
+ }
23
+ function privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform(struct) {
24
+ if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
25
+ return struct;
26
+ }
27
+ if (cdktn.isComplexElement(struct)) {
28
+ throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
29
+ }
30
+ const attrs = {
31
+ create: {
32
+ value: cdktn.stringToHclTerraform(struct.create),
33
+ isBlock: false,
34
+ type: "simple",
35
+ storageClassType: "string",
36
+ },
37
+ delete: {
38
+ value: cdktn.stringToHclTerraform(struct.delete),
39
+ isBlock: false,
40
+ type: "simple",
41
+ storageClassType: "string",
42
+ },
43
+ read: {
44
+ value: cdktn.stringToHclTerraform(struct.read),
45
+ isBlock: false,
46
+ type: "simple",
47
+ storageClassType: "string",
48
+ },
49
+ update: {
50
+ value: cdktn.stringToHclTerraform(struct.update),
51
+ isBlock: false,
52
+ type: "simple",
53
+ storageClassType: "string",
54
+ },
55
+ };
56
+ // remove undefined attributes
57
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
58
+ }
59
+ class PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference extends cdktn.ComplexObject {
60
+ /**
61
+ * @param terraformResource The parent resource
62
+ * @param terraformAttribute The attribute on the parent resource this class is referencing
63
+ */
64
+ constructor(terraformResource, terraformAttribute) {
65
+ super(terraformResource, terraformAttribute, false);
66
+ this.isEmptyObject = false;
67
+ }
68
+ get internalValue() {
69
+ if (this.resolvableValue) {
70
+ return this.resolvableValue;
71
+ }
72
+ let hasAnyValues = this.isEmptyObject;
73
+ const internalValueResult = {};
74
+ if (this._create !== undefined) {
75
+ hasAnyValues = true;
76
+ internalValueResult.create = this._create;
77
+ }
78
+ if (this._delete !== undefined) {
79
+ hasAnyValues = true;
80
+ internalValueResult.delete = this._delete;
81
+ }
82
+ if (this._read !== undefined) {
83
+ hasAnyValues = true;
84
+ internalValueResult.read = this._read;
85
+ }
86
+ if (this._update !== undefined) {
87
+ hasAnyValues = true;
88
+ internalValueResult.update = this._update;
89
+ }
90
+ return hasAnyValues ? internalValueResult : undefined;
91
+ }
92
+ set internalValue(value) {
93
+ if (value === undefined) {
94
+ this.isEmptyObject = false;
95
+ this.resolvableValue = undefined;
96
+ this._create = undefined;
97
+ this._delete = undefined;
98
+ this._read = undefined;
99
+ this._update = undefined;
100
+ }
101
+ else if (cdktn.Tokenization.isResolvable(value)) {
102
+ this.isEmptyObject = false;
103
+ this.resolvableValue = value;
104
+ }
105
+ else {
106
+ this.isEmptyObject = Object.keys(value).length === 0;
107
+ this.resolvableValue = undefined;
108
+ this._create = value.create;
109
+ this._delete = value.delete;
110
+ this._read = value.read;
111
+ this._update = value.update;
112
+ }
113
+ }
114
+ get create() {
115
+ return this.getStringAttribute('create');
116
+ }
117
+ set create(value) {
118
+ this._create = value;
119
+ }
120
+ resetCreate() {
121
+ this._create = undefined;
122
+ }
123
+ // Temporarily expose input value. Use with caution.
124
+ get createInput() {
125
+ return this._create;
126
+ }
127
+ get delete() {
128
+ return this.getStringAttribute('delete');
129
+ }
130
+ set delete(value) {
131
+ this._delete = value;
132
+ }
133
+ resetDelete() {
134
+ this._delete = undefined;
135
+ }
136
+ // Temporarily expose input value. Use with caution.
137
+ get deleteInput() {
138
+ return this._delete;
139
+ }
140
+ get read() {
141
+ return this.getStringAttribute('read');
142
+ }
143
+ set read(value) {
144
+ this._read = value;
145
+ }
146
+ resetRead() {
147
+ this._read = undefined;
148
+ }
149
+ // Temporarily expose input value. Use with caution.
150
+ get readInput() {
151
+ return this._read;
152
+ }
153
+ get update() {
154
+ return this.getStringAttribute('update');
155
+ }
156
+ set update(value) {
157
+ this._update = value;
158
+ }
159
+ resetUpdate() {
160
+ this._update = undefined;
161
+ }
162
+ // Temporarily expose input value. Use with caution.
163
+ get updateInput() {
164
+ return this._update;
165
+ }
166
+ }
167
+ exports.PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference = PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference;
168
+ _a = JSII_RTTI_SYMBOL_1;
169
+ PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference[_a] = { fqn: "@cdktn/provider-azuread.privilegedAccessGroupEligibilitySchedule.PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference", version: "15.0.0" };
170
+ /**
171
+ * Represents a {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule azuread_privileged_access_group_eligibility_schedule}
172
+ */
173
+ class PrivilegedAccessGroupEligibilitySchedule extends cdktn.TerraformResource {
174
+ // ==============
175
+ // STATIC Methods
176
+ // ==============
177
+ /**
178
+ * Generates CDKTN code for importing a PrivilegedAccessGroupEligibilitySchedule resource upon running "cdktn plan <stack-name>"
179
+ * @param scope The scope in which to define this construct
180
+ * @param importToId The construct id used in the generated config for the PrivilegedAccessGroupEligibilitySchedule to import
181
+ * @param importFromId The id of the existing PrivilegedAccessGroupEligibilitySchedule that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#import import section} in the documentation of this resource for the id to use
182
+ * @param provider? Optional instance of the provider where the PrivilegedAccessGroupEligibilitySchedule to import is found
183
+ */
184
+ static generateConfigForImport(scope, importToId, importFromId, provider) {
185
+ return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: "azuread_privileged_access_group_eligibility_schedule", importId: importFromId, provider });
186
+ }
187
+ // ===========
188
+ // INITIALIZER
189
+ // ===========
190
+ /**
191
+ * Create a new {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule azuread_privileged_access_group_eligibility_schedule} Resource
192
+ *
193
+ * @param scope The scope in which to define this construct
194
+ * @param id The scoped construct ID. Must be unique amongst siblings in the same scope
195
+ * @param options PrivilegedAccessGroupEligibilityScheduleConfig
196
+ */
197
+ constructor(scope, id, config) {
198
+ super(scope, id, {
199
+ terraformResourceType: 'azuread_privileged_access_group_eligibility_schedule',
200
+ terraformGeneratorMetadata: {
201
+ providerName: 'azuread',
202
+ providerVersion: '3.7.0',
203
+ providerVersionConstraint: '~> 3.0'
204
+ },
205
+ provider: config.provider,
206
+ dependsOn: config.dependsOn,
207
+ count: config.count,
208
+ lifecycle: config.lifecycle,
209
+ provisioners: config.provisioners,
210
+ connection: config.connection,
211
+ forEach: config.forEach
212
+ });
213
+ // timeouts - computed: false, optional: true, required: false
214
+ this._timeouts = new PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference(this, "timeouts");
215
+ this._assignmentType = config.assignmentType;
216
+ this._duration = config.duration;
217
+ this._expirationDate = config.expirationDate;
218
+ this._groupId = config.groupId;
219
+ this._id = config.id;
220
+ this._justification = config.justification;
221
+ this._permanentAssignment = config.permanentAssignment;
222
+ this._principalId = config.principalId;
223
+ this._startDate = config.startDate;
224
+ this._ticketNumber = config.ticketNumber;
225
+ this._ticketSystem = config.ticketSystem;
226
+ this._timeouts.internalValue = config.timeouts;
227
+ }
228
+ get assignmentType() {
229
+ return this.getStringAttribute('assignment_type');
230
+ }
231
+ set assignmentType(value) {
232
+ this._assignmentType = value;
233
+ }
234
+ // Temporarily expose input value. Use with caution.
235
+ get assignmentTypeInput() {
236
+ return this._assignmentType;
237
+ }
238
+ get duration() {
239
+ return this.getStringAttribute('duration');
240
+ }
241
+ set duration(value) {
242
+ this._duration = value;
243
+ }
244
+ resetDuration() {
245
+ this._duration = undefined;
246
+ }
247
+ // Temporarily expose input value. Use with caution.
248
+ get durationInput() {
249
+ return this._duration;
250
+ }
251
+ get expirationDate() {
252
+ return this.getStringAttribute('expiration_date');
253
+ }
254
+ set expirationDate(value) {
255
+ this._expirationDate = value;
256
+ }
257
+ resetExpirationDate() {
258
+ this._expirationDate = undefined;
259
+ }
260
+ // Temporarily expose input value. Use with caution.
261
+ get expirationDateInput() {
262
+ return this._expirationDate;
263
+ }
264
+ get groupId() {
265
+ return this.getStringAttribute('group_id');
266
+ }
267
+ set groupId(value) {
268
+ this._groupId = value;
269
+ }
270
+ // Temporarily expose input value. Use with caution.
271
+ get groupIdInput() {
272
+ return this._groupId;
273
+ }
274
+ get id() {
275
+ return this.getStringAttribute('id');
276
+ }
277
+ set id(value) {
278
+ this._id = value;
279
+ }
280
+ resetId() {
281
+ this._id = undefined;
282
+ }
283
+ // Temporarily expose input value. Use with caution.
284
+ get idInput() {
285
+ return this._id;
286
+ }
287
+ get justification() {
288
+ return this.getStringAttribute('justification');
289
+ }
290
+ set justification(value) {
291
+ this._justification = value;
292
+ }
293
+ resetJustification() {
294
+ this._justification = undefined;
295
+ }
296
+ // Temporarily expose input value. Use with caution.
297
+ get justificationInput() {
298
+ return this._justification;
299
+ }
300
+ get permanentAssignment() {
301
+ return this.getBooleanAttribute('permanent_assignment');
302
+ }
303
+ set permanentAssignment(value) {
304
+ this._permanentAssignment = value;
305
+ }
306
+ resetPermanentAssignment() {
307
+ this._permanentAssignment = undefined;
308
+ }
309
+ // Temporarily expose input value. Use with caution.
310
+ get permanentAssignmentInput() {
311
+ return this._permanentAssignment;
312
+ }
313
+ get principalId() {
314
+ return this.getStringAttribute('principal_id');
315
+ }
316
+ set principalId(value) {
317
+ this._principalId = value;
318
+ }
319
+ // Temporarily expose input value. Use with caution.
320
+ get principalIdInput() {
321
+ return this._principalId;
322
+ }
323
+ get startDate() {
324
+ return this.getStringAttribute('start_date');
325
+ }
326
+ set startDate(value) {
327
+ this._startDate = value;
328
+ }
329
+ resetStartDate() {
330
+ this._startDate = undefined;
331
+ }
332
+ // Temporarily expose input value. Use with caution.
333
+ get startDateInput() {
334
+ return this._startDate;
335
+ }
336
+ // status - computed: true, optional: false, required: false
337
+ get status() {
338
+ return this.getStringAttribute('status');
339
+ }
340
+ get ticketNumber() {
341
+ return this.getStringAttribute('ticket_number');
342
+ }
343
+ set ticketNumber(value) {
344
+ this._ticketNumber = value;
345
+ }
346
+ resetTicketNumber() {
347
+ this._ticketNumber = undefined;
348
+ }
349
+ // Temporarily expose input value. Use with caution.
350
+ get ticketNumberInput() {
351
+ return this._ticketNumber;
352
+ }
353
+ get ticketSystem() {
354
+ return this.getStringAttribute('ticket_system');
355
+ }
356
+ set ticketSystem(value) {
357
+ this._ticketSystem = value;
358
+ }
359
+ resetTicketSystem() {
360
+ this._ticketSystem = undefined;
361
+ }
362
+ // Temporarily expose input value. Use with caution.
363
+ get ticketSystemInput() {
364
+ return this._ticketSystem;
365
+ }
366
+ get timeouts() {
367
+ return this._timeouts;
368
+ }
369
+ putTimeouts(value) {
370
+ this._timeouts.internalValue = value;
371
+ }
372
+ resetTimeouts() {
373
+ this._timeouts.internalValue = undefined;
374
+ }
375
+ // Temporarily expose input value. Use with caution.
376
+ get timeoutsInput() {
377
+ return this._timeouts.internalValue;
378
+ }
379
+ // =========
380
+ // SYNTHESIS
381
+ // =========
382
+ synthesizeAttributes() {
383
+ return {
384
+ assignment_type: cdktn.stringToTerraform(this._assignmentType),
385
+ duration: cdktn.stringToTerraform(this._duration),
386
+ expiration_date: cdktn.stringToTerraform(this._expirationDate),
387
+ group_id: cdktn.stringToTerraform(this._groupId),
388
+ id: cdktn.stringToTerraform(this._id),
389
+ justification: cdktn.stringToTerraform(this._justification),
390
+ permanent_assignment: cdktn.booleanToTerraform(this._permanentAssignment),
391
+ principal_id: cdktn.stringToTerraform(this._principalId),
392
+ start_date: cdktn.stringToTerraform(this._startDate),
393
+ ticket_number: cdktn.stringToTerraform(this._ticketNumber),
394
+ ticket_system: cdktn.stringToTerraform(this._ticketSystem),
395
+ timeouts: privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform(this._timeouts.internalValue),
396
+ };
397
+ }
398
+ synthesizeHclAttributes() {
399
+ const attrs = {
400
+ assignment_type: {
401
+ value: cdktn.stringToHclTerraform(this._assignmentType),
402
+ isBlock: false,
403
+ type: "simple",
404
+ storageClassType: "string",
405
+ },
406
+ duration: {
407
+ value: cdktn.stringToHclTerraform(this._duration),
408
+ isBlock: false,
409
+ type: "simple",
410
+ storageClassType: "string",
411
+ },
412
+ expiration_date: {
413
+ value: cdktn.stringToHclTerraform(this._expirationDate),
414
+ isBlock: false,
415
+ type: "simple",
416
+ storageClassType: "string",
417
+ },
418
+ group_id: {
419
+ value: cdktn.stringToHclTerraform(this._groupId),
420
+ isBlock: false,
421
+ type: "simple",
422
+ storageClassType: "string",
423
+ },
424
+ id: {
425
+ value: cdktn.stringToHclTerraform(this._id),
426
+ isBlock: false,
427
+ type: "simple",
428
+ storageClassType: "string",
429
+ },
430
+ justification: {
431
+ value: cdktn.stringToHclTerraform(this._justification),
432
+ isBlock: false,
433
+ type: "simple",
434
+ storageClassType: "string",
435
+ },
436
+ permanent_assignment: {
437
+ value: cdktn.booleanToHclTerraform(this._permanentAssignment),
438
+ isBlock: false,
439
+ type: "simple",
440
+ storageClassType: "boolean",
441
+ },
442
+ principal_id: {
443
+ value: cdktn.stringToHclTerraform(this._principalId),
444
+ isBlock: false,
445
+ type: "simple",
446
+ storageClassType: "string",
447
+ },
448
+ start_date: {
449
+ value: cdktn.stringToHclTerraform(this._startDate),
450
+ isBlock: false,
451
+ type: "simple",
452
+ storageClassType: "string",
453
+ },
454
+ ticket_number: {
455
+ value: cdktn.stringToHclTerraform(this._ticketNumber),
456
+ isBlock: false,
457
+ type: "simple",
458
+ storageClassType: "string",
459
+ },
460
+ ticket_system: {
461
+ value: cdktn.stringToHclTerraform(this._ticketSystem),
462
+ isBlock: false,
463
+ type: "simple",
464
+ storageClassType: "string",
465
+ },
466
+ timeouts: {
467
+ value: privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform(this._timeouts.internalValue),
468
+ isBlock: true,
469
+ type: "struct",
470
+ storageClassType: "PrivilegedAccessGroupEligibilityScheduleTimeouts",
471
+ },
472
+ };
473
+ // remove undefined attributes
474
+ return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
475
+ }
476
+ }
477
+ exports.PrivilegedAccessGroupEligibilitySchedule = PrivilegedAccessGroupEligibilitySchedule;
478
+ _b = JSII_RTTI_SYMBOL_1;
479
+ PrivilegedAccessGroupEligibilitySchedule[_b] = { fqn: "@cdktn/provider-azuread.privilegedAccessGroupEligibilitySchedule.PrivilegedAccessGroupEligibilitySchedule", version: "15.0.0" };
480
+ // =================
481
+ // STATIC PROPERTIES
482
+ // =================
483
+ PrivilegedAccessGroupEligibilitySchedule.tfResourceType = "azuread_privileged_access_group_eligibility_schedule";
484
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/privileged-access-group-eligibility-schedule/index.ts"],"names":[],"mappings":";;;;AA2GA,kIAWC;AAGD,wIAkCC;;AAlJD,+BAA+B;AAkG/B,SAAgB,2DAA2D,CAAC,MAA6E;IACvJ,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC;QAAC,OAAO,MAAM,CAAC;IAAC,CAAC;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;IACxI,CAAC;IACD,OAAO;QACL,MAAM,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,MAAM,CAAC;QAC/C,MAAM,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,MAAM,CAAC;QAC/C,IAAI,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,IAAI,CAAC;QAC3C,MAAM,EAAE,KAAK,CAAC,iBAAiB,CAAC,MAAO,CAAC,MAAM,CAAC;KAChD,CAAA;AACH,CAAC;AAGD,SAAgB,8DAA8D,CAAC,MAA6E;IAC1J,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE,CAAC;QAAC,OAAO,MAAM,CAAC;IAAC,CAAC;IAC5F,IAAI,KAAK,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE,CAAC;QACnC,MAAM,IAAI,KAAK,CAAC,oHAAoH,CAAC,CAAC;IACxI,CAAC;IACD,MAAM,KAAK,GAAG;QACZ,MAAM,EAAE;YACN,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,MAAO,CAAC,MAAM,CAAC;YACjD,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,QAAQ;YACd,gBAAgB,EAAE,QAAQ;SAC3B;QACD,MAAM,EAAE;YACN,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,MAAO,CAAC,MAAM,CAAC;YACjD,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,QAAQ;YACd,gBAAgB,EAAE,QAAQ;SAC3B;QACD,IAAI,EAAE;YACJ,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,MAAO,CAAC,IAAI,CAAC;YAC/C,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,QAAQ;YACd,gBAAgB,EAAE,QAAQ;SAC3B;QACD,MAAM,EAAE;YACN,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,MAAO,CAAC,MAAM,CAAC;YACjD,OAAO,EAAE,KAAK;YACd,IAAI,EAAE,QAAQ;YACd,gBAAgB,EAAE,QAAQ;SAC3B;KACF,CAAC;IAEF,8BAA8B;IAC9B,OAAO,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC;AAC5H,CAAC;AAED,MAAa,+DAAgE,SAAQ,KAAK,CAAC,aAAa;IAItG;;;MAGE;IACF,YAAmB,iBAA6C,EAAE,kBAA0B;QAC1F,KAAK,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,KAAK,CAAC,CAAC;QAR9C,kBAAa,GAAG,KAAK,CAAC;IAS9B,CAAC;IAED,IAAW,aAAa;QACtB,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO,IAAI,CAAC,eAAe,CAAC;QAC9B,CAAC;QACD,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACtC,MAAM,mBAAmB,GAAQ,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC/B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5C,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC/B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5C,CAAC;QACD,IAAI,IAAI,CAAC,KAAK,KAAK,SAAS,EAAE,CAAC;YAC7B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC;QACxC,CAAC;QACD,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;YAC/B,YAAY,GAAG,IAAI,CAAC;YACpB,mBAAmB,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5C,CAAC;QACD,OAAO,YAAY,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,IAAW,aAAa,CAAC,KAAuF;QAC9G,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;YACzB,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;YACvB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;QAC3B,CAAC;aACI,IAAI,KAAK,CAAC,YAAY,CAAC,YAAY,CAAC,KAAK,CAAC,EAAE,CAAC;YAChD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC/B,CAAC;aACI,CAAC;YACJ,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;YACrD,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;YACjC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;YAC5B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;YAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC;QAC9B,CAAC;IACH,CAAC;IAID,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IACD,IAAW,MAAM,CAAC,KAAa;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IACD,oDAAoD;IACpD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAID,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IACD,IAAW,MAAM,CAAC,KAAa;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IACD,oDAAoD;IACpD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAID,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;IACD,IAAW,IAAI,CAAC,KAAa;QAC3B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACM,SAAS;QACd,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IACD,oDAAoD;IACpD,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAID,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IACD,IAAW,MAAM,CAAC,KAAa;QAC7B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IACM,WAAW;QAChB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC;IAC3B,CAAC;IACD,oDAAoD;IACpD,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;AA1HH,0IA2HC;;;AAED;;EAEE;AACF,MAAa,wCAAyC,SAAQ,KAAK,CAAC,iBAAiB;IAOnF,iBAAiB;IACjB,iBAAiB;IACjB,iBAAiB;IACjB;;;;;;MAME;IACK,MAAM,CAAC,uBAAuB,CAAC,KAAgB,EAAE,UAAkB,EAAE,YAAoB,EAAE,QAAkC;QAC9H,OAAO,IAAI,KAAK,CAAC,kBAAkB,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,qBAAqB,EAAE,sDAAsD,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC9K,CAAC;IAEL,cAAc;IACd,cAAc;IACd,cAAc;IAEd;;;;;;MAME;IACF,YAAmB,KAAgB,EAAE,EAAU,EAAE,MAAsD;QACrG,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE;YACf,qBAAqB,EAAE,sDAAsD;YAC7E,0BAA0B,EAAE;gBAC1B,YAAY,EAAE,SAAS;gBACvB,eAAe,EAAE,OAAO;gBACxB,yBAAyB,EAAE,QAAQ;aACpC;YACD,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,YAAY,EAAE,MAAM,CAAC,YAAY;YACjC,UAAU,EAAE,MAAM,CAAC,UAAU;YAC7B,OAAO,EAAE,MAAM,CAAC,OAAO;SACxB,CAAC,CAAC;QA+LL,8DAA8D;QACtD,cAAS,GAAG,IAAI,+DAA+D,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QA/LxG,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC,EAAE,CAAC;QACrB,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,aAAa,CAAC;QAC3C,IAAI,CAAC,oBAAoB,GAAG,MAAM,CAAC,mBAAmB,CAAC;QACvD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,WAAW,CAAC;QACvC,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,SAAS,CAAC;QACnC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,YAAY,CAAC;QACzC,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAC;IACjD,CAAC;IAQD,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IACD,IAAW,cAAc,CAAC,KAAa;QACrC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IACD,oDAAoD;IACpD,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAID,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IACD,IAAW,QAAQ,CAAC,KAAa;QAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACM,aAAa;QAClB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC7B,CAAC;IACD,oDAAoD;IACpD,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAID,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;IACpD,CAAC;IACD,IAAW,cAAc,CAAC,KAAa;QACrC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IACM,mBAAmB;QACxB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;IACnC,CAAC;IACD,oDAAoD;IACpD,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAID,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;IAC7C,CAAC;IACD,IAAW,OAAO,CAAC,KAAa;QAC9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,oDAAoD;IACpD,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAID,IAAW,EAAE;QACX,OAAO,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IACD,IAAW,EAAE,CAAC,KAAa;QACzB,IAAI,CAAC,GAAG,GAAG,KAAK,CAAC;IACnB,CAAC;IACM,OAAO;QACZ,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC;IACvB,CAAC;IACD,oDAAoD;IACpD,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,GAAG,CAAC;IAClB,CAAC;IAID,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAClD,CAAC;IACD,IAAW,aAAa,CAAC,KAAa;QACpC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IACM,kBAAkB;QACvB,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IAClC,CAAC;IACD,oDAAoD;IACpD,IAAW,kBAAkB;QAC3B,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAID,IAAW,mBAAmB;QAC5B,OAAO,IAAI,CAAC,mBAAmB,CAAC,sBAAsB,CAAC,CAAC;IAC1D,CAAC;IACD,IAAW,mBAAmB,CAAC,KAAkC;QAC/D,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;IACpC,CAAC;IACM,wBAAwB;QAC7B,IAAI,CAAC,oBAAoB,GAAG,SAAS,CAAC;IACxC,CAAC;IACD,oDAAoD;IACpD,IAAW,wBAAwB;QACjC,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACnC,CAAC;IAID,IAAW,WAAW;QACpB,OAAO,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;IACjD,CAAC;IACD,IAAW,WAAW,CAAC,KAAa;QAClC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IACD,oDAAoD;IACpD,IAAW,gBAAgB;QACzB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAID,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;IAC/C,CAAC;IACD,IAAW,SAAS,CAAC,KAAa;QAChC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IACM,cAAc;QACnB,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC9B,CAAC;IACD,oDAAoD;IACpD,IAAW,cAAc;QACvB,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,4DAA4D;IAC5D,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC;IAID,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAClD,CAAC;IACD,IAAW,YAAY,CAAC,KAAa;QACnC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IACM,iBAAiB;QACtB,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;IACjC,CAAC;IACD,oDAAoD;IACpD,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAID,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAClD,CAAC;IACD,IAAW,YAAY,CAAC,KAAa;QACnC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IACM,iBAAiB;QACtB,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC;IACjC,CAAC;IACD,oDAAoD;IACpD,IAAW,iBAAiB;QAC1B,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAID,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACM,WAAW,CAAC,KAAuD;QACxE,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,KAAK,CAAC;IACvC,CAAC;IACM,aAAa;QAClB,IAAI,CAAC,SAAS,CAAC,aAAa,GAAG,SAAS,CAAC;IAC3C,CAAC;IACD,oDAAoD;IACpD,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;IACtC,CAAC;IAED,YAAY;IACZ,YAAY;IACZ,YAAY;IAEF,oBAAoB;QAC5B,OAAO;YACL,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC;YAC9D,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC;YACjD,eAAe,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC;YAC9D,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,QAAQ,CAAC;YAChD,EAAE,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC;YACrC,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,cAAc,CAAC;YAC3D,oBAAoB,EAAE,KAAK,CAAC,kBAAkB,CAAC,IAAI,CAAC,oBAAoB,CAAC;YACzE,YAAY,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC;YACxD,UAAU,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YACpD,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC;YAC1D,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC;YAC1D,QAAQ,EAAE,2DAA2D,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;SACpG,CAAC;IACJ,CAAC;IAES,uBAAuB;QAC/B,MAAM,KAAK,GAAG;YACZ,eAAe,EAAE;gBACf,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,eAAe,CAAC;gBACvD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,QAAQ,EAAE;gBACR,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,CAAC;gBACjD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,eAAe,EAAE;gBACf,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,eAAe,CAAC;gBACvD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,QAAQ,EAAE;gBACR,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAChD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,EAAE,EAAE;gBACF,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC3C,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,aAAa,EAAE;gBACb,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC;gBACtD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,oBAAoB,EAAE;gBACpB,KAAK,EAAE,KAAK,CAAC,qBAAqB,CAAC,IAAI,CAAC,oBAAoB,CAAC;gBAC7D,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,SAAS;aAC5B;YACD,YAAY,EAAE;gBACZ,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC;gBACpD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,UAAU,EAAE;gBACV,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,CAAC;gBAClD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,aAAa,EAAE;gBACb,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,aAAa,CAAC;gBACrD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,aAAa,EAAE;gBACb,KAAK,EAAE,KAAK,CAAC,oBAAoB,CAAC,IAAI,CAAC,aAAa,CAAC;gBACrD,OAAO,EAAE,KAAK;gBACd,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,QAAQ;aAC3B;YACD,QAAQ,EAAE;gBACR,KAAK,EAAE,8DAA8D,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;gBACnG,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,QAAQ;gBACd,gBAAgB,EAAE,kDAAkD;aACrE;SACF,CAAC;QAEF,8BAA8B;QAC9B,OAAO,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,CAAC,KAAK,KAAK,SAAS,CAAE,CAAC,CAAA;IAC5H,CAAC;;AAjWH,4FAkWC;;;AAhWC,oBAAoB;AACpB,oBAAoB;AACpB,oBAAoB;AACG,uDAAc,GAAG,sDAAsD,AAAzD,CAA0D","sourcesContent":["/**\n * Copyright IBM Corp. 2021, 2026\n * SPDX-License-Identifier: MPL-2.0\n */\n\n// https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktn from 'cdktn';\n\n// Configuration\n\nexport interface PrivilegedAccessGroupEligibilityScheduleConfig extends cdktn.TerraformMetaArguments {\n  /**\n  * The ID of the assignment to the group\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#assignment_type PrivilegedAccessGroupEligibilitySchedule#assignment_type}\n  */\n  readonly assignmentType: string;\n  /**\n  * The duration of the assignment, formatted as an ISO8601 duration string (e.g. P3D for 3 days)\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#duration PrivilegedAccessGroupEligibilitySchedule#duration}\n  */\n  readonly duration?: string;\n  /**\n  * The date that this assignment expires, formatted as an RFC3339 date string in UTC (e.g. 2018-01-01T01:02:03Z)\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#expiration_date PrivilegedAccessGroupEligibilitySchedule#expiration_date}\n  */\n  readonly expirationDate?: string;\n  /**\n  * The ID of the Group representing the scope of the assignment\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#group_id PrivilegedAccessGroupEligibilitySchedule#group_id}\n  */\n  readonly groupId: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#id PrivilegedAccessGroupEligibilitySchedule#id}\n  *\n  * Please be aware that the id field is automatically added to all resources in Terraform providers using a Terraform provider SDK version below 2.\n  * If you experience problems setting this value it might not be settable. Please take a look at the provider documentation to ensure it should be settable.\n  */\n  readonly id?: string;\n  /**\n  * The justification for the assignment\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#justification PrivilegedAccessGroupEligibilitySchedule#justification}\n  */\n  readonly justification?: string;\n  /**\n  * Is the assignment permanent\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#permanent_assignment PrivilegedAccessGroupEligibilitySchedule#permanent_assignment}\n  */\n  readonly permanentAssignment?: boolean | cdktn.IResolvable;\n  /**\n  * The ID of the Principal assigned to the schedule\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#principal_id PrivilegedAccessGroupEligibilitySchedule#principal_id}\n  */\n  readonly principalId: string;\n  /**\n  * The date that this assignment starts, formatted as an RFC3339 date string in UTC (e.g. 2018-01-01T01:02:03Z)\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#start_date PrivilegedAccessGroupEligibilitySchedule#start_date}\n  */\n  readonly startDate?: string;\n  /**\n  * The ticket number authorising the assignment\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#ticket_number PrivilegedAccessGroupEligibilitySchedule#ticket_number}\n  */\n  readonly ticketNumber?: string;\n  /**\n  * The ticket system authorising the assignment\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#ticket_system PrivilegedAccessGroupEligibilitySchedule#ticket_system}\n  */\n  readonly ticketSystem?: string;\n  /**\n  * timeouts block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#timeouts PrivilegedAccessGroupEligibilitySchedule#timeouts}\n  */\n  readonly timeouts?: PrivilegedAccessGroupEligibilityScheduleTimeouts;\n}\nexport interface PrivilegedAccessGroupEligibilityScheduleTimeouts {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#create PrivilegedAccessGroupEligibilitySchedule#create}\n  */\n  readonly create?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#delete PrivilegedAccessGroupEligibilitySchedule#delete}\n  */\n  readonly delete?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#read PrivilegedAccessGroupEligibilitySchedule#read}\n  */\n  readonly read?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#update PrivilegedAccessGroupEligibilitySchedule#update}\n  */\n  readonly update?: string;\n}\n\nexport function privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform(struct?: PrivilegedAccessGroupEligibilityScheduleTimeouts | cdktn.IResolvable): any {\n  if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktn.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  return {\n    create: cdktn.stringToTerraform(struct!.create),\n    delete: cdktn.stringToTerraform(struct!.delete),\n    read: cdktn.stringToTerraform(struct!.read),\n    update: cdktn.stringToTerraform(struct!.update),\n  }\n}\n\n\nexport function privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform(struct?: PrivilegedAccessGroupEligibilityScheduleTimeouts | cdktn.IResolvable): any {\n  if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) { return struct; }\n  if (cdktn.isComplexElement(struct)) {\n    throw new Error(\"A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration\");\n  }\n  const attrs = {\n    create: {\n      value: cdktn.stringToHclTerraform(struct!.create),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    delete: {\n      value: cdktn.stringToHclTerraform(struct!.delete),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    read: {\n      value: cdktn.stringToHclTerraform(struct!.read),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    update: {\n      value: cdktn.stringToHclTerraform(struct!.update),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n  };\n\n  // remove undefined attributes\n  return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));\n}\n\nexport class PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\n  private resolvableValue?: cdktn.IResolvable;\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  */\n  public constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string) {\n    super(terraformResource, terraformAttribute, false);\n  }\n\n  public get internalValue(): PrivilegedAccessGroupEligibilityScheduleTimeouts | cdktn.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._create !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.create = this._create;\n    }\n    if (this._delete !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.delete = this._delete;\n    }\n    if (this._read !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.read = this._read;\n    }\n    if (this._update !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.update = this._update;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: PrivilegedAccessGroupEligibilityScheduleTimeouts | cdktn.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._create = undefined;\n      this._delete = undefined;\n      this._read = undefined;\n      this._update = undefined;\n    }\n    else if (cdktn.Tokenization.isResolvable(value)) {\n      this.isEmptyObject = false;\n      this.resolvableValue = value;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this.resolvableValue = undefined;\n      this._create = value.create;\n      this._delete = value.delete;\n      this._read = value.read;\n      this._update = value.update;\n    }\n  }\n\n  // create - computed: false, optional: true, required: false\n  private _create?: string; \n  public get create() {\n    return this.getStringAttribute('create');\n  }\n  public set create(value: string) {\n    this._create = value;\n  }\n  public resetCreate() {\n    this._create = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get createInput() {\n    return this._create;\n  }\n\n  // delete - computed: false, optional: true, required: false\n  private _delete?: string; \n  public get delete() {\n    return this.getStringAttribute('delete');\n  }\n  public set delete(value: string) {\n    this._delete = value;\n  }\n  public resetDelete() {\n    this._delete = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get deleteInput() {\n    return this._delete;\n  }\n\n  // read - computed: false, optional: true, required: false\n  private _read?: string; \n  public get read() {\n    return this.getStringAttribute('read');\n  }\n  public set read(value: string) {\n    this._read = value;\n  }\n  public resetRead() {\n    this._read = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get readInput() {\n    return this._read;\n  }\n\n  // update - computed: false, optional: true, required: false\n  private _update?: string; \n  public get update() {\n    return this.getStringAttribute('update');\n  }\n  public set update(value: string) {\n    this._update = value;\n  }\n  public resetUpdate() {\n    this._update = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get updateInput() {\n    return this._update;\n  }\n}\n\n/**\n* Represents a {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule azuread_privileged_access_group_eligibility_schedule}\n*/\nexport class PrivilegedAccessGroupEligibilitySchedule extends cdktn.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"azuread_privileged_access_group_eligibility_schedule\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTN code for importing a PrivilegedAccessGroupEligibilitySchedule resource upon running \"cdktn plan <stack-name>\"\n  * @param scope The scope in which to define this construct\n  * @param importToId The construct id used in the generated config for the PrivilegedAccessGroupEligibilitySchedule to import\n  * @param importFromId The id of the existing PrivilegedAccessGroupEligibilitySchedule that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the PrivilegedAccessGroupEligibilitySchedule to import is found\n  */\n  public static generateConfigForImport(scope: Construct, importToId: string, importFromId: string, provider?: cdktn.TerraformProvider) {\n        return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: \"azuread_privileged_access_group_eligibility_schedule\", importId: importFromId, provider });\n      }\n\n  // ===========\n  // INITIALIZER\n  // ===========\n\n  /**\n  * Create a new {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/privileged_access_group_eligibility_schedule azuread_privileged_access_group_eligibility_schedule} Resource\n  *\n  * @param scope The scope in which to define this construct\n  * @param id The scoped construct ID. Must be unique amongst siblings in the same scope\n  * @param options PrivilegedAccessGroupEligibilityScheduleConfig\n  */\n  public constructor(scope: Construct, id: string, config: PrivilegedAccessGroupEligibilityScheduleConfig) {\n    super(scope, id, {\n      terraformResourceType: 'azuread_privileged_access_group_eligibility_schedule',\n      terraformGeneratorMetadata: {\n        providerName: 'azuread',\n        providerVersion: '3.7.0',\n        providerVersionConstraint: '~> 3.0'\n      },\n      provider: config.provider,\n      dependsOn: config.dependsOn,\n      count: config.count,\n      lifecycle: config.lifecycle,\n      provisioners: config.provisioners,\n      connection: config.connection,\n      forEach: config.forEach\n    });\n    this._assignmentType = config.assignmentType;\n    this._duration = config.duration;\n    this._expirationDate = config.expirationDate;\n    this._groupId = config.groupId;\n    this._id = config.id;\n    this._justification = config.justification;\n    this._permanentAssignment = config.permanentAssignment;\n    this._principalId = config.principalId;\n    this._startDate = config.startDate;\n    this._ticketNumber = config.ticketNumber;\n    this._ticketSystem = config.ticketSystem;\n    this._timeouts.internalValue = config.timeouts;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // assignment_type - computed: false, optional: false, required: true\n  private _assignmentType?: string; \n  public get assignmentType() {\n    return this.getStringAttribute('assignment_type');\n  }\n  public set assignmentType(value: string) {\n    this._assignmentType = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get assignmentTypeInput() {\n    return this._assignmentType;\n  }\n\n  // duration - computed: false, optional: true, required: false\n  private _duration?: string; \n  public get duration() {\n    return this.getStringAttribute('duration');\n  }\n  public set duration(value: string) {\n    this._duration = value;\n  }\n  public resetDuration() {\n    this._duration = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get durationInput() {\n    return this._duration;\n  }\n\n  // expiration_date - computed: true, optional: true, required: false\n  private _expirationDate?: string; \n  public get expirationDate() {\n    return this.getStringAttribute('expiration_date');\n  }\n  public set expirationDate(value: string) {\n    this._expirationDate = value;\n  }\n  public resetExpirationDate() {\n    this._expirationDate = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get expirationDateInput() {\n    return this._expirationDate;\n  }\n\n  // group_id - computed: false, optional: false, required: true\n  private _groupId?: string; \n  public get groupId() {\n    return this.getStringAttribute('group_id');\n  }\n  public set groupId(value: string) {\n    this._groupId = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get groupIdInput() {\n    return this._groupId;\n  }\n\n  // id - computed: true, optional: true, required: false\n  private _id?: string; \n  public get id() {\n    return this.getStringAttribute('id');\n  }\n  public set id(value: string) {\n    this._id = value;\n  }\n  public resetId() {\n    this._id = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get idInput() {\n    return this._id;\n  }\n\n  // justification - computed: false, optional: true, required: false\n  private _justification?: string; \n  public get justification() {\n    return this.getStringAttribute('justification');\n  }\n  public set justification(value: string) {\n    this._justification = value;\n  }\n  public resetJustification() {\n    this._justification = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get justificationInput() {\n    return this._justification;\n  }\n\n  // permanent_assignment - computed: true, optional: true, required: false\n  private _permanentAssignment?: boolean | cdktn.IResolvable; \n  public get permanentAssignment() {\n    return this.getBooleanAttribute('permanent_assignment');\n  }\n  public set permanentAssignment(value: boolean | cdktn.IResolvable) {\n    this._permanentAssignment = value;\n  }\n  public resetPermanentAssignment() {\n    this._permanentAssignment = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get permanentAssignmentInput() {\n    return this._permanentAssignment;\n  }\n\n  // principal_id - computed: false, optional: false, required: true\n  private _principalId?: string; \n  public get principalId() {\n    return this.getStringAttribute('principal_id');\n  }\n  public set principalId(value: string) {\n    this._principalId = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get principalIdInput() {\n    return this._principalId;\n  }\n\n  // start_date - computed: true, optional: true, required: false\n  private _startDate?: string; \n  public get startDate() {\n    return this.getStringAttribute('start_date');\n  }\n  public set startDate(value: string) {\n    this._startDate = value;\n  }\n  public resetStartDate() {\n    this._startDate = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get startDateInput() {\n    return this._startDate;\n  }\n\n  // status - computed: true, optional: false, required: false\n  public get status() {\n    return this.getStringAttribute('status');\n  }\n\n  // ticket_number - computed: false, optional: true, required: false\n  private _ticketNumber?: string; \n  public get ticketNumber() {\n    return this.getStringAttribute('ticket_number');\n  }\n  public set ticketNumber(value: string) {\n    this._ticketNumber = value;\n  }\n  public resetTicketNumber() {\n    this._ticketNumber = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ticketNumberInput() {\n    return this._ticketNumber;\n  }\n\n  // ticket_system - computed: false, optional: true, required: false\n  private _ticketSystem?: string; \n  public get ticketSystem() {\n    return this.getStringAttribute('ticket_system');\n  }\n  public set ticketSystem(value: string) {\n    this._ticketSystem = value;\n  }\n  public resetTicketSystem() {\n    this._ticketSystem = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ticketSystemInput() {\n    return this._ticketSystem;\n  }\n\n  // timeouts - computed: false, optional: true, required: false\n  private _timeouts = new PrivilegedAccessGroupEligibilityScheduleTimeoutsOutputReference(this, \"timeouts\");\n  public get timeouts() {\n    return this._timeouts;\n  }\n  public putTimeouts(value: PrivilegedAccessGroupEligibilityScheduleTimeouts) {\n    this._timeouts.internalValue = value;\n  }\n  public resetTimeouts() {\n    this._timeouts.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get timeoutsInput() {\n    return this._timeouts.internalValue;\n  }\n\n  // =========\n  // SYNTHESIS\n  // =========\n\n  protected synthesizeAttributes(): { [name: string]: any } {\n    return {\n      assignment_type: cdktn.stringToTerraform(this._assignmentType),\n      duration: cdktn.stringToTerraform(this._duration),\n      expiration_date: cdktn.stringToTerraform(this._expirationDate),\n      group_id: cdktn.stringToTerraform(this._groupId),\n      id: cdktn.stringToTerraform(this._id),\n      justification: cdktn.stringToTerraform(this._justification),\n      permanent_assignment: cdktn.booleanToTerraform(this._permanentAssignment),\n      principal_id: cdktn.stringToTerraform(this._principalId),\n      start_date: cdktn.stringToTerraform(this._startDate),\n      ticket_number: cdktn.stringToTerraform(this._ticketNumber),\n      ticket_system: cdktn.stringToTerraform(this._ticketSystem),\n      timeouts: privilegedAccessGroupEligibilityScheduleTimeoutsToTerraform(this._timeouts.internalValue),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      assignment_type: {\n        value: cdktn.stringToHclTerraform(this._assignmentType),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      duration: {\n        value: cdktn.stringToHclTerraform(this._duration),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      expiration_date: {\n        value: cdktn.stringToHclTerraform(this._expirationDate),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      group_id: {\n        value: cdktn.stringToHclTerraform(this._groupId),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      id: {\n        value: cdktn.stringToHclTerraform(this._id),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      justification: {\n        value: cdktn.stringToHclTerraform(this._justification),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      permanent_assignment: {\n        value: cdktn.booleanToHclTerraform(this._permanentAssignment),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"boolean\",\n      },\n      principal_id: {\n        value: cdktn.stringToHclTerraform(this._principalId),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      start_date: {\n        value: cdktn.stringToHclTerraform(this._startDate),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      ticket_number: {\n        value: cdktn.stringToHclTerraform(this._ticketNumber),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      ticket_system: {\n        value: cdktn.stringToHclTerraform(this._ticketSystem),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      timeouts: {\n        value: privilegedAccessGroupEligibilityScheduleTimeoutsToHclTerraform(this._timeouts.internalValue),\n        isBlock: true,\n        type: \"struct\",\n        storageClassType: \"PrivilegedAccessGroupEligibilityScheduleTimeouts\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}