@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.
- package/.jsii +112042 -0
- package/LICENSE +355 -0
- package/README.md +94 -0
- package/lib/access-package/index.d.ts +151 -0
- package/lib/access-package/index.js +354 -0
- package/lib/access-package-assignment-policy/index.d.ts +1098 -0
- package/lib/access-package-assignment-policy/index.js +2711 -0
- package/lib/access-package-catalog/index.d.ts +152 -0
- package/lib/access-package-catalog/index.js +357 -0
- package/lib/access-package-catalog-role-assignment/index.d.ts +140 -0
- package/lib/access-package-catalog-role-assignment/index.js +333 -0
- package/lib/access-package-resource-catalog-association/index.d.ts +131 -0
- package/lib/access-package-resource-catalog-association/index.js +307 -0
- package/lib/access-package-resource-package-association/index.d.ts +132 -0
- package/lib/access-package-resource-package-association/index.js +310 -0
- package/lib/administrative-unit/index.d.ts +165 -0
- package/lib/administrative-unit/index.js +385 -0
- package/lib/administrative-unit-member/index.d.ts +123 -0
- package/lib/administrative-unit-member/index.js +295 -0
- package/lib/administrative-unit-role-member/index.d.ts +131 -0
- package/lib/administrative-unit-role-member/index.js +307 -0
- package/lib/app-role-assignment/index.d.ts +134 -0
- package/lib/app-role-assignment/index.js +319 -0
- package/lib/application/index.d.ts +1352 -0
- package/lib/application/index.js +3262 -0
- package/lib/application-api-access/index.d.ts +152 -0
- package/lib/application-api-access/index.js +357 -0
- package/lib/application-app-role/index.d.ts +171 -0
- package/lib/application-app-role/index.js +390 -0
- package/lib/application-certificate/index.d.ts +196 -0
- package/lib/application-certificate/index.js +441 -0
- package/lib/application-fallback-public-client/index.d.ts +122 -0
- package/lib/application-fallback-public-client/index.js +292 -0
- package/lib/application-federated-identity-credential/index.d.ts +172 -0
- package/lib/application-federated-identity-credential/index.js +394 -0
- package/lib/application-flexible-federated-identity-credential/index.d.ts +172 -0
- package/lib/application-flexible-federated-identity-credential/index.js +394 -0
- package/lib/application-from-template/index.d.ts +134 -0
- package/lib/application-from-template/index.js +334 -0
- package/lib/application-identifier-uri/index.d.ts +121 -0
- package/lib/application-identifier-uri/index.js +289 -0
- package/lib/application-known-clients/index.d.ts +130 -0
- package/lib/application-known-clients/index.js +315 -0
- package/lib/application-optional-claims/index.d.ts +381 -0
- package/lib/application-optional-claims/index.js +918 -0
- package/lib/application-owner/index.d.ts +121 -0
- package/lib/application-owner/index.js +289 -0
- package/lib/application-password/index.d.ts +185 -0
- package/lib/application-password/index.js +410 -0
- package/lib/application-permission-scope/index.d.ts +193 -0
- package/lib/application-permission-scope/index.js +432 -0
- package/lib/application-pre-authorized/index.d.ts +140 -0
- package/lib/application-pre-authorized/index.js +333 -0
- package/lib/application-redirect-uris/index.d.ts +140 -0
- package/lib/application-redirect-uris/index.js +333 -0
- package/lib/application-registration/index.d.ts +278 -0
- package/lib/application-registration/index.js +610 -0
- package/lib/authentication-strength-policy/index.d.ts +141 -0
- package/lib/authentication-strength-policy/index.js +336 -0
- package/lib/claims-mapping-policy/index.d.ts +130 -0
- package/lib/claims-mapping-policy/index.js +315 -0
- package/lib/conditional-access-policy/index.d.ts +959 -0
- package/lib/conditional-access-policy/index.js +2705 -0
- package/lib/custom-directory-role/index.d.ts +216 -0
- package/lib/custom-directory-role/index.js +505 -0
- package/lib/data-azuread-access-package/index.d.ts +118 -0
- package/lib/data-azuread-access-package/index.js +272 -0
- package/lib/data-azuread-access-package-catalog/index.d.ts +108 -0
- package/lib/data-azuread-access-package-catalog/index.js +258 -0
- package/lib/data-azuread-access-package-catalog-role/index.d.ts +107 -0
- package/lib/data-azuread-access-package-catalog-role/index.js +254 -0
- package/lib/data-azuread-administrative-unit/index.d.ts +135 -0
- package/lib/data-azuread-administrative-unit/index.js +336 -0
- package/lib/data-azuread-application/index.d.ts +654 -0
- package/lib/data-azuread-application/index.js +1606 -0
- package/lib/data-azuread-application-published-app-ids/index.d.ts +85 -0
- package/lib/data-azuread-application-published-app-ids/index.js +206 -0
- package/lib/data-azuread-application-template/index.d.ts +111 -0
- package/lib/data-azuread-application-template/index.js +270 -0
- package/lib/data-azuread-client-config/index.d.ts +86 -0
- package/lib/data-azuread-client-config/index.js +216 -0
- package/lib/data-azuread-directory-object/index.d.ts +94 -0
- package/lib/data-azuread-directory-object/index.js +223 -0
- package/lib/data-azuread-directory-role-templates/index.d.ts +120 -0
- package/lib/data-azuread-directory-role-templates/index.js +293 -0
- package/lib/data-azuread-directory-roles/index.d.ts +122 -0
- package/lib/data-azuread-directory-roles/index.js +301 -0
- package/lib/data-azuread-domains/index.d.ts +190 -0
- package/lib/data-azuread-domains/index.js +435 -0
- package/lib/data-azuread-group/index.d.ts +207 -0
- package/lib/data-azuread-group/index.js +506 -0
- package/lib/data-azuread-group-role-management-policy/index.d.ts +105 -0
- package/lib/data-azuread-group-role-management-policy/index.js +248 -0
- package/lib/data-azuread-groups/index.d.ts +160 -0
- package/lib/data-azuread-groups/index.js +348 -0
- package/lib/data-azuread-named-location/index.d.ts +163 -0
- package/lib/data-azuread-named-location/index.js +398 -0
- package/lib/data-azuread-service-principal/index.d.ts +325 -0
- package/lib/data-azuread-service-principal/index.js +817 -0
- package/lib/data-azuread-service-principals/index.d.ts +183 -0
- package/lib/data-azuread-service-principals/index.js +430 -0
- package/lib/data-azuread-user/index.d.ts +177 -0
- package/lib/data-azuread-user/index.js +465 -0
- package/lib/data-azuread-users/index.d.ts +204 -0
- package/lib/data-azuread-users/index.js +468 -0
- package/lib/directory-role/index.d.ts +125 -0
- package/lib/directory-role/index.js +306 -0
- package/lib/directory-role-assignment/index.d.ts +143 -0
- package/lib/directory-role-assignment/index.js +331 -0
- package/lib/directory-role-eligibility-schedule-request/index.d.ts +141 -0
- package/lib/directory-role-eligibility-schedule-request/index.js +325 -0
- package/lib/directory-role-member/index.d.ts +123 -0
- package/lib/directory-role-member/index.js +295 -0
- package/lib/group/index.d.ts +392 -0
- package/lib/group/index.js +872 -0
- package/lib/group-member/index.d.ts +121 -0
- package/lib/group-member/index.js +289 -0
- package/lib/group-role-management-policy/index.d.ts +1043 -0
- package/lib/group-role-management-policy/index.js +2775 -0
- package/lib/group-without-members/index.d.ts +381 -0
- package/lib/group-without-members/index.js +851 -0
- package/lib/index.d.ts +79 -0
- package/lib/index.js +85 -0
- package/lib/invitation/index.d.ts +203 -0
- package/lib/invitation/index.js +490 -0
- package/lib/lazy-index.d.ts +4 -0
- package/lib/lazy-index.js +82 -0
- package/lib/named-location/index.d.ts +212 -0
- package/lib/named-location/index.js +571 -0
- package/lib/privileged-access-group-assignment-schedule/index.d.ts +218 -0
- package/lib/privileged-access-group-assignment-schedule/index.js +484 -0
- package/lib/privileged-access-group-eligibility-schedule/index.d.ts +218 -0
- package/lib/privileged-access-group-eligibility-schedule/index.js +484 -0
- package/lib/provider/index.d.ts +289 -0
- package/lib/provider/index.js +549 -0
- package/lib/service-principal/index.d.ts +547 -0
- package/lib/service-principal/index.js +1305 -0
- package/lib/service-principal-certificate/index.d.ts +187 -0
- package/lib/service-principal-certificate/index.js +415 -0
- package/lib/service-principal-claims-mapping-policy-assignment/index.d.ts +121 -0
- package/lib/service-principal-claims-mapping-policy-assignment/index.js +289 -0
- package/lib/service-principal-delegated-permission-grant/index.d.ts +151 -0
- package/lib/service-principal-delegated-permission-grant/index.js +354 -0
- package/lib/service-principal-password/index.d.ts +176 -0
- package/lib/service-principal-password/index.js +384 -0
- package/lib/service-principal-token-signing-certificate/index.d.ts +137 -0
- package/lib/service-principal-token-signing-certificate/index.js +329 -0
- package/lib/synchronization-job/index.d.ts +177 -0
- package/lib/synchronization-job/index.js +424 -0
- package/lib/synchronization-job-provision-on-demand/index.d.ts +254 -0
- package/lib/synchronization-job-provision-on-demand/index.js +590 -0
- package/lib/synchronization-secret/index.d.ts +184 -0
- package/lib/synchronization-secret/index.js +449 -0
- package/lib/user/index.d.ts +517 -0
- package/lib/user/index.js +1084 -0
- package/lib/user-flow-attribute/index.d.ts +141 -0
- package/lib/user-flow-attribute/index.js +340 -0
- package/package.json +155 -0
|
@@ -0,0 +1,2705 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.ConditionalAccessPolicy = exports.ConditionalAccessPolicyTimeoutsOutputReference = exports.ConditionalAccessPolicySessionControlsOutputReference = exports.ConditionalAccessPolicyGrantControlsOutputReference = exports.ConditionalAccessPolicyConditionsOutputReference = exports.ConditionalAccessPolicyConditionsUsersOutputReference = exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList = exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference = exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList = exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference = exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList = exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference = exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList = exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference = exports.ConditionalAccessPolicyConditionsPlatformsOutputReference = exports.ConditionalAccessPolicyConditionsLocationsOutputReference = exports.ConditionalAccessPolicyConditionsDevicesOutputReference = exports.ConditionalAccessPolicyConditionsDevicesFilterOutputReference = exports.ConditionalAccessPolicyConditionsClientApplicationsOutputReference = exports.ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference = exports.ConditionalAccessPolicyConditionsApplicationsOutputReference = void 0;
|
|
5
|
+
exports.conditionalAccessPolicyConditionsApplicationsToTerraform = conditionalAccessPolicyConditionsApplicationsToTerraform;
|
|
6
|
+
exports.conditionalAccessPolicyConditionsApplicationsToHclTerraform = conditionalAccessPolicyConditionsApplicationsToHclTerraform;
|
|
7
|
+
exports.conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform = conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform;
|
|
8
|
+
exports.conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform = conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform;
|
|
9
|
+
exports.conditionalAccessPolicyConditionsClientApplicationsToTerraform = conditionalAccessPolicyConditionsClientApplicationsToTerraform;
|
|
10
|
+
exports.conditionalAccessPolicyConditionsClientApplicationsToHclTerraform = conditionalAccessPolicyConditionsClientApplicationsToHclTerraform;
|
|
11
|
+
exports.conditionalAccessPolicyConditionsDevicesFilterToTerraform = conditionalAccessPolicyConditionsDevicesFilterToTerraform;
|
|
12
|
+
exports.conditionalAccessPolicyConditionsDevicesFilterToHclTerraform = conditionalAccessPolicyConditionsDevicesFilterToHclTerraform;
|
|
13
|
+
exports.conditionalAccessPolicyConditionsDevicesToTerraform = conditionalAccessPolicyConditionsDevicesToTerraform;
|
|
14
|
+
exports.conditionalAccessPolicyConditionsDevicesToHclTerraform = conditionalAccessPolicyConditionsDevicesToHclTerraform;
|
|
15
|
+
exports.conditionalAccessPolicyConditionsLocationsToTerraform = conditionalAccessPolicyConditionsLocationsToTerraform;
|
|
16
|
+
exports.conditionalAccessPolicyConditionsLocationsToHclTerraform = conditionalAccessPolicyConditionsLocationsToHclTerraform;
|
|
17
|
+
exports.conditionalAccessPolicyConditionsPlatformsToTerraform = conditionalAccessPolicyConditionsPlatformsToTerraform;
|
|
18
|
+
exports.conditionalAccessPolicyConditionsPlatformsToHclTerraform = conditionalAccessPolicyConditionsPlatformsToHclTerraform;
|
|
19
|
+
exports.conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform = conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform;
|
|
20
|
+
exports.conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform = conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform;
|
|
21
|
+
exports.conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform = conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform;
|
|
22
|
+
exports.conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform = conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform;
|
|
23
|
+
exports.conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform = conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform;
|
|
24
|
+
exports.conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform = conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform;
|
|
25
|
+
exports.conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform = conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform;
|
|
26
|
+
exports.conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform = conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform;
|
|
27
|
+
exports.conditionalAccessPolicyConditionsUsersToTerraform = conditionalAccessPolicyConditionsUsersToTerraform;
|
|
28
|
+
exports.conditionalAccessPolicyConditionsUsersToHclTerraform = conditionalAccessPolicyConditionsUsersToHclTerraform;
|
|
29
|
+
exports.conditionalAccessPolicyConditionsToTerraform = conditionalAccessPolicyConditionsToTerraform;
|
|
30
|
+
exports.conditionalAccessPolicyConditionsToHclTerraform = conditionalAccessPolicyConditionsToHclTerraform;
|
|
31
|
+
exports.conditionalAccessPolicyGrantControlsToTerraform = conditionalAccessPolicyGrantControlsToTerraform;
|
|
32
|
+
exports.conditionalAccessPolicyGrantControlsToHclTerraform = conditionalAccessPolicyGrantControlsToHclTerraform;
|
|
33
|
+
exports.conditionalAccessPolicySessionControlsToTerraform = conditionalAccessPolicySessionControlsToTerraform;
|
|
34
|
+
exports.conditionalAccessPolicySessionControlsToHclTerraform = conditionalAccessPolicySessionControlsToHclTerraform;
|
|
35
|
+
exports.conditionalAccessPolicyTimeoutsToTerraform = conditionalAccessPolicyTimeoutsToTerraform;
|
|
36
|
+
exports.conditionalAccessPolicyTimeoutsToHclTerraform = conditionalAccessPolicyTimeoutsToHclTerraform;
|
|
37
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
38
|
+
const cdktn = require("cdktn");
|
|
39
|
+
function conditionalAccessPolicyConditionsApplicationsToTerraform(struct) {
|
|
40
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
41
|
+
return struct;
|
|
42
|
+
}
|
|
43
|
+
if (cdktn.isComplexElement(struct)) {
|
|
44
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
45
|
+
}
|
|
46
|
+
return {
|
|
47
|
+
excluded_applications: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedApplications),
|
|
48
|
+
included_applications: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedApplications),
|
|
49
|
+
included_user_actions: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedUserActions),
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
function conditionalAccessPolicyConditionsApplicationsToHclTerraform(struct) {
|
|
53
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
54
|
+
return struct;
|
|
55
|
+
}
|
|
56
|
+
if (cdktn.isComplexElement(struct)) {
|
|
57
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
58
|
+
}
|
|
59
|
+
const attrs = {
|
|
60
|
+
excluded_applications: {
|
|
61
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedApplications),
|
|
62
|
+
isBlock: false,
|
|
63
|
+
type: "list",
|
|
64
|
+
storageClassType: "stringList",
|
|
65
|
+
},
|
|
66
|
+
included_applications: {
|
|
67
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedApplications),
|
|
68
|
+
isBlock: false,
|
|
69
|
+
type: "list",
|
|
70
|
+
storageClassType: "stringList",
|
|
71
|
+
},
|
|
72
|
+
included_user_actions: {
|
|
73
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedUserActions),
|
|
74
|
+
isBlock: false,
|
|
75
|
+
type: "list",
|
|
76
|
+
storageClassType: "stringList",
|
|
77
|
+
},
|
|
78
|
+
};
|
|
79
|
+
// remove undefined attributes
|
|
80
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
81
|
+
}
|
|
82
|
+
class ConditionalAccessPolicyConditionsApplicationsOutputReference extends cdktn.ComplexObject {
|
|
83
|
+
/**
|
|
84
|
+
* @param terraformResource The parent resource
|
|
85
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
86
|
+
*/
|
|
87
|
+
constructor(terraformResource, terraformAttribute) {
|
|
88
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
89
|
+
this.isEmptyObject = false;
|
|
90
|
+
}
|
|
91
|
+
get internalValue() {
|
|
92
|
+
let hasAnyValues = this.isEmptyObject;
|
|
93
|
+
const internalValueResult = {};
|
|
94
|
+
if (this._excludedApplications !== undefined) {
|
|
95
|
+
hasAnyValues = true;
|
|
96
|
+
internalValueResult.excludedApplications = this._excludedApplications;
|
|
97
|
+
}
|
|
98
|
+
if (this._includedApplications !== undefined) {
|
|
99
|
+
hasAnyValues = true;
|
|
100
|
+
internalValueResult.includedApplications = this._includedApplications;
|
|
101
|
+
}
|
|
102
|
+
if (this._includedUserActions !== undefined) {
|
|
103
|
+
hasAnyValues = true;
|
|
104
|
+
internalValueResult.includedUserActions = this._includedUserActions;
|
|
105
|
+
}
|
|
106
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
107
|
+
}
|
|
108
|
+
set internalValue(value) {
|
|
109
|
+
if (value === undefined) {
|
|
110
|
+
this.isEmptyObject = false;
|
|
111
|
+
this._excludedApplications = undefined;
|
|
112
|
+
this._includedApplications = undefined;
|
|
113
|
+
this._includedUserActions = undefined;
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
117
|
+
this._excludedApplications = value.excludedApplications;
|
|
118
|
+
this._includedApplications = value.includedApplications;
|
|
119
|
+
this._includedUserActions = value.includedUserActions;
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
get excludedApplications() {
|
|
123
|
+
return this.getListAttribute('excluded_applications');
|
|
124
|
+
}
|
|
125
|
+
set excludedApplications(value) {
|
|
126
|
+
this._excludedApplications = value;
|
|
127
|
+
}
|
|
128
|
+
resetExcludedApplications() {
|
|
129
|
+
this._excludedApplications = undefined;
|
|
130
|
+
}
|
|
131
|
+
// Temporarily expose input value. Use with caution.
|
|
132
|
+
get excludedApplicationsInput() {
|
|
133
|
+
return this._excludedApplications;
|
|
134
|
+
}
|
|
135
|
+
get includedApplications() {
|
|
136
|
+
return this.getListAttribute('included_applications');
|
|
137
|
+
}
|
|
138
|
+
set includedApplications(value) {
|
|
139
|
+
this._includedApplications = value;
|
|
140
|
+
}
|
|
141
|
+
resetIncludedApplications() {
|
|
142
|
+
this._includedApplications = undefined;
|
|
143
|
+
}
|
|
144
|
+
// Temporarily expose input value. Use with caution.
|
|
145
|
+
get includedApplicationsInput() {
|
|
146
|
+
return this._includedApplications;
|
|
147
|
+
}
|
|
148
|
+
get includedUserActions() {
|
|
149
|
+
return this.getListAttribute('included_user_actions');
|
|
150
|
+
}
|
|
151
|
+
set includedUserActions(value) {
|
|
152
|
+
this._includedUserActions = value;
|
|
153
|
+
}
|
|
154
|
+
resetIncludedUserActions() {
|
|
155
|
+
this._includedUserActions = undefined;
|
|
156
|
+
}
|
|
157
|
+
// Temporarily expose input value. Use with caution.
|
|
158
|
+
get includedUserActionsInput() {
|
|
159
|
+
return this._includedUserActions;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
exports.ConditionalAccessPolicyConditionsApplicationsOutputReference = ConditionalAccessPolicyConditionsApplicationsOutputReference;
|
|
163
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
164
|
+
ConditionalAccessPolicyConditionsApplicationsOutputReference[_a] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsApplicationsOutputReference", version: "15.0.0" };
|
|
165
|
+
function conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform(struct) {
|
|
166
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
167
|
+
return struct;
|
|
168
|
+
}
|
|
169
|
+
if (cdktn.isComplexElement(struct)) {
|
|
170
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
171
|
+
}
|
|
172
|
+
return {
|
|
173
|
+
mode: cdktn.stringToTerraform(struct.mode),
|
|
174
|
+
rule: cdktn.stringToTerraform(struct.rule),
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
function conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform(struct) {
|
|
178
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
179
|
+
return struct;
|
|
180
|
+
}
|
|
181
|
+
if (cdktn.isComplexElement(struct)) {
|
|
182
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
183
|
+
}
|
|
184
|
+
const attrs = {
|
|
185
|
+
mode: {
|
|
186
|
+
value: cdktn.stringToHclTerraform(struct.mode),
|
|
187
|
+
isBlock: false,
|
|
188
|
+
type: "simple",
|
|
189
|
+
storageClassType: "string",
|
|
190
|
+
},
|
|
191
|
+
rule: {
|
|
192
|
+
value: cdktn.stringToHclTerraform(struct.rule),
|
|
193
|
+
isBlock: false,
|
|
194
|
+
type: "simple",
|
|
195
|
+
storageClassType: "string",
|
|
196
|
+
},
|
|
197
|
+
};
|
|
198
|
+
// remove undefined attributes
|
|
199
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
200
|
+
}
|
|
201
|
+
class ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference extends cdktn.ComplexObject {
|
|
202
|
+
/**
|
|
203
|
+
* @param terraformResource The parent resource
|
|
204
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
205
|
+
*/
|
|
206
|
+
constructor(terraformResource, terraformAttribute) {
|
|
207
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
208
|
+
this.isEmptyObject = false;
|
|
209
|
+
}
|
|
210
|
+
get internalValue() {
|
|
211
|
+
let hasAnyValues = this.isEmptyObject;
|
|
212
|
+
const internalValueResult = {};
|
|
213
|
+
if (this._mode !== undefined) {
|
|
214
|
+
hasAnyValues = true;
|
|
215
|
+
internalValueResult.mode = this._mode;
|
|
216
|
+
}
|
|
217
|
+
if (this._rule !== undefined) {
|
|
218
|
+
hasAnyValues = true;
|
|
219
|
+
internalValueResult.rule = this._rule;
|
|
220
|
+
}
|
|
221
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
222
|
+
}
|
|
223
|
+
set internalValue(value) {
|
|
224
|
+
if (value === undefined) {
|
|
225
|
+
this.isEmptyObject = false;
|
|
226
|
+
this._mode = undefined;
|
|
227
|
+
this._rule = undefined;
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
231
|
+
this._mode = value.mode;
|
|
232
|
+
this._rule = value.rule;
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
get mode() {
|
|
236
|
+
return this.getStringAttribute('mode');
|
|
237
|
+
}
|
|
238
|
+
set mode(value) {
|
|
239
|
+
this._mode = value;
|
|
240
|
+
}
|
|
241
|
+
// Temporarily expose input value. Use with caution.
|
|
242
|
+
get modeInput() {
|
|
243
|
+
return this._mode;
|
|
244
|
+
}
|
|
245
|
+
get rule() {
|
|
246
|
+
return this.getStringAttribute('rule');
|
|
247
|
+
}
|
|
248
|
+
set rule(value) {
|
|
249
|
+
this._rule = value;
|
|
250
|
+
}
|
|
251
|
+
// Temporarily expose input value. Use with caution.
|
|
252
|
+
get ruleInput() {
|
|
253
|
+
return this._rule;
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
exports.ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference = ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference;
|
|
257
|
+
_b = JSII_RTTI_SYMBOL_1;
|
|
258
|
+
ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference[_b] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference", version: "15.0.0" };
|
|
259
|
+
function conditionalAccessPolicyConditionsClientApplicationsToTerraform(struct) {
|
|
260
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
261
|
+
return struct;
|
|
262
|
+
}
|
|
263
|
+
if (cdktn.isComplexElement(struct)) {
|
|
264
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
265
|
+
}
|
|
266
|
+
return {
|
|
267
|
+
excluded_service_principals: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedServicePrincipals),
|
|
268
|
+
included_service_principals: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedServicePrincipals),
|
|
269
|
+
filter: conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform(struct.filter),
|
|
270
|
+
};
|
|
271
|
+
}
|
|
272
|
+
function conditionalAccessPolicyConditionsClientApplicationsToHclTerraform(struct) {
|
|
273
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
274
|
+
return struct;
|
|
275
|
+
}
|
|
276
|
+
if (cdktn.isComplexElement(struct)) {
|
|
277
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
278
|
+
}
|
|
279
|
+
const attrs = {
|
|
280
|
+
excluded_service_principals: {
|
|
281
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedServicePrincipals),
|
|
282
|
+
isBlock: false,
|
|
283
|
+
type: "list",
|
|
284
|
+
storageClassType: "stringList",
|
|
285
|
+
},
|
|
286
|
+
included_service_principals: {
|
|
287
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedServicePrincipals),
|
|
288
|
+
isBlock: false,
|
|
289
|
+
type: "list",
|
|
290
|
+
storageClassType: "stringList",
|
|
291
|
+
},
|
|
292
|
+
filter: {
|
|
293
|
+
value: conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform(struct.filter),
|
|
294
|
+
isBlock: true,
|
|
295
|
+
type: "list",
|
|
296
|
+
storageClassType: "ConditionalAccessPolicyConditionsClientApplicationsFilterList",
|
|
297
|
+
},
|
|
298
|
+
};
|
|
299
|
+
// remove undefined attributes
|
|
300
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
301
|
+
}
|
|
302
|
+
class ConditionalAccessPolicyConditionsClientApplicationsOutputReference extends cdktn.ComplexObject {
|
|
303
|
+
/**
|
|
304
|
+
* @param terraformResource The parent resource
|
|
305
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
306
|
+
*/
|
|
307
|
+
constructor(terraformResource, terraformAttribute) {
|
|
308
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
309
|
+
this.isEmptyObject = false;
|
|
310
|
+
// filter - computed: false, optional: true, required: false
|
|
311
|
+
this._filter = new ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference(this, "filter");
|
|
312
|
+
}
|
|
313
|
+
get internalValue() {
|
|
314
|
+
let hasAnyValues = this.isEmptyObject;
|
|
315
|
+
const internalValueResult = {};
|
|
316
|
+
if (this._excludedServicePrincipals !== undefined) {
|
|
317
|
+
hasAnyValues = true;
|
|
318
|
+
internalValueResult.excludedServicePrincipals = this._excludedServicePrincipals;
|
|
319
|
+
}
|
|
320
|
+
if (this._includedServicePrincipals !== undefined) {
|
|
321
|
+
hasAnyValues = true;
|
|
322
|
+
internalValueResult.includedServicePrincipals = this._includedServicePrincipals;
|
|
323
|
+
}
|
|
324
|
+
if (this._filter?.internalValue !== undefined) {
|
|
325
|
+
hasAnyValues = true;
|
|
326
|
+
internalValueResult.filter = this._filter?.internalValue;
|
|
327
|
+
}
|
|
328
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
329
|
+
}
|
|
330
|
+
set internalValue(value) {
|
|
331
|
+
if (value === undefined) {
|
|
332
|
+
this.isEmptyObject = false;
|
|
333
|
+
this._excludedServicePrincipals = undefined;
|
|
334
|
+
this._includedServicePrincipals = undefined;
|
|
335
|
+
this._filter.internalValue = undefined;
|
|
336
|
+
}
|
|
337
|
+
else {
|
|
338
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
339
|
+
this._excludedServicePrincipals = value.excludedServicePrincipals;
|
|
340
|
+
this._includedServicePrincipals = value.includedServicePrincipals;
|
|
341
|
+
this._filter.internalValue = value.filter;
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
get excludedServicePrincipals() {
|
|
345
|
+
return this.getListAttribute('excluded_service_principals');
|
|
346
|
+
}
|
|
347
|
+
set excludedServicePrincipals(value) {
|
|
348
|
+
this._excludedServicePrincipals = value;
|
|
349
|
+
}
|
|
350
|
+
resetExcludedServicePrincipals() {
|
|
351
|
+
this._excludedServicePrincipals = undefined;
|
|
352
|
+
}
|
|
353
|
+
// Temporarily expose input value. Use with caution.
|
|
354
|
+
get excludedServicePrincipalsInput() {
|
|
355
|
+
return this._excludedServicePrincipals;
|
|
356
|
+
}
|
|
357
|
+
get includedServicePrincipals() {
|
|
358
|
+
return this.getListAttribute('included_service_principals');
|
|
359
|
+
}
|
|
360
|
+
set includedServicePrincipals(value) {
|
|
361
|
+
this._includedServicePrincipals = value;
|
|
362
|
+
}
|
|
363
|
+
resetIncludedServicePrincipals() {
|
|
364
|
+
this._includedServicePrincipals = undefined;
|
|
365
|
+
}
|
|
366
|
+
// Temporarily expose input value. Use with caution.
|
|
367
|
+
get includedServicePrincipalsInput() {
|
|
368
|
+
return this._includedServicePrincipals;
|
|
369
|
+
}
|
|
370
|
+
get filter() {
|
|
371
|
+
return this._filter;
|
|
372
|
+
}
|
|
373
|
+
putFilter(value) {
|
|
374
|
+
this._filter.internalValue = value;
|
|
375
|
+
}
|
|
376
|
+
resetFilter() {
|
|
377
|
+
this._filter.internalValue = undefined;
|
|
378
|
+
}
|
|
379
|
+
// Temporarily expose input value. Use with caution.
|
|
380
|
+
get filterInput() {
|
|
381
|
+
return this._filter.internalValue;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
exports.ConditionalAccessPolicyConditionsClientApplicationsOutputReference = ConditionalAccessPolicyConditionsClientApplicationsOutputReference;
|
|
385
|
+
_c = JSII_RTTI_SYMBOL_1;
|
|
386
|
+
ConditionalAccessPolicyConditionsClientApplicationsOutputReference[_c] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsClientApplicationsOutputReference", version: "15.0.0" };
|
|
387
|
+
function conditionalAccessPolicyConditionsDevicesFilterToTerraform(struct) {
|
|
388
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
389
|
+
return struct;
|
|
390
|
+
}
|
|
391
|
+
if (cdktn.isComplexElement(struct)) {
|
|
392
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
393
|
+
}
|
|
394
|
+
return {
|
|
395
|
+
mode: cdktn.stringToTerraform(struct.mode),
|
|
396
|
+
rule: cdktn.stringToTerraform(struct.rule),
|
|
397
|
+
};
|
|
398
|
+
}
|
|
399
|
+
function conditionalAccessPolicyConditionsDevicesFilterToHclTerraform(struct) {
|
|
400
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
401
|
+
return struct;
|
|
402
|
+
}
|
|
403
|
+
if (cdktn.isComplexElement(struct)) {
|
|
404
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
405
|
+
}
|
|
406
|
+
const attrs = {
|
|
407
|
+
mode: {
|
|
408
|
+
value: cdktn.stringToHclTerraform(struct.mode),
|
|
409
|
+
isBlock: false,
|
|
410
|
+
type: "simple",
|
|
411
|
+
storageClassType: "string",
|
|
412
|
+
},
|
|
413
|
+
rule: {
|
|
414
|
+
value: cdktn.stringToHclTerraform(struct.rule),
|
|
415
|
+
isBlock: false,
|
|
416
|
+
type: "simple",
|
|
417
|
+
storageClassType: "string",
|
|
418
|
+
},
|
|
419
|
+
};
|
|
420
|
+
// remove undefined attributes
|
|
421
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
422
|
+
}
|
|
423
|
+
class ConditionalAccessPolicyConditionsDevicesFilterOutputReference extends cdktn.ComplexObject {
|
|
424
|
+
/**
|
|
425
|
+
* @param terraformResource The parent resource
|
|
426
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
427
|
+
*/
|
|
428
|
+
constructor(terraformResource, terraformAttribute) {
|
|
429
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
430
|
+
this.isEmptyObject = false;
|
|
431
|
+
}
|
|
432
|
+
get internalValue() {
|
|
433
|
+
let hasAnyValues = this.isEmptyObject;
|
|
434
|
+
const internalValueResult = {};
|
|
435
|
+
if (this._mode !== undefined) {
|
|
436
|
+
hasAnyValues = true;
|
|
437
|
+
internalValueResult.mode = this._mode;
|
|
438
|
+
}
|
|
439
|
+
if (this._rule !== undefined) {
|
|
440
|
+
hasAnyValues = true;
|
|
441
|
+
internalValueResult.rule = this._rule;
|
|
442
|
+
}
|
|
443
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
444
|
+
}
|
|
445
|
+
set internalValue(value) {
|
|
446
|
+
if (value === undefined) {
|
|
447
|
+
this.isEmptyObject = false;
|
|
448
|
+
this._mode = undefined;
|
|
449
|
+
this._rule = undefined;
|
|
450
|
+
}
|
|
451
|
+
else {
|
|
452
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
453
|
+
this._mode = value.mode;
|
|
454
|
+
this._rule = value.rule;
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
get mode() {
|
|
458
|
+
return this.getStringAttribute('mode');
|
|
459
|
+
}
|
|
460
|
+
set mode(value) {
|
|
461
|
+
this._mode = value;
|
|
462
|
+
}
|
|
463
|
+
// Temporarily expose input value. Use with caution.
|
|
464
|
+
get modeInput() {
|
|
465
|
+
return this._mode;
|
|
466
|
+
}
|
|
467
|
+
get rule() {
|
|
468
|
+
return this.getStringAttribute('rule');
|
|
469
|
+
}
|
|
470
|
+
set rule(value) {
|
|
471
|
+
this._rule = value;
|
|
472
|
+
}
|
|
473
|
+
// Temporarily expose input value. Use with caution.
|
|
474
|
+
get ruleInput() {
|
|
475
|
+
return this._rule;
|
|
476
|
+
}
|
|
477
|
+
}
|
|
478
|
+
exports.ConditionalAccessPolicyConditionsDevicesFilterOutputReference = ConditionalAccessPolicyConditionsDevicesFilterOutputReference;
|
|
479
|
+
_d = JSII_RTTI_SYMBOL_1;
|
|
480
|
+
ConditionalAccessPolicyConditionsDevicesFilterOutputReference[_d] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsDevicesFilterOutputReference", version: "15.0.0" };
|
|
481
|
+
function conditionalAccessPolicyConditionsDevicesToTerraform(struct) {
|
|
482
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
483
|
+
return struct;
|
|
484
|
+
}
|
|
485
|
+
if (cdktn.isComplexElement(struct)) {
|
|
486
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
487
|
+
}
|
|
488
|
+
return {
|
|
489
|
+
filter: conditionalAccessPolicyConditionsDevicesFilterToTerraform(struct.filter),
|
|
490
|
+
};
|
|
491
|
+
}
|
|
492
|
+
function conditionalAccessPolicyConditionsDevicesToHclTerraform(struct) {
|
|
493
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
494
|
+
return struct;
|
|
495
|
+
}
|
|
496
|
+
if (cdktn.isComplexElement(struct)) {
|
|
497
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
498
|
+
}
|
|
499
|
+
const attrs = {
|
|
500
|
+
filter: {
|
|
501
|
+
value: conditionalAccessPolicyConditionsDevicesFilterToHclTerraform(struct.filter),
|
|
502
|
+
isBlock: true,
|
|
503
|
+
type: "list",
|
|
504
|
+
storageClassType: "ConditionalAccessPolicyConditionsDevicesFilterList",
|
|
505
|
+
},
|
|
506
|
+
};
|
|
507
|
+
// remove undefined attributes
|
|
508
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
509
|
+
}
|
|
510
|
+
class ConditionalAccessPolicyConditionsDevicesOutputReference extends cdktn.ComplexObject {
|
|
511
|
+
/**
|
|
512
|
+
* @param terraformResource The parent resource
|
|
513
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
514
|
+
*/
|
|
515
|
+
constructor(terraformResource, terraformAttribute) {
|
|
516
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
517
|
+
this.isEmptyObject = false;
|
|
518
|
+
// filter - computed: false, optional: true, required: false
|
|
519
|
+
this._filter = new ConditionalAccessPolicyConditionsDevicesFilterOutputReference(this, "filter");
|
|
520
|
+
}
|
|
521
|
+
get internalValue() {
|
|
522
|
+
let hasAnyValues = this.isEmptyObject;
|
|
523
|
+
const internalValueResult = {};
|
|
524
|
+
if (this._filter?.internalValue !== undefined) {
|
|
525
|
+
hasAnyValues = true;
|
|
526
|
+
internalValueResult.filter = this._filter?.internalValue;
|
|
527
|
+
}
|
|
528
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
529
|
+
}
|
|
530
|
+
set internalValue(value) {
|
|
531
|
+
if (value === undefined) {
|
|
532
|
+
this.isEmptyObject = false;
|
|
533
|
+
this._filter.internalValue = undefined;
|
|
534
|
+
}
|
|
535
|
+
else {
|
|
536
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
537
|
+
this._filter.internalValue = value.filter;
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
get filter() {
|
|
541
|
+
return this._filter;
|
|
542
|
+
}
|
|
543
|
+
putFilter(value) {
|
|
544
|
+
this._filter.internalValue = value;
|
|
545
|
+
}
|
|
546
|
+
resetFilter() {
|
|
547
|
+
this._filter.internalValue = undefined;
|
|
548
|
+
}
|
|
549
|
+
// Temporarily expose input value. Use with caution.
|
|
550
|
+
get filterInput() {
|
|
551
|
+
return this._filter.internalValue;
|
|
552
|
+
}
|
|
553
|
+
}
|
|
554
|
+
exports.ConditionalAccessPolicyConditionsDevicesOutputReference = ConditionalAccessPolicyConditionsDevicesOutputReference;
|
|
555
|
+
_e = JSII_RTTI_SYMBOL_1;
|
|
556
|
+
ConditionalAccessPolicyConditionsDevicesOutputReference[_e] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsDevicesOutputReference", version: "15.0.0" };
|
|
557
|
+
function conditionalAccessPolicyConditionsLocationsToTerraform(struct) {
|
|
558
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
559
|
+
return struct;
|
|
560
|
+
}
|
|
561
|
+
if (cdktn.isComplexElement(struct)) {
|
|
562
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
563
|
+
}
|
|
564
|
+
return {
|
|
565
|
+
excluded_locations: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedLocations),
|
|
566
|
+
included_locations: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedLocations),
|
|
567
|
+
};
|
|
568
|
+
}
|
|
569
|
+
function conditionalAccessPolicyConditionsLocationsToHclTerraform(struct) {
|
|
570
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
571
|
+
return struct;
|
|
572
|
+
}
|
|
573
|
+
if (cdktn.isComplexElement(struct)) {
|
|
574
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
575
|
+
}
|
|
576
|
+
const attrs = {
|
|
577
|
+
excluded_locations: {
|
|
578
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedLocations),
|
|
579
|
+
isBlock: false,
|
|
580
|
+
type: "list",
|
|
581
|
+
storageClassType: "stringList",
|
|
582
|
+
},
|
|
583
|
+
included_locations: {
|
|
584
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedLocations),
|
|
585
|
+
isBlock: false,
|
|
586
|
+
type: "list",
|
|
587
|
+
storageClassType: "stringList",
|
|
588
|
+
},
|
|
589
|
+
};
|
|
590
|
+
// remove undefined attributes
|
|
591
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
592
|
+
}
|
|
593
|
+
class ConditionalAccessPolicyConditionsLocationsOutputReference extends cdktn.ComplexObject {
|
|
594
|
+
/**
|
|
595
|
+
* @param terraformResource The parent resource
|
|
596
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
597
|
+
*/
|
|
598
|
+
constructor(terraformResource, terraformAttribute) {
|
|
599
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
600
|
+
this.isEmptyObject = false;
|
|
601
|
+
}
|
|
602
|
+
get internalValue() {
|
|
603
|
+
let hasAnyValues = this.isEmptyObject;
|
|
604
|
+
const internalValueResult = {};
|
|
605
|
+
if (this._excludedLocations !== undefined) {
|
|
606
|
+
hasAnyValues = true;
|
|
607
|
+
internalValueResult.excludedLocations = this._excludedLocations;
|
|
608
|
+
}
|
|
609
|
+
if (this._includedLocations !== undefined) {
|
|
610
|
+
hasAnyValues = true;
|
|
611
|
+
internalValueResult.includedLocations = this._includedLocations;
|
|
612
|
+
}
|
|
613
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
614
|
+
}
|
|
615
|
+
set internalValue(value) {
|
|
616
|
+
if (value === undefined) {
|
|
617
|
+
this.isEmptyObject = false;
|
|
618
|
+
this._excludedLocations = undefined;
|
|
619
|
+
this._includedLocations = undefined;
|
|
620
|
+
}
|
|
621
|
+
else {
|
|
622
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
623
|
+
this._excludedLocations = value.excludedLocations;
|
|
624
|
+
this._includedLocations = value.includedLocations;
|
|
625
|
+
}
|
|
626
|
+
}
|
|
627
|
+
get excludedLocations() {
|
|
628
|
+
return this.getListAttribute('excluded_locations');
|
|
629
|
+
}
|
|
630
|
+
set excludedLocations(value) {
|
|
631
|
+
this._excludedLocations = value;
|
|
632
|
+
}
|
|
633
|
+
resetExcludedLocations() {
|
|
634
|
+
this._excludedLocations = undefined;
|
|
635
|
+
}
|
|
636
|
+
// Temporarily expose input value. Use with caution.
|
|
637
|
+
get excludedLocationsInput() {
|
|
638
|
+
return this._excludedLocations;
|
|
639
|
+
}
|
|
640
|
+
get includedLocations() {
|
|
641
|
+
return this.getListAttribute('included_locations');
|
|
642
|
+
}
|
|
643
|
+
set includedLocations(value) {
|
|
644
|
+
this._includedLocations = value;
|
|
645
|
+
}
|
|
646
|
+
// Temporarily expose input value. Use with caution.
|
|
647
|
+
get includedLocationsInput() {
|
|
648
|
+
return this._includedLocations;
|
|
649
|
+
}
|
|
650
|
+
}
|
|
651
|
+
exports.ConditionalAccessPolicyConditionsLocationsOutputReference = ConditionalAccessPolicyConditionsLocationsOutputReference;
|
|
652
|
+
_f = JSII_RTTI_SYMBOL_1;
|
|
653
|
+
ConditionalAccessPolicyConditionsLocationsOutputReference[_f] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsLocationsOutputReference", version: "15.0.0" };
|
|
654
|
+
function conditionalAccessPolicyConditionsPlatformsToTerraform(struct) {
|
|
655
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
656
|
+
return struct;
|
|
657
|
+
}
|
|
658
|
+
if (cdktn.isComplexElement(struct)) {
|
|
659
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
660
|
+
}
|
|
661
|
+
return {
|
|
662
|
+
excluded_platforms: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedPlatforms),
|
|
663
|
+
included_platforms: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedPlatforms),
|
|
664
|
+
};
|
|
665
|
+
}
|
|
666
|
+
function conditionalAccessPolicyConditionsPlatformsToHclTerraform(struct) {
|
|
667
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
668
|
+
return struct;
|
|
669
|
+
}
|
|
670
|
+
if (cdktn.isComplexElement(struct)) {
|
|
671
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
672
|
+
}
|
|
673
|
+
const attrs = {
|
|
674
|
+
excluded_platforms: {
|
|
675
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedPlatforms),
|
|
676
|
+
isBlock: false,
|
|
677
|
+
type: "list",
|
|
678
|
+
storageClassType: "stringList",
|
|
679
|
+
},
|
|
680
|
+
included_platforms: {
|
|
681
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedPlatforms),
|
|
682
|
+
isBlock: false,
|
|
683
|
+
type: "list",
|
|
684
|
+
storageClassType: "stringList",
|
|
685
|
+
},
|
|
686
|
+
};
|
|
687
|
+
// remove undefined attributes
|
|
688
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
689
|
+
}
|
|
690
|
+
class ConditionalAccessPolicyConditionsPlatformsOutputReference extends cdktn.ComplexObject {
|
|
691
|
+
/**
|
|
692
|
+
* @param terraformResource The parent resource
|
|
693
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
694
|
+
*/
|
|
695
|
+
constructor(terraformResource, terraformAttribute) {
|
|
696
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
697
|
+
this.isEmptyObject = false;
|
|
698
|
+
}
|
|
699
|
+
get internalValue() {
|
|
700
|
+
let hasAnyValues = this.isEmptyObject;
|
|
701
|
+
const internalValueResult = {};
|
|
702
|
+
if (this._excludedPlatforms !== undefined) {
|
|
703
|
+
hasAnyValues = true;
|
|
704
|
+
internalValueResult.excludedPlatforms = this._excludedPlatforms;
|
|
705
|
+
}
|
|
706
|
+
if (this._includedPlatforms !== undefined) {
|
|
707
|
+
hasAnyValues = true;
|
|
708
|
+
internalValueResult.includedPlatforms = this._includedPlatforms;
|
|
709
|
+
}
|
|
710
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
711
|
+
}
|
|
712
|
+
set internalValue(value) {
|
|
713
|
+
if (value === undefined) {
|
|
714
|
+
this.isEmptyObject = false;
|
|
715
|
+
this._excludedPlatforms = undefined;
|
|
716
|
+
this._includedPlatforms = undefined;
|
|
717
|
+
}
|
|
718
|
+
else {
|
|
719
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
720
|
+
this._excludedPlatforms = value.excludedPlatforms;
|
|
721
|
+
this._includedPlatforms = value.includedPlatforms;
|
|
722
|
+
}
|
|
723
|
+
}
|
|
724
|
+
get excludedPlatforms() {
|
|
725
|
+
return this.getListAttribute('excluded_platforms');
|
|
726
|
+
}
|
|
727
|
+
set excludedPlatforms(value) {
|
|
728
|
+
this._excludedPlatforms = value;
|
|
729
|
+
}
|
|
730
|
+
resetExcludedPlatforms() {
|
|
731
|
+
this._excludedPlatforms = undefined;
|
|
732
|
+
}
|
|
733
|
+
// Temporarily expose input value. Use with caution.
|
|
734
|
+
get excludedPlatformsInput() {
|
|
735
|
+
return this._excludedPlatforms;
|
|
736
|
+
}
|
|
737
|
+
get includedPlatforms() {
|
|
738
|
+
return this.getListAttribute('included_platforms');
|
|
739
|
+
}
|
|
740
|
+
set includedPlatforms(value) {
|
|
741
|
+
this._includedPlatforms = value;
|
|
742
|
+
}
|
|
743
|
+
// Temporarily expose input value. Use with caution.
|
|
744
|
+
get includedPlatformsInput() {
|
|
745
|
+
return this._includedPlatforms;
|
|
746
|
+
}
|
|
747
|
+
}
|
|
748
|
+
exports.ConditionalAccessPolicyConditionsPlatformsOutputReference = ConditionalAccessPolicyConditionsPlatformsOutputReference;
|
|
749
|
+
_g = JSII_RTTI_SYMBOL_1;
|
|
750
|
+
ConditionalAccessPolicyConditionsPlatformsOutputReference[_g] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsPlatformsOutputReference", version: "15.0.0" };
|
|
751
|
+
function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform(struct) {
|
|
752
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
753
|
+
return struct;
|
|
754
|
+
}
|
|
755
|
+
if (cdktn.isComplexElement(struct)) {
|
|
756
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
757
|
+
}
|
|
758
|
+
return {
|
|
759
|
+
members: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.members),
|
|
760
|
+
membership_kind: cdktn.stringToTerraform(struct.membershipKind),
|
|
761
|
+
};
|
|
762
|
+
}
|
|
763
|
+
function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform(struct) {
|
|
764
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
765
|
+
return struct;
|
|
766
|
+
}
|
|
767
|
+
if (cdktn.isComplexElement(struct)) {
|
|
768
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
769
|
+
}
|
|
770
|
+
const attrs = {
|
|
771
|
+
members: {
|
|
772
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.members),
|
|
773
|
+
isBlock: false,
|
|
774
|
+
type: "list",
|
|
775
|
+
storageClassType: "stringList",
|
|
776
|
+
},
|
|
777
|
+
membership_kind: {
|
|
778
|
+
value: cdktn.stringToHclTerraform(struct.membershipKind),
|
|
779
|
+
isBlock: false,
|
|
780
|
+
type: "simple",
|
|
781
|
+
storageClassType: "string",
|
|
782
|
+
},
|
|
783
|
+
};
|
|
784
|
+
// remove undefined attributes
|
|
785
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
786
|
+
}
|
|
787
|
+
class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference extends cdktn.ComplexObject {
|
|
788
|
+
/**
|
|
789
|
+
* @param terraformResource The parent resource
|
|
790
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
791
|
+
* @param complexObjectIndex the index of this item in the list
|
|
792
|
+
* @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
793
|
+
*/
|
|
794
|
+
constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
|
|
795
|
+
super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
|
|
796
|
+
this.isEmptyObject = false;
|
|
797
|
+
}
|
|
798
|
+
get internalValue() {
|
|
799
|
+
if (this.resolvableValue) {
|
|
800
|
+
return this.resolvableValue;
|
|
801
|
+
}
|
|
802
|
+
let hasAnyValues = this.isEmptyObject;
|
|
803
|
+
const internalValueResult = {};
|
|
804
|
+
if (this._members !== undefined) {
|
|
805
|
+
hasAnyValues = true;
|
|
806
|
+
internalValueResult.members = this._members;
|
|
807
|
+
}
|
|
808
|
+
if (this._membershipKind !== undefined) {
|
|
809
|
+
hasAnyValues = true;
|
|
810
|
+
internalValueResult.membershipKind = this._membershipKind;
|
|
811
|
+
}
|
|
812
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
813
|
+
}
|
|
814
|
+
set internalValue(value) {
|
|
815
|
+
if (value === undefined) {
|
|
816
|
+
this.isEmptyObject = false;
|
|
817
|
+
this.resolvableValue = undefined;
|
|
818
|
+
this._members = undefined;
|
|
819
|
+
this._membershipKind = undefined;
|
|
820
|
+
}
|
|
821
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
822
|
+
this.isEmptyObject = false;
|
|
823
|
+
this.resolvableValue = value;
|
|
824
|
+
}
|
|
825
|
+
else {
|
|
826
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
827
|
+
this.resolvableValue = undefined;
|
|
828
|
+
this._members = value.members;
|
|
829
|
+
this._membershipKind = value.membershipKind;
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
get members() {
|
|
833
|
+
return this.getListAttribute('members');
|
|
834
|
+
}
|
|
835
|
+
set members(value) {
|
|
836
|
+
this._members = value;
|
|
837
|
+
}
|
|
838
|
+
resetMembers() {
|
|
839
|
+
this._members = undefined;
|
|
840
|
+
}
|
|
841
|
+
// Temporarily expose input value. Use with caution.
|
|
842
|
+
get membersInput() {
|
|
843
|
+
return this._members;
|
|
844
|
+
}
|
|
845
|
+
get membershipKind() {
|
|
846
|
+
return this.getStringAttribute('membership_kind');
|
|
847
|
+
}
|
|
848
|
+
set membershipKind(value) {
|
|
849
|
+
this._membershipKind = value;
|
|
850
|
+
}
|
|
851
|
+
// Temporarily expose input value. Use with caution.
|
|
852
|
+
get membershipKindInput() {
|
|
853
|
+
return this._membershipKind;
|
|
854
|
+
}
|
|
855
|
+
}
|
|
856
|
+
exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference = ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference;
|
|
857
|
+
_h = JSII_RTTI_SYMBOL_1;
|
|
858
|
+
ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference[_h] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference", version: "15.0.0" };
|
|
859
|
+
class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList extends cdktn.ComplexList {
|
|
860
|
+
/**
|
|
861
|
+
* @param terraformResource The parent resource
|
|
862
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
863
|
+
* @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
864
|
+
*/
|
|
865
|
+
constructor(terraformResource, terraformAttribute, wrapsSet) {
|
|
866
|
+
super(terraformResource, terraformAttribute, wrapsSet);
|
|
867
|
+
this.terraformResource = terraformResource;
|
|
868
|
+
this.terraformAttribute = terraformAttribute;
|
|
869
|
+
this.wrapsSet = wrapsSet;
|
|
870
|
+
}
|
|
871
|
+
/**
|
|
872
|
+
* @param index the index of the item to return
|
|
873
|
+
*/
|
|
874
|
+
get(index) {
|
|
875
|
+
return new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
|
|
876
|
+
}
|
|
877
|
+
}
|
|
878
|
+
exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList = ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList;
|
|
879
|
+
_j = JSII_RTTI_SYMBOL_1;
|
|
880
|
+
ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList[_j] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList", version: "15.0.0" };
|
|
881
|
+
function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform(struct) {
|
|
882
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
883
|
+
return struct;
|
|
884
|
+
}
|
|
885
|
+
if (cdktn.isComplexElement(struct)) {
|
|
886
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
887
|
+
}
|
|
888
|
+
return {
|
|
889
|
+
guest_or_external_user_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.guestOrExternalUserTypes),
|
|
890
|
+
external_tenants: cdktn.listMapper(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform, true)(struct.externalTenants),
|
|
891
|
+
};
|
|
892
|
+
}
|
|
893
|
+
function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform(struct) {
|
|
894
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
895
|
+
return struct;
|
|
896
|
+
}
|
|
897
|
+
if (cdktn.isComplexElement(struct)) {
|
|
898
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
899
|
+
}
|
|
900
|
+
const attrs = {
|
|
901
|
+
guest_or_external_user_types: {
|
|
902
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.guestOrExternalUserTypes),
|
|
903
|
+
isBlock: false,
|
|
904
|
+
type: "list",
|
|
905
|
+
storageClassType: "stringList",
|
|
906
|
+
},
|
|
907
|
+
external_tenants: {
|
|
908
|
+
value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform, true)(struct.externalTenants),
|
|
909
|
+
isBlock: true,
|
|
910
|
+
type: "list",
|
|
911
|
+
storageClassType: "ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList",
|
|
912
|
+
},
|
|
913
|
+
};
|
|
914
|
+
// remove undefined attributes
|
|
915
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
916
|
+
}
|
|
917
|
+
class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference extends cdktn.ComplexObject {
|
|
918
|
+
/**
|
|
919
|
+
* @param terraformResource The parent resource
|
|
920
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
921
|
+
* @param complexObjectIndex the index of this item in the list
|
|
922
|
+
* @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
923
|
+
*/
|
|
924
|
+
constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
|
|
925
|
+
super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
|
|
926
|
+
this.isEmptyObject = false;
|
|
927
|
+
// external_tenants - computed: false, optional: true, required: false
|
|
928
|
+
this._externalTenants = new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList(this, "external_tenants", false);
|
|
929
|
+
}
|
|
930
|
+
get internalValue() {
|
|
931
|
+
if (this.resolvableValue) {
|
|
932
|
+
return this.resolvableValue;
|
|
933
|
+
}
|
|
934
|
+
let hasAnyValues = this.isEmptyObject;
|
|
935
|
+
const internalValueResult = {};
|
|
936
|
+
if (this._guestOrExternalUserTypes !== undefined) {
|
|
937
|
+
hasAnyValues = true;
|
|
938
|
+
internalValueResult.guestOrExternalUserTypes = this._guestOrExternalUserTypes;
|
|
939
|
+
}
|
|
940
|
+
if (this._externalTenants?.internalValue !== undefined) {
|
|
941
|
+
hasAnyValues = true;
|
|
942
|
+
internalValueResult.externalTenants = this._externalTenants?.internalValue;
|
|
943
|
+
}
|
|
944
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
945
|
+
}
|
|
946
|
+
set internalValue(value) {
|
|
947
|
+
if (value === undefined) {
|
|
948
|
+
this.isEmptyObject = false;
|
|
949
|
+
this.resolvableValue = undefined;
|
|
950
|
+
this._guestOrExternalUserTypes = undefined;
|
|
951
|
+
this._externalTenants.internalValue = undefined;
|
|
952
|
+
}
|
|
953
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
954
|
+
this.isEmptyObject = false;
|
|
955
|
+
this.resolvableValue = value;
|
|
956
|
+
}
|
|
957
|
+
else {
|
|
958
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
959
|
+
this.resolvableValue = undefined;
|
|
960
|
+
this._guestOrExternalUserTypes = value.guestOrExternalUserTypes;
|
|
961
|
+
this._externalTenants.internalValue = value.externalTenants;
|
|
962
|
+
}
|
|
963
|
+
}
|
|
964
|
+
get guestOrExternalUserTypes() {
|
|
965
|
+
return this.getListAttribute('guest_or_external_user_types');
|
|
966
|
+
}
|
|
967
|
+
set guestOrExternalUserTypes(value) {
|
|
968
|
+
this._guestOrExternalUserTypes = value;
|
|
969
|
+
}
|
|
970
|
+
// Temporarily expose input value. Use with caution.
|
|
971
|
+
get guestOrExternalUserTypesInput() {
|
|
972
|
+
return this._guestOrExternalUserTypes;
|
|
973
|
+
}
|
|
974
|
+
get externalTenants() {
|
|
975
|
+
return this._externalTenants;
|
|
976
|
+
}
|
|
977
|
+
putExternalTenants(value) {
|
|
978
|
+
this._externalTenants.internalValue = value;
|
|
979
|
+
}
|
|
980
|
+
resetExternalTenants() {
|
|
981
|
+
this._externalTenants.internalValue = undefined;
|
|
982
|
+
}
|
|
983
|
+
// Temporarily expose input value. Use with caution.
|
|
984
|
+
get externalTenantsInput() {
|
|
985
|
+
return this._externalTenants.internalValue;
|
|
986
|
+
}
|
|
987
|
+
}
|
|
988
|
+
exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference = ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference;
|
|
989
|
+
_k = JSII_RTTI_SYMBOL_1;
|
|
990
|
+
ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference[_k] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference", version: "15.0.0" };
|
|
991
|
+
class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList extends cdktn.ComplexList {
|
|
992
|
+
/**
|
|
993
|
+
* @param terraformResource The parent resource
|
|
994
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
995
|
+
* @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
996
|
+
*/
|
|
997
|
+
constructor(terraformResource, terraformAttribute, wrapsSet) {
|
|
998
|
+
super(terraformResource, terraformAttribute, wrapsSet);
|
|
999
|
+
this.terraformResource = terraformResource;
|
|
1000
|
+
this.terraformAttribute = terraformAttribute;
|
|
1001
|
+
this.wrapsSet = wrapsSet;
|
|
1002
|
+
}
|
|
1003
|
+
/**
|
|
1004
|
+
* @param index the index of the item to return
|
|
1005
|
+
*/
|
|
1006
|
+
get(index) {
|
|
1007
|
+
return new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
|
|
1008
|
+
}
|
|
1009
|
+
}
|
|
1010
|
+
exports.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList = ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList;
|
|
1011
|
+
_l = JSII_RTTI_SYMBOL_1;
|
|
1012
|
+
ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList[_l] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList", version: "15.0.0" };
|
|
1013
|
+
function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform(struct) {
|
|
1014
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1015
|
+
return struct;
|
|
1016
|
+
}
|
|
1017
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1018
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1019
|
+
}
|
|
1020
|
+
return {
|
|
1021
|
+
members: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.members),
|
|
1022
|
+
membership_kind: cdktn.stringToTerraform(struct.membershipKind),
|
|
1023
|
+
};
|
|
1024
|
+
}
|
|
1025
|
+
function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform(struct) {
|
|
1026
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1027
|
+
return struct;
|
|
1028
|
+
}
|
|
1029
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1030
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1031
|
+
}
|
|
1032
|
+
const attrs = {
|
|
1033
|
+
members: {
|
|
1034
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.members),
|
|
1035
|
+
isBlock: false,
|
|
1036
|
+
type: "list",
|
|
1037
|
+
storageClassType: "stringList",
|
|
1038
|
+
},
|
|
1039
|
+
membership_kind: {
|
|
1040
|
+
value: cdktn.stringToHclTerraform(struct.membershipKind),
|
|
1041
|
+
isBlock: false,
|
|
1042
|
+
type: "simple",
|
|
1043
|
+
storageClassType: "string",
|
|
1044
|
+
},
|
|
1045
|
+
};
|
|
1046
|
+
// remove undefined attributes
|
|
1047
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
1048
|
+
}
|
|
1049
|
+
class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference extends cdktn.ComplexObject {
|
|
1050
|
+
/**
|
|
1051
|
+
* @param terraformResource The parent resource
|
|
1052
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1053
|
+
* @param complexObjectIndex the index of this item in the list
|
|
1054
|
+
* @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
1055
|
+
*/
|
|
1056
|
+
constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
|
|
1057
|
+
super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
|
|
1058
|
+
this.isEmptyObject = false;
|
|
1059
|
+
}
|
|
1060
|
+
get internalValue() {
|
|
1061
|
+
if (this.resolvableValue) {
|
|
1062
|
+
return this.resolvableValue;
|
|
1063
|
+
}
|
|
1064
|
+
let hasAnyValues = this.isEmptyObject;
|
|
1065
|
+
const internalValueResult = {};
|
|
1066
|
+
if (this._members !== undefined) {
|
|
1067
|
+
hasAnyValues = true;
|
|
1068
|
+
internalValueResult.members = this._members;
|
|
1069
|
+
}
|
|
1070
|
+
if (this._membershipKind !== undefined) {
|
|
1071
|
+
hasAnyValues = true;
|
|
1072
|
+
internalValueResult.membershipKind = this._membershipKind;
|
|
1073
|
+
}
|
|
1074
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
1075
|
+
}
|
|
1076
|
+
set internalValue(value) {
|
|
1077
|
+
if (value === undefined) {
|
|
1078
|
+
this.isEmptyObject = false;
|
|
1079
|
+
this.resolvableValue = undefined;
|
|
1080
|
+
this._members = undefined;
|
|
1081
|
+
this._membershipKind = undefined;
|
|
1082
|
+
}
|
|
1083
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
1084
|
+
this.isEmptyObject = false;
|
|
1085
|
+
this.resolvableValue = value;
|
|
1086
|
+
}
|
|
1087
|
+
else {
|
|
1088
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
1089
|
+
this.resolvableValue = undefined;
|
|
1090
|
+
this._members = value.members;
|
|
1091
|
+
this._membershipKind = value.membershipKind;
|
|
1092
|
+
}
|
|
1093
|
+
}
|
|
1094
|
+
get members() {
|
|
1095
|
+
return this.getListAttribute('members');
|
|
1096
|
+
}
|
|
1097
|
+
set members(value) {
|
|
1098
|
+
this._members = value;
|
|
1099
|
+
}
|
|
1100
|
+
resetMembers() {
|
|
1101
|
+
this._members = undefined;
|
|
1102
|
+
}
|
|
1103
|
+
// Temporarily expose input value. Use with caution.
|
|
1104
|
+
get membersInput() {
|
|
1105
|
+
return this._members;
|
|
1106
|
+
}
|
|
1107
|
+
get membershipKind() {
|
|
1108
|
+
return this.getStringAttribute('membership_kind');
|
|
1109
|
+
}
|
|
1110
|
+
set membershipKind(value) {
|
|
1111
|
+
this._membershipKind = value;
|
|
1112
|
+
}
|
|
1113
|
+
// Temporarily expose input value. Use with caution.
|
|
1114
|
+
get membershipKindInput() {
|
|
1115
|
+
return this._membershipKind;
|
|
1116
|
+
}
|
|
1117
|
+
}
|
|
1118
|
+
exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference = ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference;
|
|
1119
|
+
_m = JSII_RTTI_SYMBOL_1;
|
|
1120
|
+
ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference[_m] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference", version: "15.0.0" };
|
|
1121
|
+
class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList extends cdktn.ComplexList {
|
|
1122
|
+
/**
|
|
1123
|
+
* @param terraformResource The parent resource
|
|
1124
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1125
|
+
* @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
1126
|
+
*/
|
|
1127
|
+
constructor(terraformResource, terraformAttribute, wrapsSet) {
|
|
1128
|
+
super(terraformResource, terraformAttribute, wrapsSet);
|
|
1129
|
+
this.terraformResource = terraformResource;
|
|
1130
|
+
this.terraformAttribute = terraformAttribute;
|
|
1131
|
+
this.wrapsSet = wrapsSet;
|
|
1132
|
+
}
|
|
1133
|
+
/**
|
|
1134
|
+
* @param index the index of the item to return
|
|
1135
|
+
*/
|
|
1136
|
+
get(index) {
|
|
1137
|
+
return new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
|
|
1138
|
+
}
|
|
1139
|
+
}
|
|
1140
|
+
exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList = ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList;
|
|
1141
|
+
_o = JSII_RTTI_SYMBOL_1;
|
|
1142
|
+
ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList[_o] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList", version: "15.0.0" };
|
|
1143
|
+
function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform(struct) {
|
|
1144
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1145
|
+
return struct;
|
|
1146
|
+
}
|
|
1147
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1148
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1149
|
+
}
|
|
1150
|
+
return {
|
|
1151
|
+
guest_or_external_user_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.guestOrExternalUserTypes),
|
|
1152
|
+
external_tenants: cdktn.listMapper(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform, true)(struct.externalTenants),
|
|
1153
|
+
};
|
|
1154
|
+
}
|
|
1155
|
+
function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform(struct) {
|
|
1156
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1157
|
+
return struct;
|
|
1158
|
+
}
|
|
1159
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1160
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1161
|
+
}
|
|
1162
|
+
const attrs = {
|
|
1163
|
+
guest_or_external_user_types: {
|
|
1164
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.guestOrExternalUserTypes),
|
|
1165
|
+
isBlock: false,
|
|
1166
|
+
type: "list",
|
|
1167
|
+
storageClassType: "stringList",
|
|
1168
|
+
},
|
|
1169
|
+
external_tenants: {
|
|
1170
|
+
value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform, true)(struct.externalTenants),
|
|
1171
|
+
isBlock: true,
|
|
1172
|
+
type: "list",
|
|
1173
|
+
storageClassType: "ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList",
|
|
1174
|
+
},
|
|
1175
|
+
};
|
|
1176
|
+
// remove undefined attributes
|
|
1177
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
1178
|
+
}
|
|
1179
|
+
class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference extends cdktn.ComplexObject {
|
|
1180
|
+
/**
|
|
1181
|
+
* @param terraformResource The parent resource
|
|
1182
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1183
|
+
* @param complexObjectIndex the index of this item in the list
|
|
1184
|
+
* @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
1185
|
+
*/
|
|
1186
|
+
constructor(terraformResource, terraformAttribute, complexObjectIndex, complexObjectIsFromSet) {
|
|
1187
|
+
super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);
|
|
1188
|
+
this.isEmptyObject = false;
|
|
1189
|
+
// external_tenants - computed: false, optional: true, required: false
|
|
1190
|
+
this._externalTenants = new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList(this, "external_tenants", false);
|
|
1191
|
+
}
|
|
1192
|
+
get internalValue() {
|
|
1193
|
+
if (this.resolvableValue) {
|
|
1194
|
+
return this.resolvableValue;
|
|
1195
|
+
}
|
|
1196
|
+
let hasAnyValues = this.isEmptyObject;
|
|
1197
|
+
const internalValueResult = {};
|
|
1198
|
+
if (this._guestOrExternalUserTypes !== undefined) {
|
|
1199
|
+
hasAnyValues = true;
|
|
1200
|
+
internalValueResult.guestOrExternalUserTypes = this._guestOrExternalUserTypes;
|
|
1201
|
+
}
|
|
1202
|
+
if (this._externalTenants?.internalValue !== undefined) {
|
|
1203
|
+
hasAnyValues = true;
|
|
1204
|
+
internalValueResult.externalTenants = this._externalTenants?.internalValue;
|
|
1205
|
+
}
|
|
1206
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
1207
|
+
}
|
|
1208
|
+
set internalValue(value) {
|
|
1209
|
+
if (value === undefined) {
|
|
1210
|
+
this.isEmptyObject = false;
|
|
1211
|
+
this.resolvableValue = undefined;
|
|
1212
|
+
this._guestOrExternalUserTypes = undefined;
|
|
1213
|
+
this._externalTenants.internalValue = undefined;
|
|
1214
|
+
}
|
|
1215
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
1216
|
+
this.isEmptyObject = false;
|
|
1217
|
+
this.resolvableValue = value;
|
|
1218
|
+
}
|
|
1219
|
+
else {
|
|
1220
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
1221
|
+
this.resolvableValue = undefined;
|
|
1222
|
+
this._guestOrExternalUserTypes = value.guestOrExternalUserTypes;
|
|
1223
|
+
this._externalTenants.internalValue = value.externalTenants;
|
|
1224
|
+
}
|
|
1225
|
+
}
|
|
1226
|
+
get guestOrExternalUserTypes() {
|
|
1227
|
+
return this.getListAttribute('guest_or_external_user_types');
|
|
1228
|
+
}
|
|
1229
|
+
set guestOrExternalUserTypes(value) {
|
|
1230
|
+
this._guestOrExternalUserTypes = value;
|
|
1231
|
+
}
|
|
1232
|
+
// Temporarily expose input value. Use with caution.
|
|
1233
|
+
get guestOrExternalUserTypesInput() {
|
|
1234
|
+
return this._guestOrExternalUserTypes;
|
|
1235
|
+
}
|
|
1236
|
+
get externalTenants() {
|
|
1237
|
+
return this._externalTenants;
|
|
1238
|
+
}
|
|
1239
|
+
putExternalTenants(value) {
|
|
1240
|
+
this._externalTenants.internalValue = value;
|
|
1241
|
+
}
|
|
1242
|
+
resetExternalTenants() {
|
|
1243
|
+
this._externalTenants.internalValue = undefined;
|
|
1244
|
+
}
|
|
1245
|
+
// Temporarily expose input value. Use with caution.
|
|
1246
|
+
get externalTenantsInput() {
|
|
1247
|
+
return this._externalTenants.internalValue;
|
|
1248
|
+
}
|
|
1249
|
+
}
|
|
1250
|
+
exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference = ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference;
|
|
1251
|
+
_p = JSII_RTTI_SYMBOL_1;
|
|
1252
|
+
ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference[_p] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference", version: "15.0.0" };
|
|
1253
|
+
class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList extends cdktn.ComplexList {
|
|
1254
|
+
/**
|
|
1255
|
+
* @param terraformResource The parent resource
|
|
1256
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1257
|
+
* @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)
|
|
1258
|
+
*/
|
|
1259
|
+
constructor(terraformResource, terraformAttribute, wrapsSet) {
|
|
1260
|
+
super(terraformResource, terraformAttribute, wrapsSet);
|
|
1261
|
+
this.terraformResource = terraformResource;
|
|
1262
|
+
this.terraformAttribute = terraformAttribute;
|
|
1263
|
+
this.wrapsSet = wrapsSet;
|
|
1264
|
+
}
|
|
1265
|
+
/**
|
|
1266
|
+
* @param index the index of the item to return
|
|
1267
|
+
*/
|
|
1268
|
+
get(index) {
|
|
1269
|
+
return new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);
|
|
1270
|
+
}
|
|
1271
|
+
}
|
|
1272
|
+
exports.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList = ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList;
|
|
1273
|
+
_q = JSII_RTTI_SYMBOL_1;
|
|
1274
|
+
ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList[_q] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList", version: "15.0.0" };
|
|
1275
|
+
function conditionalAccessPolicyConditionsUsersToTerraform(struct) {
|
|
1276
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1277
|
+
return struct;
|
|
1278
|
+
}
|
|
1279
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1280
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1281
|
+
}
|
|
1282
|
+
return {
|
|
1283
|
+
excluded_groups: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedGroups),
|
|
1284
|
+
excluded_roles: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedRoles),
|
|
1285
|
+
excluded_users: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.excludedUsers),
|
|
1286
|
+
included_groups: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedGroups),
|
|
1287
|
+
included_roles: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedRoles),
|
|
1288
|
+
included_users: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.includedUsers),
|
|
1289
|
+
excluded_guests_or_external_users: cdktn.listMapper(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform, true)(struct.excludedGuestsOrExternalUsers),
|
|
1290
|
+
included_guests_or_external_users: cdktn.listMapper(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform, true)(struct.includedGuestsOrExternalUsers),
|
|
1291
|
+
};
|
|
1292
|
+
}
|
|
1293
|
+
function conditionalAccessPolicyConditionsUsersToHclTerraform(struct) {
|
|
1294
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1295
|
+
return struct;
|
|
1296
|
+
}
|
|
1297
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1298
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1299
|
+
}
|
|
1300
|
+
const attrs = {
|
|
1301
|
+
excluded_groups: {
|
|
1302
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedGroups),
|
|
1303
|
+
isBlock: false,
|
|
1304
|
+
type: "list",
|
|
1305
|
+
storageClassType: "stringList",
|
|
1306
|
+
},
|
|
1307
|
+
excluded_roles: {
|
|
1308
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedRoles),
|
|
1309
|
+
isBlock: false,
|
|
1310
|
+
type: "list",
|
|
1311
|
+
storageClassType: "stringList",
|
|
1312
|
+
},
|
|
1313
|
+
excluded_users: {
|
|
1314
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.excludedUsers),
|
|
1315
|
+
isBlock: false,
|
|
1316
|
+
type: "list",
|
|
1317
|
+
storageClassType: "stringList",
|
|
1318
|
+
},
|
|
1319
|
+
included_groups: {
|
|
1320
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedGroups),
|
|
1321
|
+
isBlock: false,
|
|
1322
|
+
type: "list",
|
|
1323
|
+
storageClassType: "stringList",
|
|
1324
|
+
},
|
|
1325
|
+
included_roles: {
|
|
1326
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedRoles),
|
|
1327
|
+
isBlock: false,
|
|
1328
|
+
type: "list",
|
|
1329
|
+
storageClassType: "stringList",
|
|
1330
|
+
},
|
|
1331
|
+
included_users: {
|
|
1332
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.includedUsers),
|
|
1333
|
+
isBlock: false,
|
|
1334
|
+
type: "list",
|
|
1335
|
+
storageClassType: "stringList",
|
|
1336
|
+
},
|
|
1337
|
+
excluded_guests_or_external_users: {
|
|
1338
|
+
value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform, true)(struct.excludedGuestsOrExternalUsers),
|
|
1339
|
+
isBlock: true,
|
|
1340
|
+
type: "list",
|
|
1341
|
+
storageClassType: "ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList",
|
|
1342
|
+
},
|
|
1343
|
+
included_guests_or_external_users: {
|
|
1344
|
+
value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform, true)(struct.includedGuestsOrExternalUsers),
|
|
1345
|
+
isBlock: true,
|
|
1346
|
+
type: "list",
|
|
1347
|
+
storageClassType: "ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList",
|
|
1348
|
+
},
|
|
1349
|
+
};
|
|
1350
|
+
// remove undefined attributes
|
|
1351
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
1352
|
+
}
|
|
1353
|
+
class ConditionalAccessPolicyConditionsUsersOutputReference extends cdktn.ComplexObject {
|
|
1354
|
+
/**
|
|
1355
|
+
* @param terraformResource The parent resource
|
|
1356
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1357
|
+
*/
|
|
1358
|
+
constructor(terraformResource, terraformAttribute) {
|
|
1359
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
1360
|
+
this.isEmptyObject = false;
|
|
1361
|
+
// excluded_guests_or_external_users - computed: false, optional: true, required: false
|
|
1362
|
+
this._excludedGuestsOrExternalUsers = new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList(this, "excluded_guests_or_external_users", false);
|
|
1363
|
+
// included_guests_or_external_users - computed: false, optional: true, required: false
|
|
1364
|
+
this._includedGuestsOrExternalUsers = new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList(this, "included_guests_or_external_users", false);
|
|
1365
|
+
}
|
|
1366
|
+
get internalValue() {
|
|
1367
|
+
let hasAnyValues = this.isEmptyObject;
|
|
1368
|
+
const internalValueResult = {};
|
|
1369
|
+
if (this._excludedGroups !== undefined) {
|
|
1370
|
+
hasAnyValues = true;
|
|
1371
|
+
internalValueResult.excludedGroups = this._excludedGroups;
|
|
1372
|
+
}
|
|
1373
|
+
if (this._excludedRoles !== undefined) {
|
|
1374
|
+
hasAnyValues = true;
|
|
1375
|
+
internalValueResult.excludedRoles = this._excludedRoles;
|
|
1376
|
+
}
|
|
1377
|
+
if (this._excludedUsers !== undefined) {
|
|
1378
|
+
hasAnyValues = true;
|
|
1379
|
+
internalValueResult.excludedUsers = this._excludedUsers;
|
|
1380
|
+
}
|
|
1381
|
+
if (this._includedGroups !== undefined) {
|
|
1382
|
+
hasAnyValues = true;
|
|
1383
|
+
internalValueResult.includedGroups = this._includedGroups;
|
|
1384
|
+
}
|
|
1385
|
+
if (this._includedRoles !== undefined) {
|
|
1386
|
+
hasAnyValues = true;
|
|
1387
|
+
internalValueResult.includedRoles = this._includedRoles;
|
|
1388
|
+
}
|
|
1389
|
+
if (this._includedUsers !== undefined) {
|
|
1390
|
+
hasAnyValues = true;
|
|
1391
|
+
internalValueResult.includedUsers = this._includedUsers;
|
|
1392
|
+
}
|
|
1393
|
+
if (this._excludedGuestsOrExternalUsers?.internalValue !== undefined) {
|
|
1394
|
+
hasAnyValues = true;
|
|
1395
|
+
internalValueResult.excludedGuestsOrExternalUsers = this._excludedGuestsOrExternalUsers?.internalValue;
|
|
1396
|
+
}
|
|
1397
|
+
if (this._includedGuestsOrExternalUsers?.internalValue !== undefined) {
|
|
1398
|
+
hasAnyValues = true;
|
|
1399
|
+
internalValueResult.includedGuestsOrExternalUsers = this._includedGuestsOrExternalUsers?.internalValue;
|
|
1400
|
+
}
|
|
1401
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
1402
|
+
}
|
|
1403
|
+
set internalValue(value) {
|
|
1404
|
+
if (value === undefined) {
|
|
1405
|
+
this.isEmptyObject = false;
|
|
1406
|
+
this._excludedGroups = undefined;
|
|
1407
|
+
this._excludedRoles = undefined;
|
|
1408
|
+
this._excludedUsers = undefined;
|
|
1409
|
+
this._includedGroups = undefined;
|
|
1410
|
+
this._includedRoles = undefined;
|
|
1411
|
+
this._includedUsers = undefined;
|
|
1412
|
+
this._excludedGuestsOrExternalUsers.internalValue = undefined;
|
|
1413
|
+
this._includedGuestsOrExternalUsers.internalValue = undefined;
|
|
1414
|
+
}
|
|
1415
|
+
else {
|
|
1416
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
1417
|
+
this._excludedGroups = value.excludedGroups;
|
|
1418
|
+
this._excludedRoles = value.excludedRoles;
|
|
1419
|
+
this._excludedUsers = value.excludedUsers;
|
|
1420
|
+
this._includedGroups = value.includedGroups;
|
|
1421
|
+
this._includedRoles = value.includedRoles;
|
|
1422
|
+
this._includedUsers = value.includedUsers;
|
|
1423
|
+
this._excludedGuestsOrExternalUsers.internalValue = value.excludedGuestsOrExternalUsers;
|
|
1424
|
+
this._includedGuestsOrExternalUsers.internalValue = value.includedGuestsOrExternalUsers;
|
|
1425
|
+
}
|
|
1426
|
+
}
|
|
1427
|
+
get excludedGroups() {
|
|
1428
|
+
return this.getListAttribute('excluded_groups');
|
|
1429
|
+
}
|
|
1430
|
+
set excludedGroups(value) {
|
|
1431
|
+
this._excludedGroups = value;
|
|
1432
|
+
}
|
|
1433
|
+
resetExcludedGroups() {
|
|
1434
|
+
this._excludedGroups = undefined;
|
|
1435
|
+
}
|
|
1436
|
+
// Temporarily expose input value. Use with caution.
|
|
1437
|
+
get excludedGroupsInput() {
|
|
1438
|
+
return this._excludedGroups;
|
|
1439
|
+
}
|
|
1440
|
+
get excludedRoles() {
|
|
1441
|
+
return this.getListAttribute('excluded_roles');
|
|
1442
|
+
}
|
|
1443
|
+
set excludedRoles(value) {
|
|
1444
|
+
this._excludedRoles = value;
|
|
1445
|
+
}
|
|
1446
|
+
resetExcludedRoles() {
|
|
1447
|
+
this._excludedRoles = undefined;
|
|
1448
|
+
}
|
|
1449
|
+
// Temporarily expose input value. Use with caution.
|
|
1450
|
+
get excludedRolesInput() {
|
|
1451
|
+
return this._excludedRoles;
|
|
1452
|
+
}
|
|
1453
|
+
get excludedUsers() {
|
|
1454
|
+
return this.getListAttribute('excluded_users');
|
|
1455
|
+
}
|
|
1456
|
+
set excludedUsers(value) {
|
|
1457
|
+
this._excludedUsers = value;
|
|
1458
|
+
}
|
|
1459
|
+
resetExcludedUsers() {
|
|
1460
|
+
this._excludedUsers = undefined;
|
|
1461
|
+
}
|
|
1462
|
+
// Temporarily expose input value. Use with caution.
|
|
1463
|
+
get excludedUsersInput() {
|
|
1464
|
+
return this._excludedUsers;
|
|
1465
|
+
}
|
|
1466
|
+
get includedGroups() {
|
|
1467
|
+
return this.getListAttribute('included_groups');
|
|
1468
|
+
}
|
|
1469
|
+
set includedGroups(value) {
|
|
1470
|
+
this._includedGroups = value;
|
|
1471
|
+
}
|
|
1472
|
+
resetIncludedGroups() {
|
|
1473
|
+
this._includedGroups = undefined;
|
|
1474
|
+
}
|
|
1475
|
+
// Temporarily expose input value. Use with caution.
|
|
1476
|
+
get includedGroupsInput() {
|
|
1477
|
+
return this._includedGroups;
|
|
1478
|
+
}
|
|
1479
|
+
get includedRoles() {
|
|
1480
|
+
return this.getListAttribute('included_roles');
|
|
1481
|
+
}
|
|
1482
|
+
set includedRoles(value) {
|
|
1483
|
+
this._includedRoles = value;
|
|
1484
|
+
}
|
|
1485
|
+
resetIncludedRoles() {
|
|
1486
|
+
this._includedRoles = undefined;
|
|
1487
|
+
}
|
|
1488
|
+
// Temporarily expose input value. Use with caution.
|
|
1489
|
+
get includedRolesInput() {
|
|
1490
|
+
return this._includedRoles;
|
|
1491
|
+
}
|
|
1492
|
+
get includedUsers() {
|
|
1493
|
+
return this.getListAttribute('included_users');
|
|
1494
|
+
}
|
|
1495
|
+
set includedUsers(value) {
|
|
1496
|
+
this._includedUsers = value;
|
|
1497
|
+
}
|
|
1498
|
+
resetIncludedUsers() {
|
|
1499
|
+
this._includedUsers = undefined;
|
|
1500
|
+
}
|
|
1501
|
+
// Temporarily expose input value. Use with caution.
|
|
1502
|
+
get includedUsersInput() {
|
|
1503
|
+
return this._includedUsers;
|
|
1504
|
+
}
|
|
1505
|
+
get excludedGuestsOrExternalUsers() {
|
|
1506
|
+
return this._excludedGuestsOrExternalUsers;
|
|
1507
|
+
}
|
|
1508
|
+
putExcludedGuestsOrExternalUsers(value) {
|
|
1509
|
+
this._excludedGuestsOrExternalUsers.internalValue = value;
|
|
1510
|
+
}
|
|
1511
|
+
resetExcludedGuestsOrExternalUsers() {
|
|
1512
|
+
this._excludedGuestsOrExternalUsers.internalValue = undefined;
|
|
1513
|
+
}
|
|
1514
|
+
// Temporarily expose input value. Use with caution.
|
|
1515
|
+
get excludedGuestsOrExternalUsersInput() {
|
|
1516
|
+
return this._excludedGuestsOrExternalUsers.internalValue;
|
|
1517
|
+
}
|
|
1518
|
+
get includedGuestsOrExternalUsers() {
|
|
1519
|
+
return this._includedGuestsOrExternalUsers;
|
|
1520
|
+
}
|
|
1521
|
+
putIncludedGuestsOrExternalUsers(value) {
|
|
1522
|
+
this._includedGuestsOrExternalUsers.internalValue = value;
|
|
1523
|
+
}
|
|
1524
|
+
resetIncludedGuestsOrExternalUsers() {
|
|
1525
|
+
this._includedGuestsOrExternalUsers.internalValue = undefined;
|
|
1526
|
+
}
|
|
1527
|
+
// Temporarily expose input value. Use with caution.
|
|
1528
|
+
get includedGuestsOrExternalUsersInput() {
|
|
1529
|
+
return this._includedGuestsOrExternalUsers.internalValue;
|
|
1530
|
+
}
|
|
1531
|
+
}
|
|
1532
|
+
exports.ConditionalAccessPolicyConditionsUsersOutputReference = ConditionalAccessPolicyConditionsUsersOutputReference;
|
|
1533
|
+
_r = JSII_RTTI_SYMBOL_1;
|
|
1534
|
+
ConditionalAccessPolicyConditionsUsersOutputReference[_r] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsUsersOutputReference", version: "15.0.0" };
|
|
1535
|
+
function conditionalAccessPolicyConditionsToTerraform(struct) {
|
|
1536
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1537
|
+
return struct;
|
|
1538
|
+
}
|
|
1539
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1540
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1541
|
+
}
|
|
1542
|
+
return {
|
|
1543
|
+
authentication_flow_transfer_methods: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.authenticationFlowTransferMethods),
|
|
1544
|
+
client_app_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.clientAppTypes),
|
|
1545
|
+
insider_risk_levels: cdktn.stringToTerraform(struct.insiderRiskLevels),
|
|
1546
|
+
service_principal_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.servicePrincipalRiskLevels),
|
|
1547
|
+
sign_in_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.signInRiskLevels),
|
|
1548
|
+
user_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.userRiskLevels),
|
|
1549
|
+
applications: conditionalAccessPolicyConditionsApplicationsToTerraform(struct.applications),
|
|
1550
|
+
client_applications: conditionalAccessPolicyConditionsClientApplicationsToTerraform(struct.clientApplications),
|
|
1551
|
+
devices: conditionalAccessPolicyConditionsDevicesToTerraform(struct.devices),
|
|
1552
|
+
locations: conditionalAccessPolicyConditionsLocationsToTerraform(struct.locations),
|
|
1553
|
+
platforms: conditionalAccessPolicyConditionsPlatformsToTerraform(struct.platforms),
|
|
1554
|
+
users: conditionalAccessPolicyConditionsUsersToTerraform(struct.users),
|
|
1555
|
+
};
|
|
1556
|
+
}
|
|
1557
|
+
function conditionalAccessPolicyConditionsToHclTerraform(struct) {
|
|
1558
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1559
|
+
return struct;
|
|
1560
|
+
}
|
|
1561
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1562
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1563
|
+
}
|
|
1564
|
+
const attrs = {
|
|
1565
|
+
authentication_flow_transfer_methods: {
|
|
1566
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.authenticationFlowTransferMethods),
|
|
1567
|
+
isBlock: false,
|
|
1568
|
+
type: "set",
|
|
1569
|
+
storageClassType: "stringList",
|
|
1570
|
+
},
|
|
1571
|
+
client_app_types: {
|
|
1572
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.clientAppTypes),
|
|
1573
|
+
isBlock: false,
|
|
1574
|
+
type: "list",
|
|
1575
|
+
storageClassType: "stringList",
|
|
1576
|
+
},
|
|
1577
|
+
insider_risk_levels: {
|
|
1578
|
+
value: cdktn.stringToHclTerraform(struct.insiderRiskLevels),
|
|
1579
|
+
isBlock: false,
|
|
1580
|
+
type: "simple",
|
|
1581
|
+
storageClassType: "string",
|
|
1582
|
+
},
|
|
1583
|
+
service_principal_risk_levels: {
|
|
1584
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.servicePrincipalRiskLevels),
|
|
1585
|
+
isBlock: false,
|
|
1586
|
+
type: "list",
|
|
1587
|
+
storageClassType: "stringList",
|
|
1588
|
+
},
|
|
1589
|
+
sign_in_risk_levels: {
|
|
1590
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.signInRiskLevels),
|
|
1591
|
+
isBlock: false,
|
|
1592
|
+
type: "list",
|
|
1593
|
+
storageClassType: "stringList",
|
|
1594
|
+
},
|
|
1595
|
+
user_risk_levels: {
|
|
1596
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.userRiskLevels),
|
|
1597
|
+
isBlock: false,
|
|
1598
|
+
type: "list",
|
|
1599
|
+
storageClassType: "stringList",
|
|
1600
|
+
},
|
|
1601
|
+
applications: {
|
|
1602
|
+
value: conditionalAccessPolicyConditionsApplicationsToHclTerraform(struct.applications),
|
|
1603
|
+
isBlock: true,
|
|
1604
|
+
type: "list",
|
|
1605
|
+
storageClassType: "ConditionalAccessPolicyConditionsApplicationsList",
|
|
1606
|
+
},
|
|
1607
|
+
client_applications: {
|
|
1608
|
+
value: conditionalAccessPolicyConditionsClientApplicationsToHclTerraform(struct.clientApplications),
|
|
1609
|
+
isBlock: true,
|
|
1610
|
+
type: "list",
|
|
1611
|
+
storageClassType: "ConditionalAccessPolicyConditionsClientApplicationsList",
|
|
1612
|
+
},
|
|
1613
|
+
devices: {
|
|
1614
|
+
value: conditionalAccessPolicyConditionsDevicesToHclTerraform(struct.devices),
|
|
1615
|
+
isBlock: true,
|
|
1616
|
+
type: "list",
|
|
1617
|
+
storageClassType: "ConditionalAccessPolicyConditionsDevicesList",
|
|
1618
|
+
},
|
|
1619
|
+
locations: {
|
|
1620
|
+
value: conditionalAccessPolicyConditionsLocationsToHclTerraform(struct.locations),
|
|
1621
|
+
isBlock: true,
|
|
1622
|
+
type: "list",
|
|
1623
|
+
storageClassType: "ConditionalAccessPolicyConditionsLocationsList",
|
|
1624
|
+
},
|
|
1625
|
+
platforms: {
|
|
1626
|
+
value: conditionalAccessPolicyConditionsPlatformsToHclTerraform(struct.platforms),
|
|
1627
|
+
isBlock: true,
|
|
1628
|
+
type: "list",
|
|
1629
|
+
storageClassType: "ConditionalAccessPolicyConditionsPlatformsList",
|
|
1630
|
+
},
|
|
1631
|
+
users: {
|
|
1632
|
+
value: conditionalAccessPolicyConditionsUsersToHclTerraform(struct.users),
|
|
1633
|
+
isBlock: true,
|
|
1634
|
+
type: "list",
|
|
1635
|
+
storageClassType: "ConditionalAccessPolicyConditionsUsersList",
|
|
1636
|
+
},
|
|
1637
|
+
};
|
|
1638
|
+
// remove undefined attributes
|
|
1639
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
1640
|
+
}
|
|
1641
|
+
class ConditionalAccessPolicyConditionsOutputReference extends cdktn.ComplexObject {
|
|
1642
|
+
/**
|
|
1643
|
+
* @param terraformResource The parent resource
|
|
1644
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1645
|
+
*/
|
|
1646
|
+
constructor(terraformResource, terraformAttribute) {
|
|
1647
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
1648
|
+
this.isEmptyObject = false;
|
|
1649
|
+
// applications - computed: false, optional: false, required: true
|
|
1650
|
+
this._applications = new ConditionalAccessPolicyConditionsApplicationsOutputReference(this, "applications");
|
|
1651
|
+
// client_applications - computed: false, optional: true, required: false
|
|
1652
|
+
this._clientApplications = new ConditionalAccessPolicyConditionsClientApplicationsOutputReference(this, "client_applications");
|
|
1653
|
+
// devices - computed: false, optional: true, required: false
|
|
1654
|
+
this._devices = new ConditionalAccessPolicyConditionsDevicesOutputReference(this, "devices");
|
|
1655
|
+
// locations - computed: false, optional: true, required: false
|
|
1656
|
+
this._locations = new ConditionalAccessPolicyConditionsLocationsOutputReference(this, "locations");
|
|
1657
|
+
// platforms - computed: false, optional: true, required: false
|
|
1658
|
+
this._platforms = new ConditionalAccessPolicyConditionsPlatformsOutputReference(this, "platforms");
|
|
1659
|
+
// users - computed: false, optional: false, required: true
|
|
1660
|
+
this._users = new ConditionalAccessPolicyConditionsUsersOutputReference(this, "users");
|
|
1661
|
+
}
|
|
1662
|
+
get internalValue() {
|
|
1663
|
+
let hasAnyValues = this.isEmptyObject;
|
|
1664
|
+
const internalValueResult = {};
|
|
1665
|
+
if (this._authenticationFlowTransferMethods !== undefined) {
|
|
1666
|
+
hasAnyValues = true;
|
|
1667
|
+
internalValueResult.authenticationFlowTransferMethods = this._authenticationFlowTransferMethods;
|
|
1668
|
+
}
|
|
1669
|
+
if (this._clientAppTypes !== undefined) {
|
|
1670
|
+
hasAnyValues = true;
|
|
1671
|
+
internalValueResult.clientAppTypes = this._clientAppTypes;
|
|
1672
|
+
}
|
|
1673
|
+
if (this._insiderRiskLevels !== undefined) {
|
|
1674
|
+
hasAnyValues = true;
|
|
1675
|
+
internalValueResult.insiderRiskLevels = this._insiderRiskLevels;
|
|
1676
|
+
}
|
|
1677
|
+
if (this._servicePrincipalRiskLevels !== undefined) {
|
|
1678
|
+
hasAnyValues = true;
|
|
1679
|
+
internalValueResult.servicePrincipalRiskLevels = this._servicePrincipalRiskLevels;
|
|
1680
|
+
}
|
|
1681
|
+
if (this._signInRiskLevels !== undefined) {
|
|
1682
|
+
hasAnyValues = true;
|
|
1683
|
+
internalValueResult.signInRiskLevels = this._signInRiskLevels;
|
|
1684
|
+
}
|
|
1685
|
+
if (this._userRiskLevels !== undefined) {
|
|
1686
|
+
hasAnyValues = true;
|
|
1687
|
+
internalValueResult.userRiskLevels = this._userRiskLevels;
|
|
1688
|
+
}
|
|
1689
|
+
if (this._applications?.internalValue !== undefined) {
|
|
1690
|
+
hasAnyValues = true;
|
|
1691
|
+
internalValueResult.applications = this._applications?.internalValue;
|
|
1692
|
+
}
|
|
1693
|
+
if (this._clientApplications?.internalValue !== undefined) {
|
|
1694
|
+
hasAnyValues = true;
|
|
1695
|
+
internalValueResult.clientApplications = this._clientApplications?.internalValue;
|
|
1696
|
+
}
|
|
1697
|
+
if (this._devices?.internalValue !== undefined) {
|
|
1698
|
+
hasAnyValues = true;
|
|
1699
|
+
internalValueResult.devices = this._devices?.internalValue;
|
|
1700
|
+
}
|
|
1701
|
+
if (this._locations?.internalValue !== undefined) {
|
|
1702
|
+
hasAnyValues = true;
|
|
1703
|
+
internalValueResult.locations = this._locations?.internalValue;
|
|
1704
|
+
}
|
|
1705
|
+
if (this._platforms?.internalValue !== undefined) {
|
|
1706
|
+
hasAnyValues = true;
|
|
1707
|
+
internalValueResult.platforms = this._platforms?.internalValue;
|
|
1708
|
+
}
|
|
1709
|
+
if (this._users?.internalValue !== undefined) {
|
|
1710
|
+
hasAnyValues = true;
|
|
1711
|
+
internalValueResult.users = this._users?.internalValue;
|
|
1712
|
+
}
|
|
1713
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
1714
|
+
}
|
|
1715
|
+
set internalValue(value) {
|
|
1716
|
+
if (value === undefined) {
|
|
1717
|
+
this.isEmptyObject = false;
|
|
1718
|
+
this._authenticationFlowTransferMethods = undefined;
|
|
1719
|
+
this._clientAppTypes = undefined;
|
|
1720
|
+
this._insiderRiskLevels = undefined;
|
|
1721
|
+
this._servicePrincipalRiskLevels = undefined;
|
|
1722
|
+
this._signInRiskLevels = undefined;
|
|
1723
|
+
this._userRiskLevels = undefined;
|
|
1724
|
+
this._applications.internalValue = undefined;
|
|
1725
|
+
this._clientApplications.internalValue = undefined;
|
|
1726
|
+
this._devices.internalValue = undefined;
|
|
1727
|
+
this._locations.internalValue = undefined;
|
|
1728
|
+
this._platforms.internalValue = undefined;
|
|
1729
|
+
this._users.internalValue = undefined;
|
|
1730
|
+
}
|
|
1731
|
+
else {
|
|
1732
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
1733
|
+
this._authenticationFlowTransferMethods = value.authenticationFlowTransferMethods;
|
|
1734
|
+
this._clientAppTypes = value.clientAppTypes;
|
|
1735
|
+
this._insiderRiskLevels = value.insiderRiskLevels;
|
|
1736
|
+
this._servicePrincipalRiskLevels = value.servicePrincipalRiskLevels;
|
|
1737
|
+
this._signInRiskLevels = value.signInRiskLevels;
|
|
1738
|
+
this._userRiskLevels = value.userRiskLevels;
|
|
1739
|
+
this._applications.internalValue = value.applications;
|
|
1740
|
+
this._clientApplications.internalValue = value.clientApplications;
|
|
1741
|
+
this._devices.internalValue = value.devices;
|
|
1742
|
+
this._locations.internalValue = value.locations;
|
|
1743
|
+
this._platforms.internalValue = value.platforms;
|
|
1744
|
+
this._users.internalValue = value.users;
|
|
1745
|
+
}
|
|
1746
|
+
}
|
|
1747
|
+
get authenticationFlowTransferMethods() {
|
|
1748
|
+
return cdktn.Fn.tolist(this.getListAttribute('authentication_flow_transfer_methods'));
|
|
1749
|
+
}
|
|
1750
|
+
set authenticationFlowTransferMethods(value) {
|
|
1751
|
+
this._authenticationFlowTransferMethods = value;
|
|
1752
|
+
}
|
|
1753
|
+
resetAuthenticationFlowTransferMethods() {
|
|
1754
|
+
this._authenticationFlowTransferMethods = undefined;
|
|
1755
|
+
}
|
|
1756
|
+
// Temporarily expose input value. Use with caution.
|
|
1757
|
+
get authenticationFlowTransferMethodsInput() {
|
|
1758
|
+
return this._authenticationFlowTransferMethods;
|
|
1759
|
+
}
|
|
1760
|
+
get clientAppTypes() {
|
|
1761
|
+
return this.getListAttribute('client_app_types');
|
|
1762
|
+
}
|
|
1763
|
+
set clientAppTypes(value) {
|
|
1764
|
+
this._clientAppTypes = value;
|
|
1765
|
+
}
|
|
1766
|
+
// Temporarily expose input value. Use with caution.
|
|
1767
|
+
get clientAppTypesInput() {
|
|
1768
|
+
return this._clientAppTypes;
|
|
1769
|
+
}
|
|
1770
|
+
get insiderRiskLevels() {
|
|
1771
|
+
return this.getStringAttribute('insider_risk_levels');
|
|
1772
|
+
}
|
|
1773
|
+
set insiderRiskLevels(value) {
|
|
1774
|
+
this._insiderRiskLevels = value;
|
|
1775
|
+
}
|
|
1776
|
+
resetInsiderRiskLevels() {
|
|
1777
|
+
this._insiderRiskLevels = undefined;
|
|
1778
|
+
}
|
|
1779
|
+
// Temporarily expose input value. Use with caution.
|
|
1780
|
+
get insiderRiskLevelsInput() {
|
|
1781
|
+
return this._insiderRiskLevels;
|
|
1782
|
+
}
|
|
1783
|
+
get servicePrincipalRiskLevels() {
|
|
1784
|
+
return this.getListAttribute('service_principal_risk_levels');
|
|
1785
|
+
}
|
|
1786
|
+
set servicePrincipalRiskLevels(value) {
|
|
1787
|
+
this._servicePrincipalRiskLevels = value;
|
|
1788
|
+
}
|
|
1789
|
+
resetServicePrincipalRiskLevels() {
|
|
1790
|
+
this._servicePrincipalRiskLevels = undefined;
|
|
1791
|
+
}
|
|
1792
|
+
// Temporarily expose input value. Use with caution.
|
|
1793
|
+
get servicePrincipalRiskLevelsInput() {
|
|
1794
|
+
return this._servicePrincipalRiskLevels;
|
|
1795
|
+
}
|
|
1796
|
+
get signInRiskLevels() {
|
|
1797
|
+
return this.getListAttribute('sign_in_risk_levels');
|
|
1798
|
+
}
|
|
1799
|
+
set signInRiskLevels(value) {
|
|
1800
|
+
this._signInRiskLevels = value;
|
|
1801
|
+
}
|
|
1802
|
+
resetSignInRiskLevels() {
|
|
1803
|
+
this._signInRiskLevels = undefined;
|
|
1804
|
+
}
|
|
1805
|
+
// Temporarily expose input value. Use with caution.
|
|
1806
|
+
get signInRiskLevelsInput() {
|
|
1807
|
+
return this._signInRiskLevels;
|
|
1808
|
+
}
|
|
1809
|
+
get userRiskLevels() {
|
|
1810
|
+
return this.getListAttribute('user_risk_levels');
|
|
1811
|
+
}
|
|
1812
|
+
set userRiskLevels(value) {
|
|
1813
|
+
this._userRiskLevels = value;
|
|
1814
|
+
}
|
|
1815
|
+
resetUserRiskLevels() {
|
|
1816
|
+
this._userRiskLevels = undefined;
|
|
1817
|
+
}
|
|
1818
|
+
// Temporarily expose input value. Use with caution.
|
|
1819
|
+
get userRiskLevelsInput() {
|
|
1820
|
+
return this._userRiskLevels;
|
|
1821
|
+
}
|
|
1822
|
+
get applications() {
|
|
1823
|
+
return this._applications;
|
|
1824
|
+
}
|
|
1825
|
+
putApplications(value) {
|
|
1826
|
+
this._applications.internalValue = value;
|
|
1827
|
+
}
|
|
1828
|
+
// Temporarily expose input value. Use with caution.
|
|
1829
|
+
get applicationsInput() {
|
|
1830
|
+
return this._applications.internalValue;
|
|
1831
|
+
}
|
|
1832
|
+
get clientApplications() {
|
|
1833
|
+
return this._clientApplications;
|
|
1834
|
+
}
|
|
1835
|
+
putClientApplications(value) {
|
|
1836
|
+
this._clientApplications.internalValue = value;
|
|
1837
|
+
}
|
|
1838
|
+
resetClientApplications() {
|
|
1839
|
+
this._clientApplications.internalValue = undefined;
|
|
1840
|
+
}
|
|
1841
|
+
// Temporarily expose input value. Use with caution.
|
|
1842
|
+
get clientApplicationsInput() {
|
|
1843
|
+
return this._clientApplications.internalValue;
|
|
1844
|
+
}
|
|
1845
|
+
get devices() {
|
|
1846
|
+
return this._devices;
|
|
1847
|
+
}
|
|
1848
|
+
putDevices(value) {
|
|
1849
|
+
this._devices.internalValue = value;
|
|
1850
|
+
}
|
|
1851
|
+
resetDevices() {
|
|
1852
|
+
this._devices.internalValue = undefined;
|
|
1853
|
+
}
|
|
1854
|
+
// Temporarily expose input value. Use with caution.
|
|
1855
|
+
get devicesInput() {
|
|
1856
|
+
return this._devices.internalValue;
|
|
1857
|
+
}
|
|
1858
|
+
get locations() {
|
|
1859
|
+
return this._locations;
|
|
1860
|
+
}
|
|
1861
|
+
putLocations(value) {
|
|
1862
|
+
this._locations.internalValue = value;
|
|
1863
|
+
}
|
|
1864
|
+
resetLocations() {
|
|
1865
|
+
this._locations.internalValue = undefined;
|
|
1866
|
+
}
|
|
1867
|
+
// Temporarily expose input value. Use with caution.
|
|
1868
|
+
get locationsInput() {
|
|
1869
|
+
return this._locations.internalValue;
|
|
1870
|
+
}
|
|
1871
|
+
get platforms() {
|
|
1872
|
+
return this._platforms;
|
|
1873
|
+
}
|
|
1874
|
+
putPlatforms(value) {
|
|
1875
|
+
this._platforms.internalValue = value;
|
|
1876
|
+
}
|
|
1877
|
+
resetPlatforms() {
|
|
1878
|
+
this._platforms.internalValue = undefined;
|
|
1879
|
+
}
|
|
1880
|
+
// Temporarily expose input value. Use with caution.
|
|
1881
|
+
get platformsInput() {
|
|
1882
|
+
return this._platforms.internalValue;
|
|
1883
|
+
}
|
|
1884
|
+
get users() {
|
|
1885
|
+
return this._users;
|
|
1886
|
+
}
|
|
1887
|
+
putUsers(value) {
|
|
1888
|
+
this._users.internalValue = value;
|
|
1889
|
+
}
|
|
1890
|
+
// Temporarily expose input value. Use with caution.
|
|
1891
|
+
get usersInput() {
|
|
1892
|
+
return this._users.internalValue;
|
|
1893
|
+
}
|
|
1894
|
+
}
|
|
1895
|
+
exports.ConditionalAccessPolicyConditionsOutputReference = ConditionalAccessPolicyConditionsOutputReference;
|
|
1896
|
+
_s = JSII_RTTI_SYMBOL_1;
|
|
1897
|
+
ConditionalAccessPolicyConditionsOutputReference[_s] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyConditionsOutputReference", version: "15.0.0" };
|
|
1898
|
+
function conditionalAccessPolicyGrantControlsToTerraform(struct) {
|
|
1899
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1900
|
+
return struct;
|
|
1901
|
+
}
|
|
1902
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1903
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1904
|
+
}
|
|
1905
|
+
return {
|
|
1906
|
+
authentication_strength_policy_id: cdktn.stringToTerraform(struct.authenticationStrengthPolicyId),
|
|
1907
|
+
built_in_controls: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.builtInControls),
|
|
1908
|
+
custom_authentication_factors: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.customAuthenticationFactors),
|
|
1909
|
+
operator: cdktn.stringToTerraform(struct.operator),
|
|
1910
|
+
terms_of_use: cdktn.listMapper(cdktn.stringToTerraform, false)(struct.termsOfUse),
|
|
1911
|
+
};
|
|
1912
|
+
}
|
|
1913
|
+
function conditionalAccessPolicyGrantControlsToHclTerraform(struct) {
|
|
1914
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
1915
|
+
return struct;
|
|
1916
|
+
}
|
|
1917
|
+
if (cdktn.isComplexElement(struct)) {
|
|
1918
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
1919
|
+
}
|
|
1920
|
+
const attrs = {
|
|
1921
|
+
authentication_strength_policy_id: {
|
|
1922
|
+
value: cdktn.stringToHclTerraform(struct.authenticationStrengthPolicyId),
|
|
1923
|
+
isBlock: false,
|
|
1924
|
+
type: "simple",
|
|
1925
|
+
storageClassType: "string",
|
|
1926
|
+
},
|
|
1927
|
+
built_in_controls: {
|
|
1928
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.builtInControls),
|
|
1929
|
+
isBlock: false,
|
|
1930
|
+
type: "list",
|
|
1931
|
+
storageClassType: "stringList",
|
|
1932
|
+
},
|
|
1933
|
+
custom_authentication_factors: {
|
|
1934
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.customAuthenticationFactors),
|
|
1935
|
+
isBlock: false,
|
|
1936
|
+
type: "list",
|
|
1937
|
+
storageClassType: "stringList",
|
|
1938
|
+
},
|
|
1939
|
+
operator: {
|
|
1940
|
+
value: cdktn.stringToHclTerraform(struct.operator),
|
|
1941
|
+
isBlock: false,
|
|
1942
|
+
type: "simple",
|
|
1943
|
+
storageClassType: "string",
|
|
1944
|
+
},
|
|
1945
|
+
terms_of_use: {
|
|
1946
|
+
value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct.termsOfUse),
|
|
1947
|
+
isBlock: false,
|
|
1948
|
+
type: "list",
|
|
1949
|
+
storageClassType: "stringList",
|
|
1950
|
+
},
|
|
1951
|
+
};
|
|
1952
|
+
// remove undefined attributes
|
|
1953
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
1954
|
+
}
|
|
1955
|
+
class ConditionalAccessPolicyGrantControlsOutputReference extends cdktn.ComplexObject {
|
|
1956
|
+
/**
|
|
1957
|
+
* @param terraformResource The parent resource
|
|
1958
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
1959
|
+
*/
|
|
1960
|
+
constructor(terraformResource, terraformAttribute) {
|
|
1961
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
1962
|
+
this.isEmptyObject = false;
|
|
1963
|
+
}
|
|
1964
|
+
get internalValue() {
|
|
1965
|
+
let hasAnyValues = this.isEmptyObject;
|
|
1966
|
+
const internalValueResult = {};
|
|
1967
|
+
if (this._authenticationStrengthPolicyId !== undefined) {
|
|
1968
|
+
hasAnyValues = true;
|
|
1969
|
+
internalValueResult.authenticationStrengthPolicyId = this._authenticationStrengthPolicyId;
|
|
1970
|
+
}
|
|
1971
|
+
if (this._builtInControls !== undefined) {
|
|
1972
|
+
hasAnyValues = true;
|
|
1973
|
+
internalValueResult.builtInControls = this._builtInControls;
|
|
1974
|
+
}
|
|
1975
|
+
if (this._customAuthenticationFactors !== undefined) {
|
|
1976
|
+
hasAnyValues = true;
|
|
1977
|
+
internalValueResult.customAuthenticationFactors = this._customAuthenticationFactors;
|
|
1978
|
+
}
|
|
1979
|
+
if (this._operator !== undefined) {
|
|
1980
|
+
hasAnyValues = true;
|
|
1981
|
+
internalValueResult.operator = this._operator;
|
|
1982
|
+
}
|
|
1983
|
+
if (this._termsOfUse !== undefined) {
|
|
1984
|
+
hasAnyValues = true;
|
|
1985
|
+
internalValueResult.termsOfUse = this._termsOfUse;
|
|
1986
|
+
}
|
|
1987
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
1988
|
+
}
|
|
1989
|
+
set internalValue(value) {
|
|
1990
|
+
if (value === undefined) {
|
|
1991
|
+
this.isEmptyObject = false;
|
|
1992
|
+
this._authenticationStrengthPolicyId = undefined;
|
|
1993
|
+
this._builtInControls = undefined;
|
|
1994
|
+
this._customAuthenticationFactors = undefined;
|
|
1995
|
+
this._operator = undefined;
|
|
1996
|
+
this._termsOfUse = undefined;
|
|
1997
|
+
}
|
|
1998
|
+
else {
|
|
1999
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
2000
|
+
this._authenticationStrengthPolicyId = value.authenticationStrengthPolicyId;
|
|
2001
|
+
this._builtInControls = value.builtInControls;
|
|
2002
|
+
this._customAuthenticationFactors = value.customAuthenticationFactors;
|
|
2003
|
+
this._operator = value.operator;
|
|
2004
|
+
this._termsOfUse = value.termsOfUse;
|
|
2005
|
+
}
|
|
2006
|
+
}
|
|
2007
|
+
get authenticationStrengthPolicyId() {
|
|
2008
|
+
return this.getStringAttribute('authentication_strength_policy_id');
|
|
2009
|
+
}
|
|
2010
|
+
set authenticationStrengthPolicyId(value) {
|
|
2011
|
+
this._authenticationStrengthPolicyId = value;
|
|
2012
|
+
}
|
|
2013
|
+
resetAuthenticationStrengthPolicyId() {
|
|
2014
|
+
this._authenticationStrengthPolicyId = undefined;
|
|
2015
|
+
}
|
|
2016
|
+
// Temporarily expose input value. Use with caution.
|
|
2017
|
+
get authenticationStrengthPolicyIdInput() {
|
|
2018
|
+
return this._authenticationStrengthPolicyId;
|
|
2019
|
+
}
|
|
2020
|
+
get builtInControls() {
|
|
2021
|
+
return this.getListAttribute('built_in_controls');
|
|
2022
|
+
}
|
|
2023
|
+
set builtInControls(value) {
|
|
2024
|
+
this._builtInControls = value;
|
|
2025
|
+
}
|
|
2026
|
+
resetBuiltInControls() {
|
|
2027
|
+
this._builtInControls = undefined;
|
|
2028
|
+
}
|
|
2029
|
+
// Temporarily expose input value. Use with caution.
|
|
2030
|
+
get builtInControlsInput() {
|
|
2031
|
+
return this._builtInControls;
|
|
2032
|
+
}
|
|
2033
|
+
get customAuthenticationFactors() {
|
|
2034
|
+
return this.getListAttribute('custom_authentication_factors');
|
|
2035
|
+
}
|
|
2036
|
+
set customAuthenticationFactors(value) {
|
|
2037
|
+
this._customAuthenticationFactors = value;
|
|
2038
|
+
}
|
|
2039
|
+
resetCustomAuthenticationFactors() {
|
|
2040
|
+
this._customAuthenticationFactors = undefined;
|
|
2041
|
+
}
|
|
2042
|
+
// Temporarily expose input value. Use with caution.
|
|
2043
|
+
get customAuthenticationFactorsInput() {
|
|
2044
|
+
return this._customAuthenticationFactors;
|
|
2045
|
+
}
|
|
2046
|
+
get operator() {
|
|
2047
|
+
return this.getStringAttribute('operator');
|
|
2048
|
+
}
|
|
2049
|
+
set operator(value) {
|
|
2050
|
+
this._operator = value;
|
|
2051
|
+
}
|
|
2052
|
+
// Temporarily expose input value. Use with caution.
|
|
2053
|
+
get operatorInput() {
|
|
2054
|
+
return this._operator;
|
|
2055
|
+
}
|
|
2056
|
+
get termsOfUse() {
|
|
2057
|
+
return this.getListAttribute('terms_of_use');
|
|
2058
|
+
}
|
|
2059
|
+
set termsOfUse(value) {
|
|
2060
|
+
this._termsOfUse = value;
|
|
2061
|
+
}
|
|
2062
|
+
resetTermsOfUse() {
|
|
2063
|
+
this._termsOfUse = undefined;
|
|
2064
|
+
}
|
|
2065
|
+
// Temporarily expose input value. Use with caution.
|
|
2066
|
+
get termsOfUseInput() {
|
|
2067
|
+
return this._termsOfUse;
|
|
2068
|
+
}
|
|
2069
|
+
}
|
|
2070
|
+
exports.ConditionalAccessPolicyGrantControlsOutputReference = ConditionalAccessPolicyGrantControlsOutputReference;
|
|
2071
|
+
_t = JSII_RTTI_SYMBOL_1;
|
|
2072
|
+
ConditionalAccessPolicyGrantControlsOutputReference[_t] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyGrantControlsOutputReference", version: "15.0.0" };
|
|
2073
|
+
function conditionalAccessPolicySessionControlsToTerraform(struct) {
|
|
2074
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
2075
|
+
return struct;
|
|
2076
|
+
}
|
|
2077
|
+
if (cdktn.isComplexElement(struct)) {
|
|
2078
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
2079
|
+
}
|
|
2080
|
+
return {
|
|
2081
|
+
application_enforced_restrictions_enabled: cdktn.booleanToTerraform(struct.applicationEnforcedRestrictionsEnabled),
|
|
2082
|
+
cloud_app_security_policy: cdktn.stringToTerraform(struct.cloudAppSecurityPolicy),
|
|
2083
|
+
disable_resilience_defaults: cdktn.booleanToTerraform(struct.disableResilienceDefaults),
|
|
2084
|
+
persistent_browser_mode: cdktn.stringToTerraform(struct.persistentBrowserMode),
|
|
2085
|
+
sign_in_frequency: cdktn.numberToTerraform(struct.signInFrequency),
|
|
2086
|
+
sign_in_frequency_authentication_type: cdktn.stringToTerraform(struct.signInFrequencyAuthenticationType),
|
|
2087
|
+
sign_in_frequency_interval: cdktn.stringToTerraform(struct.signInFrequencyInterval),
|
|
2088
|
+
sign_in_frequency_period: cdktn.stringToTerraform(struct.signInFrequencyPeriod),
|
|
2089
|
+
};
|
|
2090
|
+
}
|
|
2091
|
+
function conditionalAccessPolicySessionControlsToHclTerraform(struct) {
|
|
2092
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
2093
|
+
return struct;
|
|
2094
|
+
}
|
|
2095
|
+
if (cdktn.isComplexElement(struct)) {
|
|
2096
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
2097
|
+
}
|
|
2098
|
+
const attrs = {
|
|
2099
|
+
application_enforced_restrictions_enabled: {
|
|
2100
|
+
value: cdktn.booleanToHclTerraform(struct.applicationEnforcedRestrictionsEnabled),
|
|
2101
|
+
isBlock: false,
|
|
2102
|
+
type: "simple",
|
|
2103
|
+
storageClassType: "boolean",
|
|
2104
|
+
},
|
|
2105
|
+
cloud_app_security_policy: {
|
|
2106
|
+
value: cdktn.stringToHclTerraform(struct.cloudAppSecurityPolicy),
|
|
2107
|
+
isBlock: false,
|
|
2108
|
+
type: "simple",
|
|
2109
|
+
storageClassType: "string",
|
|
2110
|
+
},
|
|
2111
|
+
disable_resilience_defaults: {
|
|
2112
|
+
value: cdktn.booleanToHclTerraform(struct.disableResilienceDefaults),
|
|
2113
|
+
isBlock: false,
|
|
2114
|
+
type: "simple",
|
|
2115
|
+
storageClassType: "boolean",
|
|
2116
|
+
},
|
|
2117
|
+
persistent_browser_mode: {
|
|
2118
|
+
value: cdktn.stringToHclTerraform(struct.persistentBrowserMode),
|
|
2119
|
+
isBlock: false,
|
|
2120
|
+
type: "simple",
|
|
2121
|
+
storageClassType: "string",
|
|
2122
|
+
},
|
|
2123
|
+
sign_in_frequency: {
|
|
2124
|
+
value: cdktn.numberToHclTerraform(struct.signInFrequency),
|
|
2125
|
+
isBlock: false,
|
|
2126
|
+
type: "simple",
|
|
2127
|
+
storageClassType: "number",
|
|
2128
|
+
},
|
|
2129
|
+
sign_in_frequency_authentication_type: {
|
|
2130
|
+
value: cdktn.stringToHclTerraform(struct.signInFrequencyAuthenticationType),
|
|
2131
|
+
isBlock: false,
|
|
2132
|
+
type: "simple",
|
|
2133
|
+
storageClassType: "string",
|
|
2134
|
+
},
|
|
2135
|
+
sign_in_frequency_interval: {
|
|
2136
|
+
value: cdktn.stringToHclTerraform(struct.signInFrequencyInterval),
|
|
2137
|
+
isBlock: false,
|
|
2138
|
+
type: "simple",
|
|
2139
|
+
storageClassType: "string",
|
|
2140
|
+
},
|
|
2141
|
+
sign_in_frequency_period: {
|
|
2142
|
+
value: cdktn.stringToHclTerraform(struct.signInFrequencyPeriod),
|
|
2143
|
+
isBlock: false,
|
|
2144
|
+
type: "simple",
|
|
2145
|
+
storageClassType: "string",
|
|
2146
|
+
},
|
|
2147
|
+
};
|
|
2148
|
+
// remove undefined attributes
|
|
2149
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
2150
|
+
}
|
|
2151
|
+
class ConditionalAccessPolicySessionControlsOutputReference extends cdktn.ComplexObject {
|
|
2152
|
+
/**
|
|
2153
|
+
* @param terraformResource The parent resource
|
|
2154
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
2155
|
+
*/
|
|
2156
|
+
constructor(terraformResource, terraformAttribute) {
|
|
2157
|
+
super(terraformResource, terraformAttribute, false, 0);
|
|
2158
|
+
this.isEmptyObject = false;
|
|
2159
|
+
}
|
|
2160
|
+
get internalValue() {
|
|
2161
|
+
let hasAnyValues = this.isEmptyObject;
|
|
2162
|
+
const internalValueResult = {};
|
|
2163
|
+
if (this._applicationEnforcedRestrictionsEnabled !== undefined) {
|
|
2164
|
+
hasAnyValues = true;
|
|
2165
|
+
internalValueResult.applicationEnforcedRestrictionsEnabled = this._applicationEnforcedRestrictionsEnabled;
|
|
2166
|
+
}
|
|
2167
|
+
if (this._cloudAppSecurityPolicy !== undefined) {
|
|
2168
|
+
hasAnyValues = true;
|
|
2169
|
+
internalValueResult.cloudAppSecurityPolicy = this._cloudAppSecurityPolicy;
|
|
2170
|
+
}
|
|
2171
|
+
if (this._disableResilienceDefaults !== undefined) {
|
|
2172
|
+
hasAnyValues = true;
|
|
2173
|
+
internalValueResult.disableResilienceDefaults = this._disableResilienceDefaults;
|
|
2174
|
+
}
|
|
2175
|
+
if (this._persistentBrowserMode !== undefined) {
|
|
2176
|
+
hasAnyValues = true;
|
|
2177
|
+
internalValueResult.persistentBrowserMode = this._persistentBrowserMode;
|
|
2178
|
+
}
|
|
2179
|
+
if (this._signInFrequency !== undefined) {
|
|
2180
|
+
hasAnyValues = true;
|
|
2181
|
+
internalValueResult.signInFrequency = this._signInFrequency;
|
|
2182
|
+
}
|
|
2183
|
+
if (this._signInFrequencyAuthenticationType !== undefined) {
|
|
2184
|
+
hasAnyValues = true;
|
|
2185
|
+
internalValueResult.signInFrequencyAuthenticationType = this._signInFrequencyAuthenticationType;
|
|
2186
|
+
}
|
|
2187
|
+
if (this._signInFrequencyInterval !== undefined) {
|
|
2188
|
+
hasAnyValues = true;
|
|
2189
|
+
internalValueResult.signInFrequencyInterval = this._signInFrequencyInterval;
|
|
2190
|
+
}
|
|
2191
|
+
if (this._signInFrequencyPeriod !== undefined) {
|
|
2192
|
+
hasAnyValues = true;
|
|
2193
|
+
internalValueResult.signInFrequencyPeriod = this._signInFrequencyPeriod;
|
|
2194
|
+
}
|
|
2195
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
2196
|
+
}
|
|
2197
|
+
set internalValue(value) {
|
|
2198
|
+
if (value === undefined) {
|
|
2199
|
+
this.isEmptyObject = false;
|
|
2200
|
+
this._applicationEnforcedRestrictionsEnabled = undefined;
|
|
2201
|
+
this._cloudAppSecurityPolicy = undefined;
|
|
2202
|
+
this._disableResilienceDefaults = undefined;
|
|
2203
|
+
this._persistentBrowserMode = undefined;
|
|
2204
|
+
this._signInFrequency = undefined;
|
|
2205
|
+
this._signInFrequencyAuthenticationType = undefined;
|
|
2206
|
+
this._signInFrequencyInterval = undefined;
|
|
2207
|
+
this._signInFrequencyPeriod = undefined;
|
|
2208
|
+
}
|
|
2209
|
+
else {
|
|
2210
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
2211
|
+
this._applicationEnforcedRestrictionsEnabled = value.applicationEnforcedRestrictionsEnabled;
|
|
2212
|
+
this._cloudAppSecurityPolicy = value.cloudAppSecurityPolicy;
|
|
2213
|
+
this._disableResilienceDefaults = value.disableResilienceDefaults;
|
|
2214
|
+
this._persistentBrowserMode = value.persistentBrowserMode;
|
|
2215
|
+
this._signInFrequency = value.signInFrequency;
|
|
2216
|
+
this._signInFrequencyAuthenticationType = value.signInFrequencyAuthenticationType;
|
|
2217
|
+
this._signInFrequencyInterval = value.signInFrequencyInterval;
|
|
2218
|
+
this._signInFrequencyPeriod = value.signInFrequencyPeriod;
|
|
2219
|
+
}
|
|
2220
|
+
}
|
|
2221
|
+
get applicationEnforcedRestrictionsEnabled() {
|
|
2222
|
+
return this.getBooleanAttribute('application_enforced_restrictions_enabled');
|
|
2223
|
+
}
|
|
2224
|
+
set applicationEnforcedRestrictionsEnabled(value) {
|
|
2225
|
+
this._applicationEnforcedRestrictionsEnabled = value;
|
|
2226
|
+
}
|
|
2227
|
+
resetApplicationEnforcedRestrictionsEnabled() {
|
|
2228
|
+
this._applicationEnforcedRestrictionsEnabled = undefined;
|
|
2229
|
+
}
|
|
2230
|
+
// Temporarily expose input value. Use with caution.
|
|
2231
|
+
get applicationEnforcedRestrictionsEnabledInput() {
|
|
2232
|
+
return this._applicationEnforcedRestrictionsEnabled;
|
|
2233
|
+
}
|
|
2234
|
+
get cloudAppSecurityPolicy() {
|
|
2235
|
+
return this.getStringAttribute('cloud_app_security_policy');
|
|
2236
|
+
}
|
|
2237
|
+
set cloudAppSecurityPolicy(value) {
|
|
2238
|
+
this._cloudAppSecurityPolicy = value;
|
|
2239
|
+
}
|
|
2240
|
+
resetCloudAppSecurityPolicy() {
|
|
2241
|
+
this._cloudAppSecurityPolicy = undefined;
|
|
2242
|
+
}
|
|
2243
|
+
// Temporarily expose input value. Use with caution.
|
|
2244
|
+
get cloudAppSecurityPolicyInput() {
|
|
2245
|
+
return this._cloudAppSecurityPolicy;
|
|
2246
|
+
}
|
|
2247
|
+
get disableResilienceDefaults() {
|
|
2248
|
+
return this.getBooleanAttribute('disable_resilience_defaults');
|
|
2249
|
+
}
|
|
2250
|
+
set disableResilienceDefaults(value) {
|
|
2251
|
+
this._disableResilienceDefaults = value;
|
|
2252
|
+
}
|
|
2253
|
+
resetDisableResilienceDefaults() {
|
|
2254
|
+
this._disableResilienceDefaults = undefined;
|
|
2255
|
+
}
|
|
2256
|
+
// Temporarily expose input value. Use with caution.
|
|
2257
|
+
get disableResilienceDefaultsInput() {
|
|
2258
|
+
return this._disableResilienceDefaults;
|
|
2259
|
+
}
|
|
2260
|
+
get persistentBrowserMode() {
|
|
2261
|
+
return this.getStringAttribute('persistent_browser_mode');
|
|
2262
|
+
}
|
|
2263
|
+
set persistentBrowserMode(value) {
|
|
2264
|
+
this._persistentBrowserMode = value;
|
|
2265
|
+
}
|
|
2266
|
+
resetPersistentBrowserMode() {
|
|
2267
|
+
this._persistentBrowserMode = undefined;
|
|
2268
|
+
}
|
|
2269
|
+
// Temporarily expose input value. Use with caution.
|
|
2270
|
+
get persistentBrowserModeInput() {
|
|
2271
|
+
return this._persistentBrowserMode;
|
|
2272
|
+
}
|
|
2273
|
+
get signInFrequency() {
|
|
2274
|
+
return this.getNumberAttribute('sign_in_frequency');
|
|
2275
|
+
}
|
|
2276
|
+
set signInFrequency(value) {
|
|
2277
|
+
this._signInFrequency = value;
|
|
2278
|
+
}
|
|
2279
|
+
resetSignInFrequency() {
|
|
2280
|
+
this._signInFrequency = undefined;
|
|
2281
|
+
}
|
|
2282
|
+
// Temporarily expose input value. Use with caution.
|
|
2283
|
+
get signInFrequencyInput() {
|
|
2284
|
+
return this._signInFrequency;
|
|
2285
|
+
}
|
|
2286
|
+
get signInFrequencyAuthenticationType() {
|
|
2287
|
+
return this.getStringAttribute('sign_in_frequency_authentication_type');
|
|
2288
|
+
}
|
|
2289
|
+
set signInFrequencyAuthenticationType(value) {
|
|
2290
|
+
this._signInFrequencyAuthenticationType = value;
|
|
2291
|
+
}
|
|
2292
|
+
resetSignInFrequencyAuthenticationType() {
|
|
2293
|
+
this._signInFrequencyAuthenticationType = undefined;
|
|
2294
|
+
}
|
|
2295
|
+
// Temporarily expose input value. Use with caution.
|
|
2296
|
+
get signInFrequencyAuthenticationTypeInput() {
|
|
2297
|
+
return this._signInFrequencyAuthenticationType;
|
|
2298
|
+
}
|
|
2299
|
+
get signInFrequencyInterval() {
|
|
2300
|
+
return this.getStringAttribute('sign_in_frequency_interval');
|
|
2301
|
+
}
|
|
2302
|
+
set signInFrequencyInterval(value) {
|
|
2303
|
+
this._signInFrequencyInterval = value;
|
|
2304
|
+
}
|
|
2305
|
+
resetSignInFrequencyInterval() {
|
|
2306
|
+
this._signInFrequencyInterval = undefined;
|
|
2307
|
+
}
|
|
2308
|
+
// Temporarily expose input value. Use with caution.
|
|
2309
|
+
get signInFrequencyIntervalInput() {
|
|
2310
|
+
return this._signInFrequencyInterval;
|
|
2311
|
+
}
|
|
2312
|
+
get signInFrequencyPeriod() {
|
|
2313
|
+
return this.getStringAttribute('sign_in_frequency_period');
|
|
2314
|
+
}
|
|
2315
|
+
set signInFrequencyPeriod(value) {
|
|
2316
|
+
this._signInFrequencyPeriod = value;
|
|
2317
|
+
}
|
|
2318
|
+
resetSignInFrequencyPeriod() {
|
|
2319
|
+
this._signInFrequencyPeriod = undefined;
|
|
2320
|
+
}
|
|
2321
|
+
// Temporarily expose input value. Use with caution.
|
|
2322
|
+
get signInFrequencyPeriodInput() {
|
|
2323
|
+
return this._signInFrequencyPeriod;
|
|
2324
|
+
}
|
|
2325
|
+
}
|
|
2326
|
+
exports.ConditionalAccessPolicySessionControlsOutputReference = ConditionalAccessPolicySessionControlsOutputReference;
|
|
2327
|
+
_u = JSII_RTTI_SYMBOL_1;
|
|
2328
|
+
ConditionalAccessPolicySessionControlsOutputReference[_u] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicySessionControlsOutputReference", version: "15.0.0" };
|
|
2329
|
+
function conditionalAccessPolicyTimeoutsToTerraform(struct) {
|
|
2330
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
2331
|
+
return struct;
|
|
2332
|
+
}
|
|
2333
|
+
if (cdktn.isComplexElement(struct)) {
|
|
2334
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
2335
|
+
}
|
|
2336
|
+
return {
|
|
2337
|
+
create: cdktn.stringToTerraform(struct.create),
|
|
2338
|
+
delete: cdktn.stringToTerraform(struct.delete),
|
|
2339
|
+
read: cdktn.stringToTerraform(struct.read),
|
|
2340
|
+
update: cdktn.stringToTerraform(struct.update),
|
|
2341
|
+
};
|
|
2342
|
+
}
|
|
2343
|
+
function conditionalAccessPolicyTimeoutsToHclTerraform(struct) {
|
|
2344
|
+
if (!cdktn.canInspect(struct) || cdktn.Tokenization.isResolvable(struct)) {
|
|
2345
|
+
return struct;
|
|
2346
|
+
}
|
|
2347
|
+
if (cdktn.isComplexElement(struct)) {
|
|
2348
|
+
throw new Error("A complex element was used as configuration, this is not supported: https://cdk.tf/complex-object-as-configuration");
|
|
2349
|
+
}
|
|
2350
|
+
const attrs = {
|
|
2351
|
+
create: {
|
|
2352
|
+
value: cdktn.stringToHclTerraform(struct.create),
|
|
2353
|
+
isBlock: false,
|
|
2354
|
+
type: "simple",
|
|
2355
|
+
storageClassType: "string",
|
|
2356
|
+
},
|
|
2357
|
+
delete: {
|
|
2358
|
+
value: cdktn.stringToHclTerraform(struct.delete),
|
|
2359
|
+
isBlock: false,
|
|
2360
|
+
type: "simple",
|
|
2361
|
+
storageClassType: "string",
|
|
2362
|
+
},
|
|
2363
|
+
read: {
|
|
2364
|
+
value: cdktn.stringToHclTerraform(struct.read),
|
|
2365
|
+
isBlock: false,
|
|
2366
|
+
type: "simple",
|
|
2367
|
+
storageClassType: "string",
|
|
2368
|
+
},
|
|
2369
|
+
update: {
|
|
2370
|
+
value: cdktn.stringToHclTerraform(struct.update),
|
|
2371
|
+
isBlock: false,
|
|
2372
|
+
type: "simple",
|
|
2373
|
+
storageClassType: "string",
|
|
2374
|
+
},
|
|
2375
|
+
};
|
|
2376
|
+
// remove undefined attributes
|
|
2377
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
2378
|
+
}
|
|
2379
|
+
class ConditionalAccessPolicyTimeoutsOutputReference extends cdktn.ComplexObject {
|
|
2380
|
+
/**
|
|
2381
|
+
* @param terraformResource The parent resource
|
|
2382
|
+
* @param terraformAttribute The attribute on the parent resource this class is referencing
|
|
2383
|
+
*/
|
|
2384
|
+
constructor(terraformResource, terraformAttribute) {
|
|
2385
|
+
super(terraformResource, terraformAttribute, false);
|
|
2386
|
+
this.isEmptyObject = false;
|
|
2387
|
+
}
|
|
2388
|
+
get internalValue() {
|
|
2389
|
+
if (this.resolvableValue) {
|
|
2390
|
+
return this.resolvableValue;
|
|
2391
|
+
}
|
|
2392
|
+
let hasAnyValues = this.isEmptyObject;
|
|
2393
|
+
const internalValueResult = {};
|
|
2394
|
+
if (this._create !== undefined) {
|
|
2395
|
+
hasAnyValues = true;
|
|
2396
|
+
internalValueResult.create = this._create;
|
|
2397
|
+
}
|
|
2398
|
+
if (this._delete !== undefined) {
|
|
2399
|
+
hasAnyValues = true;
|
|
2400
|
+
internalValueResult.delete = this._delete;
|
|
2401
|
+
}
|
|
2402
|
+
if (this._read !== undefined) {
|
|
2403
|
+
hasAnyValues = true;
|
|
2404
|
+
internalValueResult.read = this._read;
|
|
2405
|
+
}
|
|
2406
|
+
if (this._update !== undefined) {
|
|
2407
|
+
hasAnyValues = true;
|
|
2408
|
+
internalValueResult.update = this._update;
|
|
2409
|
+
}
|
|
2410
|
+
return hasAnyValues ? internalValueResult : undefined;
|
|
2411
|
+
}
|
|
2412
|
+
set internalValue(value) {
|
|
2413
|
+
if (value === undefined) {
|
|
2414
|
+
this.isEmptyObject = false;
|
|
2415
|
+
this.resolvableValue = undefined;
|
|
2416
|
+
this._create = undefined;
|
|
2417
|
+
this._delete = undefined;
|
|
2418
|
+
this._read = undefined;
|
|
2419
|
+
this._update = undefined;
|
|
2420
|
+
}
|
|
2421
|
+
else if (cdktn.Tokenization.isResolvable(value)) {
|
|
2422
|
+
this.isEmptyObject = false;
|
|
2423
|
+
this.resolvableValue = value;
|
|
2424
|
+
}
|
|
2425
|
+
else {
|
|
2426
|
+
this.isEmptyObject = Object.keys(value).length === 0;
|
|
2427
|
+
this.resolvableValue = undefined;
|
|
2428
|
+
this._create = value.create;
|
|
2429
|
+
this._delete = value.delete;
|
|
2430
|
+
this._read = value.read;
|
|
2431
|
+
this._update = value.update;
|
|
2432
|
+
}
|
|
2433
|
+
}
|
|
2434
|
+
get create() {
|
|
2435
|
+
return this.getStringAttribute('create');
|
|
2436
|
+
}
|
|
2437
|
+
set create(value) {
|
|
2438
|
+
this._create = value;
|
|
2439
|
+
}
|
|
2440
|
+
resetCreate() {
|
|
2441
|
+
this._create = undefined;
|
|
2442
|
+
}
|
|
2443
|
+
// Temporarily expose input value. Use with caution.
|
|
2444
|
+
get createInput() {
|
|
2445
|
+
return this._create;
|
|
2446
|
+
}
|
|
2447
|
+
get delete() {
|
|
2448
|
+
return this.getStringAttribute('delete');
|
|
2449
|
+
}
|
|
2450
|
+
set delete(value) {
|
|
2451
|
+
this._delete = value;
|
|
2452
|
+
}
|
|
2453
|
+
resetDelete() {
|
|
2454
|
+
this._delete = undefined;
|
|
2455
|
+
}
|
|
2456
|
+
// Temporarily expose input value. Use with caution.
|
|
2457
|
+
get deleteInput() {
|
|
2458
|
+
return this._delete;
|
|
2459
|
+
}
|
|
2460
|
+
get read() {
|
|
2461
|
+
return this.getStringAttribute('read');
|
|
2462
|
+
}
|
|
2463
|
+
set read(value) {
|
|
2464
|
+
this._read = value;
|
|
2465
|
+
}
|
|
2466
|
+
resetRead() {
|
|
2467
|
+
this._read = undefined;
|
|
2468
|
+
}
|
|
2469
|
+
// Temporarily expose input value. Use with caution.
|
|
2470
|
+
get readInput() {
|
|
2471
|
+
return this._read;
|
|
2472
|
+
}
|
|
2473
|
+
get update() {
|
|
2474
|
+
return this.getStringAttribute('update');
|
|
2475
|
+
}
|
|
2476
|
+
set update(value) {
|
|
2477
|
+
this._update = value;
|
|
2478
|
+
}
|
|
2479
|
+
resetUpdate() {
|
|
2480
|
+
this._update = undefined;
|
|
2481
|
+
}
|
|
2482
|
+
// Temporarily expose input value. Use with caution.
|
|
2483
|
+
get updateInput() {
|
|
2484
|
+
return this._update;
|
|
2485
|
+
}
|
|
2486
|
+
}
|
|
2487
|
+
exports.ConditionalAccessPolicyTimeoutsOutputReference = ConditionalAccessPolicyTimeoutsOutputReference;
|
|
2488
|
+
_v = JSII_RTTI_SYMBOL_1;
|
|
2489
|
+
ConditionalAccessPolicyTimeoutsOutputReference[_v] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicyTimeoutsOutputReference", version: "15.0.0" };
|
|
2490
|
+
/**
|
|
2491
|
+
* Represents a {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy azuread_conditional_access_policy}
|
|
2492
|
+
*/
|
|
2493
|
+
class ConditionalAccessPolicy extends cdktn.TerraformResource {
|
|
2494
|
+
// ==============
|
|
2495
|
+
// STATIC Methods
|
|
2496
|
+
// ==============
|
|
2497
|
+
/**
|
|
2498
|
+
* Generates CDKTN code for importing a ConditionalAccessPolicy resource upon running "cdktn plan <stack-name>"
|
|
2499
|
+
* @param scope The scope in which to define this construct
|
|
2500
|
+
* @param importToId The construct id used in the generated config for the ConditionalAccessPolicy to import
|
|
2501
|
+
* @param importFromId The id of the existing ConditionalAccessPolicy that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#import import section} in the documentation of this resource for the id to use
|
|
2502
|
+
* @param provider? Optional instance of the provider where the ConditionalAccessPolicy to import is found
|
|
2503
|
+
*/
|
|
2504
|
+
static generateConfigForImport(scope, importToId, importFromId, provider) {
|
|
2505
|
+
return new cdktn.ImportableResource(scope, importToId, { terraformResourceType: "azuread_conditional_access_policy", importId: importFromId, provider });
|
|
2506
|
+
}
|
|
2507
|
+
// ===========
|
|
2508
|
+
// INITIALIZER
|
|
2509
|
+
// ===========
|
|
2510
|
+
/**
|
|
2511
|
+
* Create a new {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy azuread_conditional_access_policy} Resource
|
|
2512
|
+
*
|
|
2513
|
+
* @param scope The scope in which to define this construct
|
|
2514
|
+
* @param id The scoped construct ID. Must be unique amongst siblings in the same scope
|
|
2515
|
+
* @param options ConditionalAccessPolicyConfig
|
|
2516
|
+
*/
|
|
2517
|
+
constructor(scope, id, config) {
|
|
2518
|
+
super(scope, id, {
|
|
2519
|
+
terraformResourceType: 'azuread_conditional_access_policy',
|
|
2520
|
+
terraformGeneratorMetadata: {
|
|
2521
|
+
providerName: 'azuread',
|
|
2522
|
+
providerVersion: '3.7.0',
|
|
2523
|
+
providerVersionConstraint: '~> 3.0'
|
|
2524
|
+
},
|
|
2525
|
+
provider: config.provider,
|
|
2526
|
+
dependsOn: config.dependsOn,
|
|
2527
|
+
count: config.count,
|
|
2528
|
+
lifecycle: config.lifecycle,
|
|
2529
|
+
provisioners: config.provisioners,
|
|
2530
|
+
connection: config.connection,
|
|
2531
|
+
forEach: config.forEach
|
|
2532
|
+
});
|
|
2533
|
+
// conditions - computed: false, optional: false, required: true
|
|
2534
|
+
this._conditions = new ConditionalAccessPolicyConditionsOutputReference(this, "conditions");
|
|
2535
|
+
// grant_controls - computed: false, optional: true, required: false
|
|
2536
|
+
this._grantControls = new ConditionalAccessPolicyGrantControlsOutputReference(this, "grant_controls");
|
|
2537
|
+
// session_controls - computed: false, optional: true, required: false
|
|
2538
|
+
this._sessionControls = new ConditionalAccessPolicySessionControlsOutputReference(this, "session_controls");
|
|
2539
|
+
// timeouts - computed: false, optional: true, required: false
|
|
2540
|
+
this._timeouts = new ConditionalAccessPolicyTimeoutsOutputReference(this, "timeouts");
|
|
2541
|
+
this._displayName = config.displayName;
|
|
2542
|
+
this._id = config.id;
|
|
2543
|
+
this._state = config.state;
|
|
2544
|
+
this._conditions.internalValue = config.conditions;
|
|
2545
|
+
this._grantControls.internalValue = config.grantControls;
|
|
2546
|
+
this._sessionControls.internalValue = config.sessionControls;
|
|
2547
|
+
this._timeouts.internalValue = config.timeouts;
|
|
2548
|
+
}
|
|
2549
|
+
get displayName() {
|
|
2550
|
+
return this.getStringAttribute('display_name');
|
|
2551
|
+
}
|
|
2552
|
+
set displayName(value) {
|
|
2553
|
+
this._displayName = value;
|
|
2554
|
+
}
|
|
2555
|
+
// Temporarily expose input value. Use with caution.
|
|
2556
|
+
get displayNameInput() {
|
|
2557
|
+
return this._displayName;
|
|
2558
|
+
}
|
|
2559
|
+
get id() {
|
|
2560
|
+
return this.getStringAttribute('id');
|
|
2561
|
+
}
|
|
2562
|
+
set id(value) {
|
|
2563
|
+
this._id = value;
|
|
2564
|
+
}
|
|
2565
|
+
resetId() {
|
|
2566
|
+
this._id = undefined;
|
|
2567
|
+
}
|
|
2568
|
+
// Temporarily expose input value. Use with caution.
|
|
2569
|
+
get idInput() {
|
|
2570
|
+
return this._id;
|
|
2571
|
+
}
|
|
2572
|
+
// object_id - computed: true, optional: false, required: false
|
|
2573
|
+
get objectId() {
|
|
2574
|
+
return this.getStringAttribute('object_id');
|
|
2575
|
+
}
|
|
2576
|
+
get state() {
|
|
2577
|
+
return this.getStringAttribute('state');
|
|
2578
|
+
}
|
|
2579
|
+
set state(value) {
|
|
2580
|
+
this._state = value;
|
|
2581
|
+
}
|
|
2582
|
+
// Temporarily expose input value. Use with caution.
|
|
2583
|
+
get stateInput() {
|
|
2584
|
+
return this._state;
|
|
2585
|
+
}
|
|
2586
|
+
get conditions() {
|
|
2587
|
+
return this._conditions;
|
|
2588
|
+
}
|
|
2589
|
+
putConditions(value) {
|
|
2590
|
+
this._conditions.internalValue = value;
|
|
2591
|
+
}
|
|
2592
|
+
// Temporarily expose input value. Use with caution.
|
|
2593
|
+
get conditionsInput() {
|
|
2594
|
+
return this._conditions.internalValue;
|
|
2595
|
+
}
|
|
2596
|
+
get grantControls() {
|
|
2597
|
+
return this._grantControls;
|
|
2598
|
+
}
|
|
2599
|
+
putGrantControls(value) {
|
|
2600
|
+
this._grantControls.internalValue = value;
|
|
2601
|
+
}
|
|
2602
|
+
resetGrantControls() {
|
|
2603
|
+
this._grantControls.internalValue = undefined;
|
|
2604
|
+
}
|
|
2605
|
+
// Temporarily expose input value. Use with caution.
|
|
2606
|
+
get grantControlsInput() {
|
|
2607
|
+
return this._grantControls.internalValue;
|
|
2608
|
+
}
|
|
2609
|
+
get sessionControls() {
|
|
2610
|
+
return this._sessionControls;
|
|
2611
|
+
}
|
|
2612
|
+
putSessionControls(value) {
|
|
2613
|
+
this._sessionControls.internalValue = value;
|
|
2614
|
+
}
|
|
2615
|
+
resetSessionControls() {
|
|
2616
|
+
this._sessionControls.internalValue = undefined;
|
|
2617
|
+
}
|
|
2618
|
+
// Temporarily expose input value. Use with caution.
|
|
2619
|
+
get sessionControlsInput() {
|
|
2620
|
+
return this._sessionControls.internalValue;
|
|
2621
|
+
}
|
|
2622
|
+
get timeouts() {
|
|
2623
|
+
return this._timeouts;
|
|
2624
|
+
}
|
|
2625
|
+
putTimeouts(value) {
|
|
2626
|
+
this._timeouts.internalValue = value;
|
|
2627
|
+
}
|
|
2628
|
+
resetTimeouts() {
|
|
2629
|
+
this._timeouts.internalValue = undefined;
|
|
2630
|
+
}
|
|
2631
|
+
// Temporarily expose input value. Use with caution.
|
|
2632
|
+
get timeoutsInput() {
|
|
2633
|
+
return this._timeouts.internalValue;
|
|
2634
|
+
}
|
|
2635
|
+
// =========
|
|
2636
|
+
// SYNTHESIS
|
|
2637
|
+
// =========
|
|
2638
|
+
synthesizeAttributes() {
|
|
2639
|
+
return {
|
|
2640
|
+
display_name: cdktn.stringToTerraform(this._displayName),
|
|
2641
|
+
id: cdktn.stringToTerraform(this._id),
|
|
2642
|
+
state: cdktn.stringToTerraform(this._state),
|
|
2643
|
+
conditions: conditionalAccessPolicyConditionsToTerraform(this._conditions.internalValue),
|
|
2644
|
+
grant_controls: conditionalAccessPolicyGrantControlsToTerraform(this._grantControls.internalValue),
|
|
2645
|
+
session_controls: conditionalAccessPolicySessionControlsToTerraform(this._sessionControls.internalValue),
|
|
2646
|
+
timeouts: conditionalAccessPolicyTimeoutsToTerraform(this._timeouts.internalValue),
|
|
2647
|
+
};
|
|
2648
|
+
}
|
|
2649
|
+
synthesizeHclAttributes() {
|
|
2650
|
+
const attrs = {
|
|
2651
|
+
display_name: {
|
|
2652
|
+
value: cdktn.stringToHclTerraform(this._displayName),
|
|
2653
|
+
isBlock: false,
|
|
2654
|
+
type: "simple",
|
|
2655
|
+
storageClassType: "string",
|
|
2656
|
+
},
|
|
2657
|
+
id: {
|
|
2658
|
+
value: cdktn.stringToHclTerraform(this._id),
|
|
2659
|
+
isBlock: false,
|
|
2660
|
+
type: "simple",
|
|
2661
|
+
storageClassType: "string",
|
|
2662
|
+
},
|
|
2663
|
+
state: {
|
|
2664
|
+
value: cdktn.stringToHclTerraform(this._state),
|
|
2665
|
+
isBlock: false,
|
|
2666
|
+
type: "simple",
|
|
2667
|
+
storageClassType: "string",
|
|
2668
|
+
},
|
|
2669
|
+
conditions: {
|
|
2670
|
+
value: conditionalAccessPolicyConditionsToHclTerraform(this._conditions.internalValue),
|
|
2671
|
+
isBlock: true,
|
|
2672
|
+
type: "list",
|
|
2673
|
+
storageClassType: "ConditionalAccessPolicyConditionsList",
|
|
2674
|
+
},
|
|
2675
|
+
grant_controls: {
|
|
2676
|
+
value: conditionalAccessPolicyGrantControlsToHclTerraform(this._grantControls.internalValue),
|
|
2677
|
+
isBlock: true,
|
|
2678
|
+
type: "list",
|
|
2679
|
+
storageClassType: "ConditionalAccessPolicyGrantControlsList",
|
|
2680
|
+
},
|
|
2681
|
+
session_controls: {
|
|
2682
|
+
value: conditionalAccessPolicySessionControlsToHclTerraform(this._sessionControls.internalValue),
|
|
2683
|
+
isBlock: true,
|
|
2684
|
+
type: "list",
|
|
2685
|
+
storageClassType: "ConditionalAccessPolicySessionControlsList",
|
|
2686
|
+
},
|
|
2687
|
+
timeouts: {
|
|
2688
|
+
value: conditionalAccessPolicyTimeoutsToHclTerraform(this._timeouts.internalValue),
|
|
2689
|
+
isBlock: true,
|
|
2690
|
+
type: "struct",
|
|
2691
|
+
storageClassType: "ConditionalAccessPolicyTimeouts",
|
|
2692
|
+
},
|
|
2693
|
+
};
|
|
2694
|
+
// remove undefined attributes
|
|
2695
|
+
return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined));
|
|
2696
|
+
}
|
|
2697
|
+
}
|
|
2698
|
+
exports.ConditionalAccessPolicy = ConditionalAccessPolicy;
|
|
2699
|
+
_w = JSII_RTTI_SYMBOL_1;
|
|
2700
|
+
ConditionalAccessPolicy[_w] = { fqn: "@cdktn/provider-azuread.conditionalAccessPolicy.ConditionalAccessPolicy", version: "15.0.0" };
|
|
2701
|
+
// =================
|
|
2702
|
+
// STATIC PROPERTIES
|
|
2703
|
+
// =================
|
|
2704
|
+
ConditionalAccessPolicy.tfResourceType = "azuread_conditional_access_policy";
|
|
2705
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/conditional-access-policy/index.ts"],"names":[],"mappings":"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","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/conditional_access_policy\n// generated from terraform resource schema\n\nimport { Construct } from 'constructs';\nimport * as cdktn from 'cdktn';\n\n// Configuration\n\nexport interface ConditionalAccessPolicyConfig extends cdktn.TerraformMetaArguments {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#display_name ConditionalAccessPolicy#display_name}\n  */\n  readonly displayName: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#id ConditionalAccessPolicy#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  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#state ConditionalAccessPolicy#state}\n  */\n  readonly state: string;\n  /**\n  * conditions block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#conditions ConditionalAccessPolicy#conditions}\n  */\n  readonly conditions: ConditionalAccessPolicyConditions;\n  /**\n  * grant_controls block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#grant_controls ConditionalAccessPolicy#grant_controls}\n  */\n  readonly grantControls?: ConditionalAccessPolicyGrantControls;\n  /**\n  * session_controls block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#session_controls ConditionalAccessPolicy#session_controls}\n  */\n  readonly sessionControls?: ConditionalAccessPolicySessionControls;\n  /**\n  * timeouts block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#timeouts ConditionalAccessPolicy#timeouts}\n  */\n  readonly timeouts?: ConditionalAccessPolicyTimeouts;\n}\nexport interface ConditionalAccessPolicyConditionsApplications {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_applications ConditionalAccessPolicy#excluded_applications}\n  */\n  readonly excludedApplications?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_applications ConditionalAccessPolicy#included_applications}\n  */\n  readonly includedApplications?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_user_actions ConditionalAccessPolicy#included_user_actions}\n  */\n  readonly includedUserActions?: string[];\n}\n\nexport function conditionalAccessPolicyConditionsApplicationsToTerraform(struct?: ConditionalAccessPolicyConditionsApplicationsOutputReference | ConditionalAccessPolicyConditionsApplications): 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    excluded_applications: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedApplications),\n    included_applications: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedApplications),\n    included_user_actions: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedUserActions),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsApplicationsToHclTerraform(struct?: ConditionalAccessPolicyConditionsApplicationsOutputReference | ConditionalAccessPolicyConditionsApplications): 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    excluded_applications: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedApplications),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_applications: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedApplications),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_user_actions: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedUserActions),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\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 ConditionalAccessPolicyConditionsApplicationsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsApplications | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._excludedApplications !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedApplications = this._excludedApplications;\n    }\n    if (this._includedApplications !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedApplications = this._includedApplications;\n    }\n    if (this._includedUserActions !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedUserActions = this._includedUserActions;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsApplications | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._excludedApplications = undefined;\n      this._includedApplications = undefined;\n      this._includedUserActions = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._excludedApplications = value.excludedApplications;\n      this._includedApplications = value.includedApplications;\n      this._includedUserActions = value.includedUserActions;\n    }\n  }\n\n  // excluded_applications - computed: false, optional: true, required: false\n  private _excludedApplications?: string[]; \n  public get excludedApplications() {\n    return this.getListAttribute('excluded_applications');\n  }\n  public set excludedApplications(value: string[]) {\n    this._excludedApplications = value;\n  }\n  public resetExcludedApplications() {\n    this._excludedApplications = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedApplicationsInput() {\n    return this._excludedApplications;\n  }\n\n  // included_applications - computed: false, optional: true, required: false\n  private _includedApplications?: string[]; \n  public get includedApplications() {\n    return this.getListAttribute('included_applications');\n  }\n  public set includedApplications(value: string[]) {\n    this._includedApplications = value;\n  }\n  public resetIncludedApplications() {\n    this._includedApplications = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedApplicationsInput() {\n    return this._includedApplications;\n  }\n\n  // included_user_actions - computed: false, optional: true, required: false\n  private _includedUserActions?: string[]; \n  public get includedUserActions() {\n    return this.getListAttribute('included_user_actions');\n  }\n  public set includedUserActions(value: string[]) {\n    this._includedUserActions = value;\n  }\n  public resetIncludedUserActions() {\n    this._includedUserActions = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedUserActionsInput() {\n    return this._includedUserActions;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsClientApplicationsFilter {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#mode ConditionalAccessPolicy#mode}\n  */\n  readonly mode: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#rule ConditionalAccessPolicy#rule}\n  */\n  readonly rule: string;\n}\n\nexport function conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform(struct?: ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference | ConditionalAccessPolicyConditionsClientApplicationsFilter): 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    mode: cdktn.stringToTerraform(struct!.mode),\n    rule: cdktn.stringToTerraform(struct!.rule),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform(struct?: ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference | ConditionalAccessPolicyConditionsClientApplicationsFilter): 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    mode: {\n      value: cdktn.stringToHclTerraform(struct!.mode),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    rule: {\n      value: cdktn.stringToHclTerraform(struct!.rule),\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 ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsClientApplicationsFilter | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._mode !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.mode = this._mode;\n    }\n    if (this._rule !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.rule = this._rule;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsClientApplicationsFilter | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._mode = undefined;\n      this._rule = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._mode = value.mode;\n      this._rule = value.rule;\n    }\n  }\n\n  // mode - computed: false, optional: false, required: true\n  private _mode?: string; \n  public get mode() {\n    return this.getStringAttribute('mode');\n  }\n  public set mode(value: string) {\n    this._mode = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get modeInput() {\n    return this._mode;\n  }\n\n  // rule - computed: false, optional: false, required: true\n  private _rule?: string; \n  public get rule() {\n    return this.getStringAttribute('rule');\n  }\n  public set rule(value: string) {\n    this._rule = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ruleInput() {\n    return this._rule;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsClientApplications {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_service_principals ConditionalAccessPolicy#excluded_service_principals}\n  */\n  readonly excludedServicePrincipals?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_service_principals ConditionalAccessPolicy#included_service_principals}\n  */\n  readonly includedServicePrincipals?: string[];\n  /**\n  * filter block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#filter ConditionalAccessPolicy#filter}\n  */\n  readonly filter?: ConditionalAccessPolicyConditionsClientApplicationsFilter;\n}\n\nexport function conditionalAccessPolicyConditionsClientApplicationsToTerraform(struct?: ConditionalAccessPolicyConditionsClientApplicationsOutputReference | ConditionalAccessPolicyConditionsClientApplications): 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    excluded_service_principals: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedServicePrincipals),\n    included_service_principals: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedServicePrincipals),\n    filter: conditionalAccessPolicyConditionsClientApplicationsFilterToTerraform(struct!.filter),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsClientApplicationsToHclTerraform(struct?: ConditionalAccessPolicyConditionsClientApplicationsOutputReference | ConditionalAccessPolicyConditionsClientApplications): 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    excluded_service_principals: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedServicePrincipals),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_service_principals: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedServicePrincipals),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    filter: {\n      value: conditionalAccessPolicyConditionsClientApplicationsFilterToHclTerraform(struct!.filter),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsClientApplicationsFilterList\",\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 ConditionalAccessPolicyConditionsClientApplicationsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsClientApplications | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._excludedServicePrincipals !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedServicePrincipals = this._excludedServicePrincipals;\n    }\n    if (this._includedServicePrincipals !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedServicePrincipals = this._includedServicePrincipals;\n    }\n    if (this._filter?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.filter = this._filter?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsClientApplications | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._excludedServicePrincipals = undefined;\n      this._includedServicePrincipals = undefined;\n      this._filter.internalValue = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._excludedServicePrincipals = value.excludedServicePrincipals;\n      this._includedServicePrincipals = value.includedServicePrincipals;\n      this._filter.internalValue = value.filter;\n    }\n  }\n\n  // excluded_service_principals - computed: false, optional: true, required: false\n  private _excludedServicePrincipals?: string[]; \n  public get excludedServicePrincipals() {\n    return this.getListAttribute('excluded_service_principals');\n  }\n  public set excludedServicePrincipals(value: string[]) {\n    this._excludedServicePrincipals = value;\n  }\n  public resetExcludedServicePrincipals() {\n    this._excludedServicePrincipals = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedServicePrincipalsInput() {\n    return this._excludedServicePrincipals;\n  }\n\n  // included_service_principals - computed: false, optional: true, required: false\n  private _includedServicePrincipals?: string[]; \n  public get includedServicePrincipals() {\n    return this.getListAttribute('included_service_principals');\n  }\n  public set includedServicePrincipals(value: string[]) {\n    this._includedServicePrincipals = value;\n  }\n  public resetIncludedServicePrincipals() {\n    this._includedServicePrincipals = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedServicePrincipalsInput() {\n    return this._includedServicePrincipals;\n  }\n\n  // filter - computed: false, optional: true, required: false\n  private _filter = new ConditionalAccessPolicyConditionsClientApplicationsFilterOutputReference(this, \"filter\");\n  public get filter() {\n    return this._filter;\n  }\n  public putFilter(value: ConditionalAccessPolicyConditionsClientApplicationsFilter) {\n    this._filter.internalValue = value;\n  }\n  public resetFilter() {\n    this._filter.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get filterInput() {\n    return this._filter.internalValue;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsDevicesFilter {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#mode ConditionalAccessPolicy#mode}\n  */\n  readonly mode: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#rule ConditionalAccessPolicy#rule}\n  */\n  readonly rule: string;\n}\n\nexport function conditionalAccessPolicyConditionsDevicesFilterToTerraform(struct?: ConditionalAccessPolicyConditionsDevicesFilterOutputReference | ConditionalAccessPolicyConditionsDevicesFilter): 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    mode: cdktn.stringToTerraform(struct!.mode),\n    rule: cdktn.stringToTerraform(struct!.rule),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsDevicesFilterToHclTerraform(struct?: ConditionalAccessPolicyConditionsDevicesFilterOutputReference | ConditionalAccessPolicyConditionsDevicesFilter): 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    mode: {\n      value: cdktn.stringToHclTerraform(struct!.mode),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    rule: {\n      value: cdktn.stringToHclTerraform(struct!.rule),\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 ConditionalAccessPolicyConditionsDevicesFilterOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsDevicesFilter | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._mode !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.mode = this._mode;\n    }\n    if (this._rule !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.rule = this._rule;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsDevicesFilter | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._mode = undefined;\n      this._rule = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._mode = value.mode;\n      this._rule = value.rule;\n    }\n  }\n\n  // mode - computed: false, optional: false, required: true\n  private _mode?: string; \n  public get mode() {\n    return this.getStringAttribute('mode');\n  }\n  public set mode(value: string) {\n    this._mode = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get modeInput() {\n    return this._mode;\n  }\n\n  // rule - computed: false, optional: false, required: true\n  private _rule?: string; \n  public get rule() {\n    return this.getStringAttribute('rule');\n  }\n  public set rule(value: string) {\n    this._rule = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get ruleInput() {\n    return this._rule;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsDevices {\n  /**\n  * filter block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#filter ConditionalAccessPolicy#filter}\n  */\n  readonly filter?: ConditionalAccessPolicyConditionsDevicesFilter;\n}\n\nexport function conditionalAccessPolicyConditionsDevicesToTerraform(struct?: ConditionalAccessPolicyConditionsDevicesOutputReference | ConditionalAccessPolicyConditionsDevices): 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    filter: conditionalAccessPolicyConditionsDevicesFilterToTerraform(struct!.filter),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsDevicesToHclTerraform(struct?: ConditionalAccessPolicyConditionsDevicesOutputReference | ConditionalAccessPolicyConditionsDevices): 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    filter: {\n      value: conditionalAccessPolicyConditionsDevicesFilterToHclTerraform(struct!.filter),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsDevicesFilterList\",\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 ConditionalAccessPolicyConditionsDevicesOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsDevices | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._filter?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.filter = this._filter?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsDevices | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._filter.internalValue = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._filter.internalValue = value.filter;\n    }\n  }\n\n  // filter - computed: false, optional: true, required: false\n  private _filter = new ConditionalAccessPolicyConditionsDevicesFilterOutputReference(this, \"filter\");\n  public get filter() {\n    return this._filter;\n  }\n  public putFilter(value: ConditionalAccessPolicyConditionsDevicesFilter) {\n    this._filter.internalValue = value;\n  }\n  public resetFilter() {\n    this._filter.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get filterInput() {\n    return this._filter.internalValue;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsLocations {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_locations ConditionalAccessPolicy#excluded_locations}\n  */\n  readonly excludedLocations?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_locations ConditionalAccessPolicy#included_locations}\n  */\n  readonly includedLocations: string[];\n}\n\nexport function conditionalAccessPolicyConditionsLocationsToTerraform(struct?: ConditionalAccessPolicyConditionsLocationsOutputReference | ConditionalAccessPolicyConditionsLocations): 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    excluded_locations: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedLocations),\n    included_locations: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedLocations),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsLocationsToHclTerraform(struct?: ConditionalAccessPolicyConditionsLocationsOutputReference | ConditionalAccessPolicyConditionsLocations): 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    excluded_locations: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedLocations),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_locations: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedLocations),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\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 ConditionalAccessPolicyConditionsLocationsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsLocations | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._excludedLocations !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedLocations = this._excludedLocations;\n    }\n    if (this._includedLocations !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedLocations = this._includedLocations;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsLocations | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._excludedLocations = undefined;\n      this._includedLocations = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._excludedLocations = value.excludedLocations;\n      this._includedLocations = value.includedLocations;\n    }\n  }\n\n  // excluded_locations - computed: false, optional: true, required: false\n  private _excludedLocations?: string[]; \n  public get excludedLocations() {\n    return this.getListAttribute('excluded_locations');\n  }\n  public set excludedLocations(value: string[]) {\n    this._excludedLocations = value;\n  }\n  public resetExcludedLocations() {\n    this._excludedLocations = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedLocationsInput() {\n    return this._excludedLocations;\n  }\n\n  // included_locations - computed: false, optional: false, required: true\n  private _includedLocations?: string[]; \n  public get includedLocations() {\n    return this.getListAttribute('included_locations');\n  }\n  public set includedLocations(value: string[]) {\n    this._includedLocations = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedLocationsInput() {\n    return this._includedLocations;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsPlatforms {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_platforms ConditionalAccessPolicy#excluded_platforms}\n  */\n  readonly excludedPlatforms?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_platforms ConditionalAccessPolicy#included_platforms}\n  */\n  readonly includedPlatforms: string[];\n}\n\nexport function conditionalAccessPolicyConditionsPlatformsToTerraform(struct?: ConditionalAccessPolicyConditionsPlatformsOutputReference | ConditionalAccessPolicyConditionsPlatforms): 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    excluded_platforms: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedPlatforms),\n    included_platforms: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedPlatforms),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsPlatformsToHclTerraform(struct?: ConditionalAccessPolicyConditionsPlatformsOutputReference | ConditionalAccessPolicyConditionsPlatforms): 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    excluded_platforms: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedPlatforms),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_platforms: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedPlatforms),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\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 ConditionalAccessPolicyConditionsPlatformsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsPlatforms | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._excludedPlatforms !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedPlatforms = this._excludedPlatforms;\n    }\n    if (this._includedPlatforms !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedPlatforms = this._includedPlatforms;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsPlatforms | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._excludedPlatforms = undefined;\n      this._includedPlatforms = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._excludedPlatforms = value.excludedPlatforms;\n      this._includedPlatforms = value.includedPlatforms;\n    }\n  }\n\n  // excluded_platforms - computed: false, optional: true, required: false\n  private _excludedPlatforms?: string[]; \n  public get excludedPlatforms() {\n    return this.getListAttribute('excluded_platforms');\n  }\n  public set excludedPlatforms(value: string[]) {\n    this._excludedPlatforms = value;\n  }\n  public resetExcludedPlatforms() {\n    this._excludedPlatforms = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedPlatformsInput() {\n    return this._excludedPlatforms;\n  }\n\n  // included_platforms - computed: false, optional: false, required: true\n  private _includedPlatforms?: string[]; \n  public get includedPlatforms() {\n    return this.getListAttribute('included_platforms');\n  }\n  public set includedPlatforms(value: string[]) {\n    this._includedPlatforms = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedPlatformsInput() {\n    return this._includedPlatforms;\n  }\n}\nexport interface ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#members ConditionalAccessPolicy#members}\n  */\n  readonly members?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#membership_kind ConditionalAccessPolicy#membership_kind}\n  */\n  readonly membershipKind: string;\n}\n\nexport function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform(struct?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants | 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    members: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.members),\n    membership_kind: cdktn.stringToTerraform(struct!.membershipKind),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform(struct?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants | 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    members: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.members),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    membership_kind: {\n      value: cdktn.stringToHclTerraform(struct!.membershipKind),\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 ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference 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  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants | cdktn.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._members !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.members = this._members;\n    }\n    if (this._membershipKind !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.membershipKind = this._membershipKind;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants | cdktn.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._members = undefined;\n      this._membershipKind = 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._members = value.members;\n      this._membershipKind = value.membershipKind;\n    }\n  }\n\n  // members - computed: false, optional: true, required: false\n  private _members?: string[]; \n  public get members() {\n    return this.getListAttribute('members');\n  }\n  public set members(value: string[]) {\n    this._members = value;\n  }\n  public resetMembers() {\n    this._members = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get membersInput() {\n    return this._members;\n  }\n\n  // membership_kind - computed: false, optional: false, required: true\n  private _membershipKind?: string; \n  public get membershipKind() {\n    return this.getStringAttribute('membership_kind');\n  }\n  public set membershipKind(value: string) {\n    this._membershipKind = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get membershipKindInput() {\n    return this._membershipKind;\n  }\n}\n\nexport class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList extends cdktn.ComplexList {\n  public internalValue? : ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktn.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference {\n    return new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#guest_or_external_user_types ConditionalAccessPolicy#guest_or_external_user_types}\n  */\n  readonly guestOrExternalUserTypes: string[];\n  /**\n  * external_tenants block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#external_tenants ConditionalAccessPolicy#external_tenants}\n  */\n  readonly externalTenants?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable;\n}\n\nexport function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform(struct?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers | 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    guest_or_external_user_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.guestOrExternalUserTypes),\n    external_tenants: cdktn.listMapper(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToTerraform, true)(struct!.externalTenants),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform(struct?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers | 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    guest_or_external_user_types: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.guestOrExternalUserTypes),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    external_tenants: {\n      value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsToHclTerraform, true)(struct!.externalTenants),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList\",\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 ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference 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  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers | cdktn.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._guestOrExternalUserTypes !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.guestOrExternalUserTypes = this._guestOrExternalUserTypes;\n    }\n    if (this._externalTenants?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.externalTenants = this._externalTenants?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers | cdktn.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._guestOrExternalUserTypes = undefined;\n      this._externalTenants.internalValue = 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._guestOrExternalUserTypes = value.guestOrExternalUserTypes;\n      this._externalTenants.internalValue = value.externalTenants;\n    }\n  }\n\n  // guest_or_external_user_types - computed: false, optional: false, required: true\n  private _guestOrExternalUserTypes?: string[]; \n  public get guestOrExternalUserTypes() {\n    return this.getListAttribute('guest_or_external_user_types');\n  }\n  public set guestOrExternalUserTypes(value: string[]) {\n    this._guestOrExternalUserTypes = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get guestOrExternalUserTypesInput() {\n    return this._guestOrExternalUserTypes;\n  }\n\n  // external_tenants - computed: false, optional: true, required: false\n  private _externalTenants = new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenantsList(this, \"external_tenants\", false);\n  public get externalTenants() {\n    return this._externalTenants;\n  }\n  public putExternalTenants(value: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable) {\n    this._externalTenants.internalValue = value;\n  }\n  public resetExternalTenants() {\n    this._externalTenants.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get externalTenantsInput() {\n    return this._externalTenants.internalValue;\n  }\n}\n\nexport class ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList extends cdktn.ComplexList {\n  public internalValue? : ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers[] | cdktn.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktn.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference {\n    return new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#members ConditionalAccessPolicy#members}\n  */\n  readonly members?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#membership_kind ConditionalAccessPolicy#membership_kind}\n  */\n  readonly membershipKind: string;\n}\n\nexport function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform(struct?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants | 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    members: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.members),\n    membership_kind: cdktn.stringToTerraform(struct!.membershipKind),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform(struct?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants | 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    members: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.members),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    membership_kind: {\n      value: cdktn.stringToHclTerraform(struct!.membershipKind),\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 ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference 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  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants | cdktn.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._members !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.members = this._members;\n    }\n    if (this._membershipKind !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.membershipKind = this._membershipKind;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants | cdktn.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._members = undefined;\n      this._membershipKind = 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._members = value.members;\n      this._membershipKind = value.membershipKind;\n    }\n  }\n\n  // members - computed: false, optional: true, required: false\n  private _members?: string[]; \n  public get members() {\n    return this.getListAttribute('members');\n  }\n  public set members(value: string[]) {\n    this._members = value;\n  }\n  public resetMembers() {\n    this._members = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get membersInput() {\n    return this._members;\n  }\n\n  // membership_kind - computed: false, optional: false, required: true\n  private _membershipKind?: string; \n  public get membershipKind() {\n    return this.getStringAttribute('membership_kind');\n  }\n  public set membershipKind(value: string) {\n    this._membershipKind = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get membershipKindInput() {\n    return this._membershipKind;\n  }\n}\n\nexport class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList extends cdktn.ComplexList {\n  public internalValue? : ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktn.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference {\n    return new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#guest_or_external_user_types ConditionalAccessPolicy#guest_or_external_user_types}\n  */\n  readonly guestOrExternalUserTypes: string[];\n  /**\n  * external_tenants block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#external_tenants ConditionalAccessPolicy#external_tenants}\n  */\n  readonly externalTenants?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable;\n}\n\nexport function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform(struct?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers | 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    guest_or_external_user_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.guestOrExternalUserTypes),\n    external_tenants: cdktn.listMapper(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToTerraform, true)(struct!.externalTenants),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform(struct?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers | 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    guest_or_external_user_types: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.guestOrExternalUserTypes),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    external_tenants: {\n      value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsToHclTerraform, true)(struct!.externalTenants),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList\",\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 ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference 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  * @param complexObjectIndex the index of this item in the list\n  * @param complexObjectIsFromSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  public constructor(terraformResource: cdktn.IInterpolatingParent, terraformAttribute: string, complexObjectIndex: number, complexObjectIsFromSet: boolean) {\n    super(terraformResource, terraformAttribute, complexObjectIsFromSet, complexObjectIndex);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers | cdktn.IResolvable | undefined {\n    if (this.resolvableValue) {\n      return this.resolvableValue;\n    }\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._guestOrExternalUserTypes !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.guestOrExternalUserTypes = this._guestOrExternalUserTypes;\n    }\n    if (this._externalTenants?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.externalTenants = this._externalTenants?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers | cdktn.IResolvable | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this.resolvableValue = undefined;\n      this._guestOrExternalUserTypes = undefined;\n      this._externalTenants.internalValue = 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._guestOrExternalUserTypes = value.guestOrExternalUserTypes;\n      this._externalTenants.internalValue = value.externalTenants;\n    }\n  }\n\n  // guest_or_external_user_types - computed: false, optional: false, required: true\n  private _guestOrExternalUserTypes?: string[]; \n  public get guestOrExternalUserTypes() {\n    return this.getListAttribute('guest_or_external_user_types');\n  }\n  public set guestOrExternalUserTypes(value: string[]) {\n    this._guestOrExternalUserTypes = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get guestOrExternalUserTypesInput() {\n    return this._guestOrExternalUserTypes;\n  }\n\n  // external_tenants - computed: false, optional: true, required: false\n  private _externalTenants = new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenantsList(this, \"external_tenants\", false);\n  public get externalTenants() {\n    return this._externalTenants;\n  }\n  public putExternalTenants(value: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersExternalTenants[] | cdktn.IResolvable) {\n    this._externalTenants.internalValue = value;\n  }\n  public resetExternalTenants() {\n    this._externalTenants.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get externalTenantsInput() {\n    return this._externalTenants.internalValue;\n  }\n}\n\nexport class ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList extends cdktn.ComplexList {\n  public internalValue? : ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers[] | cdktn.IResolvable\n\n  /**\n  * @param terraformResource The parent resource\n  * @param terraformAttribute The attribute on the parent resource this class is referencing\n  * @param wrapsSet whether the list is wrapping a set (will add tolist() to be able to access an item via an index)\n  */\n  constructor(protected terraformResource: cdktn.IInterpolatingParent, protected terraformAttribute: string, protected wrapsSet: boolean) {\n    super(terraformResource, terraformAttribute, wrapsSet)\n  }\n\n  /**\n  * @param index the index of the item to return\n  */\n  public get(index: number): ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference {\n    return new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersOutputReference(this.terraformResource, this.terraformAttribute, index, this.wrapsSet);\n  }\n}\nexport interface ConditionalAccessPolicyConditionsUsers {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_groups ConditionalAccessPolicy#excluded_groups}\n  */\n  readonly excludedGroups?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_roles ConditionalAccessPolicy#excluded_roles}\n  */\n  readonly excludedRoles?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_users ConditionalAccessPolicy#excluded_users}\n  */\n  readonly excludedUsers?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_groups ConditionalAccessPolicy#included_groups}\n  */\n  readonly includedGroups?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_roles ConditionalAccessPolicy#included_roles}\n  */\n  readonly includedRoles?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_users ConditionalAccessPolicy#included_users}\n  */\n  readonly includedUsers?: string[];\n  /**\n  * excluded_guests_or_external_users block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#excluded_guests_or_external_users ConditionalAccessPolicy#excluded_guests_or_external_users}\n  */\n  readonly excludedGuestsOrExternalUsers?: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers[] | cdktn.IResolvable;\n  /**\n  * included_guests_or_external_users block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#included_guests_or_external_users ConditionalAccessPolicy#included_guests_or_external_users}\n  */\n  readonly includedGuestsOrExternalUsers?: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers[] | cdktn.IResolvable;\n}\n\nexport function conditionalAccessPolicyConditionsUsersToTerraform(struct?: ConditionalAccessPolicyConditionsUsersOutputReference | ConditionalAccessPolicyConditionsUsers): 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    excluded_groups: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedGroups),\n    excluded_roles: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedRoles),\n    excluded_users: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.excludedUsers),\n    included_groups: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedGroups),\n    included_roles: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedRoles),\n    included_users: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.includedUsers),\n    excluded_guests_or_external_users: cdktn.listMapper(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToTerraform, true)(struct!.excludedGuestsOrExternalUsers),\n    included_guests_or_external_users: cdktn.listMapper(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToTerraform, true)(struct!.includedGuestsOrExternalUsers),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsUsersToHclTerraform(struct?: ConditionalAccessPolicyConditionsUsersOutputReference | ConditionalAccessPolicyConditionsUsers): 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    excluded_groups: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedGroups),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    excluded_roles: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedRoles),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    excluded_users: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.excludedUsers),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_groups: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedGroups),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_roles: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedRoles),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    included_users: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.includedUsers),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    excluded_guests_or_external_users: {\n      value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersToHclTerraform, true)(struct!.excludedGuestsOrExternalUsers),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList\",\n    },\n    included_guests_or_external_users: {\n      value: cdktn.listMapperHcl(conditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersToHclTerraform, true)(struct!.includedGuestsOrExternalUsers),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList\",\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 ConditionalAccessPolicyConditionsUsersOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditionsUsers | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._excludedGroups !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedGroups = this._excludedGroups;\n    }\n    if (this._excludedRoles !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedRoles = this._excludedRoles;\n    }\n    if (this._excludedUsers !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedUsers = this._excludedUsers;\n    }\n    if (this._includedGroups !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedGroups = this._includedGroups;\n    }\n    if (this._includedRoles !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedRoles = this._includedRoles;\n    }\n    if (this._includedUsers !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedUsers = this._includedUsers;\n    }\n    if (this._excludedGuestsOrExternalUsers?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.excludedGuestsOrExternalUsers = this._excludedGuestsOrExternalUsers?.internalValue;\n    }\n    if (this._includedGuestsOrExternalUsers?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.includedGuestsOrExternalUsers = this._includedGuestsOrExternalUsers?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditionsUsers | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._excludedGroups = undefined;\n      this._excludedRoles = undefined;\n      this._excludedUsers = undefined;\n      this._includedGroups = undefined;\n      this._includedRoles = undefined;\n      this._includedUsers = undefined;\n      this._excludedGuestsOrExternalUsers.internalValue = undefined;\n      this._includedGuestsOrExternalUsers.internalValue = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._excludedGroups = value.excludedGroups;\n      this._excludedRoles = value.excludedRoles;\n      this._excludedUsers = value.excludedUsers;\n      this._includedGroups = value.includedGroups;\n      this._includedRoles = value.includedRoles;\n      this._includedUsers = value.includedUsers;\n      this._excludedGuestsOrExternalUsers.internalValue = value.excludedGuestsOrExternalUsers;\n      this._includedGuestsOrExternalUsers.internalValue = value.includedGuestsOrExternalUsers;\n    }\n  }\n\n  // excluded_groups - computed: false, optional: true, required: false\n  private _excludedGroups?: string[]; \n  public get excludedGroups() {\n    return this.getListAttribute('excluded_groups');\n  }\n  public set excludedGroups(value: string[]) {\n    this._excludedGroups = value;\n  }\n  public resetExcludedGroups() {\n    this._excludedGroups = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedGroupsInput() {\n    return this._excludedGroups;\n  }\n\n  // excluded_roles - computed: false, optional: true, required: false\n  private _excludedRoles?: string[]; \n  public get excludedRoles() {\n    return this.getListAttribute('excluded_roles');\n  }\n  public set excludedRoles(value: string[]) {\n    this._excludedRoles = value;\n  }\n  public resetExcludedRoles() {\n    this._excludedRoles = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedRolesInput() {\n    return this._excludedRoles;\n  }\n\n  // excluded_users - computed: false, optional: true, required: false\n  private _excludedUsers?: string[]; \n  public get excludedUsers() {\n    return this.getListAttribute('excluded_users');\n  }\n  public set excludedUsers(value: string[]) {\n    this._excludedUsers = value;\n  }\n  public resetExcludedUsers() {\n    this._excludedUsers = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedUsersInput() {\n    return this._excludedUsers;\n  }\n\n  // included_groups - computed: false, optional: true, required: false\n  private _includedGroups?: string[]; \n  public get includedGroups() {\n    return this.getListAttribute('included_groups');\n  }\n  public set includedGroups(value: string[]) {\n    this._includedGroups = value;\n  }\n  public resetIncludedGroups() {\n    this._includedGroups = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedGroupsInput() {\n    return this._includedGroups;\n  }\n\n  // included_roles - computed: false, optional: true, required: false\n  private _includedRoles?: string[]; \n  public get includedRoles() {\n    return this.getListAttribute('included_roles');\n  }\n  public set includedRoles(value: string[]) {\n    this._includedRoles = value;\n  }\n  public resetIncludedRoles() {\n    this._includedRoles = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedRolesInput() {\n    return this._includedRoles;\n  }\n\n  // included_users - computed: false, optional: true, required: false\n  private _includedUsers?: string[]; \n  public get includedUsers() {\n    return this.getListAttribute('included_users');\n  }\n  public set includedUsers(value: string[]) {\n    this._includedUsers = value;\n  }\n  public resetIncludedUsers() {\n    this._includedUsers = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedUsersInput() {\n    return this._includedUsers;\n  }\n\n  // excluded_guests_or_external_users - computed: false, optional: true, required: false\n  private _excludedGuestsOrExternalUsers = new ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsersList(this, \"excluded_guests_or_external_users\", false);\n  public get excludedGuestsOrExternalUsers() {\n    return this._excludedGuestsOrExternalUsers;\n  }\n  public putExcludedGuestsOrExternalUsers(value: ConditionalAccessPolicyConditionsUsersExcludedGuestsOrExternalUsers[] | cdktn.IResolvable) {\n    this._excludedGuestsOrExternalUsers.internalValue = value;\n  }\n  public resetExcludedGuestsOrExternalUsers() {\n    this._excludedGuestsOrExternalUsers.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get excludedGuestsOrExternalUsersInput() {\n    return this._excludedGuestsOrExternalUsers.internalValue;\n  }\n\n  // included_guests_or_external_users - computed: false, optional: true, required: false\n  private _includedGuestsOrExternalUsers = new ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsersList(this, \"included_guests_or_external_users\", false);\n  public get includedGuestsOrExternalUsers() {\n    return this._includedGuestsOrExternalUsers;\n  }\n  public putIncludedGuestsOrExternalUsers(value: ConditionalAccessPolicyConditionsUsersIncludedGuestsOrExternalUsers[] | cdktn.IResolvable) {\n    this._includedGuestsOrExternalUsers.internalValue = value;\n  }\n  public resetIncludedGuestsOrExternalUsers() {\n    this._includedGuestsOrExternalUsers.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get includedGuestsOrExternalUsersInput() {\n    return this._includedGuestsOrExternalUsers.internalValue;\n  }\n}\nexport interface ConditionalAccessPolicyConditions {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#authentication_flow_transfer_methods ConditionalAccessPolicy#authentication_flow_transfer_methods}\n  */\n  readonly authenticationFlowTransferMethods?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#client_app_types ConditionalAccessPolicy#client_app_types}\n  */\n  readonly clientAppTypes: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#insider_risk_levels ConditionalAccessPolicy#insider_risk_levels}\n  */\n  readonly insiderRiskLevels?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#service_principal_risk_levels ConditionalAccessPolicy#service_principal_risk_levels}\n  */\n  readonly servicePrincipalRiskLevels?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#sign_in_risk_levels ConditionalAccessPolicy#sign_in_risk_levels}\n  */\n  readonly signInRiskLevels?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#user_risk_levels ConditionalAccessPolicy#user_risk_levels}\n  */\n  readonly userRiskLevels?: string[];\n  /**\n  * applications block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#applications ConditionalAccessPolicy#applications}\n  */\n  readonly applications: ConditionalAccessPolicyConditionsApplications;\n  /**\n  * client_applications block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#client_applications ConditionalAccessPolicy#client_applications}\n  */\n  readonly clientApplications?: ConditionalAccessPolicyConditionsClientApplications;\n  /**\n  * devices block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#devices ConditionalAccessPolicy#devices}\n  */\n  readonly devices?: ConditionalAccessPolicyConditionsDevices;\n  /**\n  * locations block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#locations ConditionalAccessPolicy#locations}\n  */\n  readonly locations?: ConditionalAccessPolicyConditionsLocations;\n  /**\n  * platforms block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#platforms ConditionalAccessPolicy#platforms}\n  */\n  readonly platforms?: ConditionalAccessPolicyConditionsPlatforms;\n  /**\n  * users block\n  *\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#users ConditionalAccessPolicy#users}\n  */\n  readonly users: ConditionalAccessPolicyConditionsUsers;\n}\n\nexport function conditionalAccessPolicyConditionsToTerraform(struct?: ConditionalAccessPolicyConditionsOutputReference | ConditionalAccessPolicyConditions): 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    authentication_flow_transfer_methods: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.authenticationFlowTransferMethods),\n    client_app_types: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.clientAppTypes),\n    insider_risk_levels: cdktn.stringToTerraform(struct!.insiderRiskLevels),\n    service_principal_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.servicePrincipalRiskLevels),\n    sign_in_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.signInRiskLevels),\n    user_risk_levels: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.userRiskLevels),\n    applications: conditionalAccessPolicyConditionsApplicationsToTerraform(struct!.applications),\n    client_applications: conditionalAccessPolicyConditionsClientApplicationsToTerraform(struct!.clientApplications),\n    devices: conditionalAccessPolicyConditionsDevicesToTerraform(struct!.devices),\n    locations: conditionalAccessPolicyConditionsLocationsToTerraform(struct!.locations),\n    platforms: conditionalAccessPolicyConditionsPlatformsToTerraform(struct!.platforms),\n    users: conditionalAccessPolicyConditionsUsersToTerraform(struct!.users),\n  }\n}\n\n\nexport function conditionalAccessPolicyConditionsToHclTerraform(struct?: ConditionalAccessPolicyConditionsOutputReference | ConditionalAccessPolicyConditions): 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    authentication_flow_transfer_methods: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.authenticationFlowTransferMethods),\n      isBlock: false,\n      type: \"set\",\n      storageClassType: \"stringList\",\n    },\n    client_app_types: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.clientAppTypes),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    insider_risk_levels: {\n      value: cdktn.stringToHclTerraform(struct!.insiderRiskLevels),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    service_principal_risk_levels: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.servicePrincipalRiskLevels),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    sign_in_risk_levels: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.signInRiskLevels),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    user_risk_levels: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.userRiskLevels),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    applications: {\n      value: conditionalAccessPolicyConditionsApplicationsToHclTerraform(struct!.applications),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsApplicationsList\",\n    },\n    client_applications: {\n      value: conditionalAccessPolicyConditionsClientApplicationsToHclTerraform(struct!.clientApplications),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsClientApplicationsList\",\n    },\n    devices: {\n      value: conditionalAccessPolicyConditionsDevicesToHclTerraform(struct!.devices),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsDevicesList\",\n    },\n    locations: {\n      value: conditionalAccessPolicyConditionsLocationsToHclTerraform(struct!.locations),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsLocationsList\",\n    },\n    platforms: {\n      value: conditionalAccessPolicyConditionsPlatformsToHclTerraform(struct!.platforms),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsPlatformsList\",\n    },\n    users: {\n      value: conditionalAccessPolicyConditionsUsersToHclTerraform(struct!.users),\n      isBlock: true,\n      type: \"list\",\n      storageClassType: \"ConditionalAccessPolicyConditionsUsersList\",\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 ConditionalAccessPolicyConditionsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyConditions | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._authenticationFlowTransferMethods !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.authenticationFlowTransferMethods = this._authenticationFlowTransferMethods;\n    }\n    if (this._clientAppTypes !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.clientAppTypes = this._clientAppTypes;\n    }\n    if (this._insiderRiskLevels !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.insiderRiskLevels = this._insiderRiskLevels;\n    }\n    if (this._servicePrincipalRiskLevels !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.servicePrincipalRiskLevels = this._servicePrincipalRiskLevels;\n    }\n    if (this._signInRiskLevels !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.signInRiskLevels = this._signInRiskLevels;\n    }\n    if (this._userRiskLevels !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.userRiskLevels = this._userRiskLevels;\n    }\n    if (this._applications?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.applications = this._applications?.internalValue;\n    }\n    if (this._clientApplications?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.clientApplications = this._clientApplications?.internalValue;\n    }\n    if (this._devices?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.devices = this._devices?.internalValue;\n    }\n    if (this._locations?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.locations = this._locations?.internalValue;\n    }\n    if (this._platforms?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.platforms = this._platforms?.internalValue;\n    }\n    if (this._users?.internalValue !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.users = this._users?.internalValue;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyConditions | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._authenticationFlowTransferMethods = undefined;\n      this._clientAppTypes = undefined;\n      this._insiderRiskLevels = undefined;\n      this._servicePrincipalRiskLevels = undefined;\n      this._signInRiskLevels = undefined;\n      this._userRiskLevels = undefined;\n      this._applications.internalValue = undefined;\n      this._clientApplications.internalValue = undefined;\n      this._devices.internalValue = undefined;\n      this._locations.internalValue = undefined;\n      this._platforms.internalValue = undefined;\n      this._users.internalValue = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._authenticationFlowTransferMethods = value.authenticationFlowTransferMethods;\n      this._clientAppTypes = value.clientAppTypes;\n      this._insiderRiskLevels = value.insiderRiskLevels;\n      this._servicePrincipalRiskLevels = value.servicePrincipalRiskLevels;\n      this._signInRiskLevels = value.signInRiskLevels;\n      this._userRiskLevels = value.userRiskLevels;\n      this._applications.internalValue = value.applications;\n      this._clientApplications.internalValue = value.clientApplications;\n      this._devices.internalValue = value.devices;\n      this._locations.internalValue = value.locations;\n      this._platforms.internalValue = value.platforms;\n      this._users.internalValue = value.users;\n    }\n  }\n\n  // authentication_flow_transfer_methods - computed: false, optional: true, required: false\n  private _authenticationFlowTransferMethods?: string[]; \n  public get authenticationFlowTransferMethods() {\n    return cdktn.Fn.tolist(this.getListAttribute('authentication_flow_transfer_methods'));\n  }\n  public set authenticationFlowTransferMethods(value: string[]) {\n    this._authenticationFlowTransferMethods = value;\n  }\n  public resetAuthenticationFlowTransferMethods() {\n    this._authenticationFlowTransferMethods = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get authenticationFlowTransferMethodsInput() {\n    return this._authenticationFlowTransferMethods;\n  }\n\n  // client_app_types - computed: false, optional: false, required: true\n  private _clientAppTypes?: string[]; \n  public get clientAppTypes() {\n    return this.getListAttribute('client_app_types');\n  }\n  public set clientAppTypes(value: string[]) {\n    this._clientAppTypes = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get clientAppTypesInput() {\n    return this._clientAppTypes;\n  }\n\n  // insider_risk_levels - computed: true, optional: true, required: false\n  private _insiderRiskLevels?: string; \n  public get insiderRiskLevels() {\n    return this.getStringAttribute('insider_risk_levels');\n  }\n  public set insiderRiskLevels(value: string) {\n    this._insiderRiskLevels = value;\n  }\n  public resetInsiderRiskLevels() {\n    this._insiderRiskLevels = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get insiderRiskLevelsInput() {\n    return this._insiderRiskLevels;\n  }\n\n  // service_principal_risk_levels - computed: false, optional: true, required: false\n  private _servicePrincipalRiskLevels?: string[]; \n  public get servicePrincipalRiskLevels() {\n    return this.getListAttribute('service_principal_risk_levels');\n  }\n  public set servicePrincipalRiskLevels(value: string[]) {\n    this._servicePrincipalRiskLevels = value;\n  }\n  public resetServicePrincipalRiskLevels() {\n    this._servicePrincipalRiskLevels = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get servicePrincipalRiskLevelsInput() {\n    return this._servicePrincipalRiskLevels;\n  }\n\n  // sign_in_risk_levels - computed: false, optional: true, required: false\n  private _signInRiskLevels?: string[]; \n  public get signInRiskLevels() {\n    return this.getListAttribute('sign_in_risk_levels');\n  }\n  public set signInRiskLevels(value: string[]) {\n    this._signInRiskLevels = value;\n  }\n  public resetSignInRiskLevels() {\n    this._signInRiskLevels = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get signInRiskLevelsInput() {\n    return this._signInRiskLevels;\n  }\n\n  // user_risk_levels - computed: false, optional: true, required: false\n  private _userRiskLevels?: string[]; \n  public get userRiskLevels() {\n    return this.getListAttribute('user_risk_levels');\n  }\n  public set userRiskLevels(value: string[]) {\n    this._userRiskLevels = value;\n  }\n  public resetUserRiskLevels() {\n    this._userRiskLevels = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get userRiskLevelsInput() {\n    return this._userRiskLevels;\n  }\n\n  // applications - computed: false, optional: false, required: true\n  private _applications = new ConditionalAccessPolicyConditionsApplicationsOutputReference(this, \"applications\");\n  public get applications() {\n    return this._applications;\n  }\n  public putApplications(value: ConditionalAccessPolicyConditionsApplications) {\n    this._applications.internalValue = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get applicationsInput() {\n    return this._applications.internalValue;\n  }\n\n  // client_applications - computed: false, optional: true, required: false\n  private _clientApplications = new ConditionalAccessPolicyConditionsClientApplicationsOutputReference(this, \"client_applications\");\n  public get clientApplications() {\n    return this._clientApplications;\n  }\n  public putClientApplications(value: ConditionalAccessPolicyConditionsClientApplications) {\n    this._clientApplications.internalValue = value;\n  }\n  public resetClientApplications() {\n    this._clientApplications.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get clientApplicationsInput() {\n    return this._clientApplications.internalValue;\n  }\n\n  // devices - computed: false, optional: true, required: false\n  private _devices = new ConditionalAccessPolicyConditionsDevicesOutputReference(this, \"devices\");\n  public get devices() {\n    return this._devices;\n  }\n  public putDevices(value: ConditionalAccessPolicyConditionsDevices) {\n    this._devices.internalValue = value;\n  }\n  public resetDevices() {\n    this._devices.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get devicesInput() {\n    return this._devices.internalValue;\n  }\n\n  // locations - computed: false, optional: true, required: false\n  private _locations = new ConditionalAccessPolicyConditionsLocationsOutputReference(this, \"locations\");\n  public get locations() {\n    return this._locations;\n  }\n  public putLocations(value: ConditionalAccessPolicyConditionsLocations) {\n    this._locations.internalValue = value;\n  }\n  public resetLocations() {\n    this._locations.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get locationsInput() {\n    return this._locations.internalValue;\n  }\n\n  // platforms - computed: false, optional: true, required: false\n  private _platforms = new ConditionalAccessPolicyConditionsPlatformsOutputReference(this, \"platforms\");\n  public get platforms() {\n    return this._platforms;\n  }\n  public putPlatforms(value: ConditionalAccessPolicyConditionsPlatforms) {\n    this._platforms.internalValue = value;\n  }\n  public resetPlatforms() {\n    this._platforms.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get platformsInput() {\n    return this._platforms.internalValue;\n  }\n\n  // users - computed: false, optional: false, required: true\n  private _users = new ConditionalAccessPolicyConditionsUsersOutputReference(this, \"users\");\n  public get users() {\n    return this._users;\n  }\n  public putUsers(value: ConditionalAccessPolicyConditionsUsers) {\n    this._users.internalValue = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get usersInput() {\n    return this._users.internalValue;\n  }\n}\nexport interface ConditionalAccessPolicyGrantControls {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#authentication_strength_policy_id ConditionalAccessPolicy#authentication_strength_policy_id}\n  */\n  readonly authenticationStrengthPolicyId?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#built_in_controls ConditionalAccessPolicy#built_in_controls}\n  */\n  readonly builtInControls?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#custom_authentication_factors ConditionalAccessPolicy#custom_authentication_factors}\n  */\n  readonly customAuthenticationFactors?: string[];\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#operator ConditionalAccessPolicy#operator}\n  */\n  readonly operator: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#terms_of_use ConditionalAccessPolicy#terms_of_use}\n  */\n  readonly termsOfUse?: string[];\n}\n\nexport function conditionalAccessPolicyGrantControlsToTerraform(struct?: ConditionalAccessPolicyGrantControlsOutputReference | ConditionalAccessPolicyGrantControls): 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    authentication_strength_policy_id: cdktn.stringToTerraform(struct!.authenticationStrengthPolicyId),\n    built_in_controls: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.builtInControls),\n    custom_authentication_factors: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.customAuthenticationFactors),\n    operator: cdktn.stringToTerraform(struct!.operator),\n    terms_of_use: cdktn.listMapper(cdktn.stringToTerraform, false)(struct!.termsOfUse),\n  }\n}\n\n\nexport function conditionalAccessPolicyGrantControlsToHclTerraform(struct?: ConditionalAccessPolicyGrantControlsOutputReference | ConditionalAccessPolicyGrantControls): 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    authentication_strength_policy_id: {\n      value: cdktn.stringToHclTerraform(struct!.authenticationStrengthPolicyId),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    built_in_controls: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.builtInControls),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    custom_authentication_factors: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.customAuthenticationFactors),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\n    },\n    operator: {\n      value: cdktn.stringToHclTerraform(struct!.operator),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    terms_of_use: {\n      value: cdktn.listMapperHcl(cdktn.stringToHclTerraform, false)(struct!.termsOfUse),\n      isBlock: false,\n      type: \"list\",\n      storageClassType: \"stringList\",\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 ConditionalAccessPolicyGrantControlsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicyGrantControls | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._authenticationStrengthPolicyId !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.authenticationStrengthPolicyId = this._authenticationStrengthPolicyId;\n    }\n    if (this._builtInControls !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.builtInControls = this._builtInControls;\n    }\n    if (this._customAuthenticationFactors !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.customAuthenticationFactors = this._customAuthenticationFactors;\n    }\n    if (this._operator !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.operator = this._operator;\n    }\n    if (this._termsOfUse !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.termsOfUse = this._termsOfUse;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicyGrantControls | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._authenticationStrengthPolicyId = undefined;\n      this._builtInControls = undefined;\n      this._customAuthenticationFactors = undefined;\n      this._operator = undefined;\n      this._termsOfUse = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._authenticationStrengthPolicyId = value.authenticationStrengthPolicyId;\n      this._builtInControls = value.builtInControls;\n      this._customAuthenticationFactors = value.customAuthenticationFactors;\n      this._operator = value.operator;\n      this._termsOfUse = value.termsOfUse;\n    }\n  }\n\n  // authentication_strength_policy_id - computed: false, optional: true, required: false\n  private _authenticationStrengthPolicyId?: string; \n  public get authenticationStrengthPolicyId() {\n    return this.getStringAttribute('authentication_strength_policy_id');\n  }\n  public set authenticationStrengthPolicyId(value: string) {\n    this._authenticationStrengthPolicyId = value;\n  }\n  public resetAuthenticationStrengthPolicyId() {\n    this._authenticationStrengthPolicyId = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get authenticationStrengthPolicyIdInput() {\n    return this._authenticationStrengthPolicyId;\n  }\n\n  // built_in_controls - computed: false, optional: true, required: false\n  private _builtInControls?: string[]; \n  public get builtInControls() {\n    return this.getListAttribute('built_in_controls');\n  }\n  public set builtInControls(value: string[]) {\n    this._builtInControls = value;\n  }\n  public resetBuiltInControls() {\n    this._builtInControls = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get builtInControlsInput() {\n    return this._builtInControls;\n  }\n\n  // custom_authentication_factors - computed: false, optional: true, required: false\n  private _customAuthenticationFactors?: string[]; \n  public get customAuthenticationFactors() {\n    return this.getListAttribute('custom_authentication_factors');\n  }\n  public set customAuthenticationFactors(value: string[]) {\n    this._customAuthenticationFactors = value;\n  }\n  public resetCustomAuthenticationFactors() {\n    this._customAuthenticationFactors = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get customAuthenticationFactorsInput() {\n    return this._customAuthenticationFactors;\n  }\n\n  // operator - computed: false, optional: false, required: true\n  private _operator?: string; \n  public get operator() {\n    return this.getStringAttribute('operator');\n  }\n  public set operator(value: string) {\n    this._operator = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get operatorInput() {\n    return this._operator;\n  }\n\n  // terms_of_use - computed: false, optional: true, required: false\n  private _termsOfUse?: string[]; \n  public get termsOfUse() {\n    return this.getListAttribute('terms_of_use');\n  }\n  public set termsOfUse(value: string[]) {\n    this._termsOfUse = value;\n  }\n  public resetTermsOfUse() {\n    this._termsOfUse = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get termsOfUseInput() {\n    return this._termsOfUse;\n  }\n}\nexport interface ConditionalAccessPolicySessionControls {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#application_enforced_restrictions_enabled ConditionalAccessPolicy#application_enforced_restrictions_enabled}\n  */\n  readonly applicationEnforcedRestrictionsEnabled?: boolean | cdktn.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#cloud_app_security_policy ConditionalAccessPolicy#cloud_app_security_policy}\n  */\n  readonly cloudAppSecurityPolicy?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#disable_resilience_defaults ConditionalAccessPolicy#disable_resilience_defaults}\n  */\n  readonly disableResilienceDefaults?: boolean | cdktn.IResolvable;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#persistent_browser_mode ConditionalAccessPolicy#persistent_browser_mode}\n  */\n  readonly persistentBrowserMode?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#sign_in_frequency ConditionalAccessPolicy#sign_in_frequency}\n  */\n  readonly signInFrequency?: number;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#sign_in_frequency_authentication_type ConditionalAccessPolicy#sign_in_frequency_authentication_type}\n  */\n  readonly signInFrequencyAuthenticationType?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#sign_in_frequency_interval ConditionalAccessPolicy#sign_in_frequency_interval}\n  */\n  readonly signInFrequencyInterval?: string;\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#sign_in_frequency_period ConditionalAccessPolicy#sign_in_frequency_period}\n  */\n  readonly signInFrequencyPeriod?: string;\n}\n\nexport function conditionalAccessPolicySessionControlsToTerraform(struct?: ConditionalAccessPolicySessionControlsOutputReference | ConditionalAccessPolicySessionControls): 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    application_enforced_restrictions_enabled: cdktn.booleanToTerraform(struct!.applicationEnforcedRestrictionsEnabled),\n    cloud_app_security_policy: cdktn.stringToTerraform(struct!.cloudAppSecurityPolicy),\n    disable_resilience_defaults: cdktn.booleanToTerraform(struct!.disableResilienceDefaults),\n    persistent_browser_mode: cdktn.stringToTerraform(struct!.persistentBrowserMode),\n    sign_in_frequency: cdktn.numberToTerraform(struct!.signInFrequency),\n    sign_in_frequency_authentication_type: cdktn.stringToTerraform(struct!.signInFrequencyAuthenticationType),\n    sign_in_frequency_interval: cdktn.stringToTerraform(struct!.signInFrequencyInterval),\n    sign_in_frequency_period: cdktn.stringToTerraform(struct!.signInFrequencyPeriod),\n  }\n}\n\n\nexport function conditionalAccessPolicySessionControlsToHclTerraform(struct?: ConditionalAccessPolicySessionControlsOutputReference | ConditionalAccessPolicySessionControls): 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    application_enforced_restrictions_enabled: {\n      value: cdktn.booleanToHclTerraform(struct!.applicationEnforcedRestrictionsEnabled),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"boolean\",\n    },\n    cloud_app_security_policy: {\n      value: cdktn.stringToHclTerraform(struct!.cloudAppSecurityPolicy),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    disable_resilience_defaults: {\n      value: cdktn.booleanToHclTerraform(struct!.disableResilienceDefaults),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"boolean\",\n    },\n    persistent_browser_mode: {\n      value: cdktn.stringToHclTerraform(struct!.persistentBrowserMode),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    sign_in_frequency: {\n      value: cdktn.numberToHclTerraform(struct!.signInFrequency),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"number\",\n    },\n    sign_in_frequency_authentication_type: {\n      value: cdktn.stringToHclTerraform(struct!.signInFrequencyAuthenticationType),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    sign_in_frequency_interval: {\n      value: cdktn.stringToHclTerraform(struct!.signInFrequencyInterval),\n      isBlock: false,\n      type: \"simple\",\n      storageClassType: \"string\",\n    },\n    sign_in_frequency_period: {\n      value: cdktn.stringToHclTerraform(struct!.signInFrequencyPeriod),\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 ConditionalAccessPolicySessionControlsOutputReference extends cdktn.ComplexObject {\n  private isEmptyObject = false;\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, 0);\n  }\n\n  public get internalValue(): ConditionalAccessPolicySessionControls | undefined {\n    let hasAnyValues = this.isEmptyObject;\n    const internalValueResult: any = {};\n    if (this._applicationEnforcedRestrictionsEnabled !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.applicationEnforcedRestrictionsEnabled = this._applicationEnforcedRestrictionsEnabled;\n    }\n    if (this._cloudAppSecurityPolicy !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.cloudAppSecurityPolicy = this._cloudAppSecurityPolicy;\n    }\n    if (this._disableResilienceDefaults !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.disableResilienceDefaults = this._disableResilienceDefaults;\n    }\n    if (this._persistentBrowserMode !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.persistentBrowserMode = this._persistentBrowserMode;\n    }\n    if (this._signInFrequency !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.signInFrequency = this._signInFrequency;\n    }\n    if (this._signInFrequencyAuthenticationType !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.signInFrequencyAuthenticationType = this._signInFrequencyAuthenticationType;\n    }\n    if (this._signInFrequencyInterval !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.signInFrequencyInterval = this._signInFrequencyInterval;\n    }\n    if (this._signInFrequencyPeriod !== undefined) {\n      hasAnyValues = true;\n      internalValueResult.signInFrequencyPeriod = this._signInFrequencyPeriod;\n    }\n    return hasAnyValues ? internalValueResult : undefined;\n  }\n\n  public set internalValue(value: ConditionalAccessPolicySessionControls | undefined) {\n    if (value === undefined) {\n      this.isEmptyObject = false;\n      this._applicationEnforcedRestrictionsEnabled = undefined;\n      this._cloudAppSecurityPolicy = undefined;\n      this._disableResilienceDefaults = undefined;\n      this._persistentBrowserMode = undefined;\n      this._signInFrequency = undefined;\n      this._signInFrequencyAuthenticationType = undefined;\n      this._signInFrequencyInterval = undefined;\n      this._signInFrequencyPeriod = undefined;\n    }\n    else {\n      this.isEmptyObject = Object.keys(value).length === 0;\n      this._applicationEnforcedRestrictionsEnabled = value.applicationEnforcedRestrictionsEnabled;\n      this._cloudAppSecurityPolicy = value.cloudAppSecurityPolicy;\n      this._disableResilienceDefaults = value.disableResilienceDefaults;\n      this._persistentBrowserMode = value.persistentBrowserMode;\n      this._signInFrequency = value.signInFrequency;\n      this._signInFrequencyAuthenticationType = value.signInFrequencyAuthenticationType;\n      this._signInFrequencyInterval = value.signInFrequencyInterval;\n      this._signInFrequencyPeriod = value.signInFrequencyPeriod;\n    }\n  }\n\n  // application_enforced_restrictions_enabled - computed: false, optional: true, required: false\n  private _applicationEnforcedRestrictionsEnabled?: boolean | cdktn.IResolvable; \n  public get applicationEnforcedRestrictionsEnabled() {\n    return this.getBooleanAttribute('application_enforced_restrictions_enabled');\n  }\n  public set applicationEnforcedRestrictionsEnabled(value: boolean | cdktn.IResolvable) {\n    this._applicationEnforcedRestrictionsEnabled = value;\n  }\n  public resetApplicationEnforcedRestrictionsEnabled() {\n    this._applicationEnforcedRestrictionsEnabled = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get applicationEnforcedRestrictionsEnabledInput() {\n    return this._applicationEnforcedRestrictionsEnabled;\n  }\n\n  // cloud_app_security_policy - computed: false, optional: true, required: false\n  private _cloudAppSecurityPolicy?: string; \n  public get cloudAppSecurityPolicy() {\n    return this.getStringAttribute('cloud_app_security_policy');\n  }\n  public set cloudAppSecurityPolicy(value: string) {\n    this._cloudAppSecurityPolicy = value;\n  }\n  public resetCloudAppSecurityPolicy() {\n    this._cloudAppSecurityPolicy = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get cloudAppSecurityPolicyInput() {\n    return this._cloudAppSecurityPolicy;\n  }\n\n  // disable_resilience_defaults - computed: false, optional: true, required: false\n  private _disableResilienceDefaults?: boolean | cdktn.IResolvable; \n  public get disableResilienceDefaults() {\n    return this.getBooleanAttribute('disable_resilience_defaults');\n  }\n  public set disableResilienceDefaults(value: boolean | cdktn.IResolvable) {\n    this._disableResilienceDefaults = value;\n  }\n  public resetDisableResilienceDefaults() {\n    this._disableResilienceDefaults = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get disableResilienceDefaultsInput() {\n    return this._disableResilienceDefaults;\n  }\n\n  // persistent_browser_mode - computed: false, optional: true, required: false\n  private _persistentBrowserMode?: string; \n  public get persistentBrowserMode() {\n    return this.getStringAttribute('persistent_browser_mode');\n  }\n  public set persistentBrowserMode(value: string) {\n    this._persistentBrowserMode = value;\n  }\n  public resetPersistentBrowserMode() {\n    this._persistentBrowserMode = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get persistentBrowserModeInput() {\n    return this._persistentBrowserMode;\n  }\n\n  // sign_in_frequency - computed: false, optional: true, required: false\n  private _signInFrequency?: number; \n  public get signInFrequency() {\n    return this.getNumberAttribute('sign_in_frequency');\n  }\n  public set signInFrequency(value: number) {\n    this._signInFrequency = value;\n  }\n  public resetSignInFrequency() {\n    this._signInFrequency = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get signInFrequencyInput() {\n    return this._signInFrequency;\n  }\n\n  // sign_in_frequency_authentication_type - computed: true, optional: true, required: false\n  private _signInFrequencyAuthenticationType?: string; \n  public get signInFrequencyAuthenticationType() {\n    return this.getStringAttribute('sign_in_frequency_authentication_type');\n  }\n  public set signInFrequencyAuthenticationType(value: string) {\n    this._signInFrequencyAuthenticationType = value;\n  }\n  public resetSignInFrequencyAuthenticationType() {\n    this._signInFrequencyAuthenticationType = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get signInFrequencyAuthenticationTypeInput() {\n    return this._signInFrequencyAuthenticationType;\n  }\n\n  // sign_in_frequency_interval - computed: true, optional: true, required: false\n  private _signInFrequencyInterval?: string; \n  public get signInFrequencyInterval() {\n    return this.getStringAttribute('sign_in_frequency_interval');\n  }\n  public set signInFrequencyInterval(value: string) {\n    this._signInFrequencyInterval = value;\n  }\n  public resetSignInFrequencyInterval() {\n    this._signInFrequencyInterval = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get signInFrequencyIntervalInput() {\n    return this._signInFrequencyInterval;\n  }\n\n  // sign_in_frequency_period - computed: false, optional: true, required: false\n  private _signInFrequencyPeriod?: string; \n  public get signInFrequencyPeriod() {\n    return this.getStringAttribute('sign_in_frequency_period');\n  }\n  public set signInFrequencyPeriod(value: string) {\n    this._signInFrequencyPeriod = value;\n  }\n  public resetSignInFrequencyPeriod() {\n    this._signInFrequencyPeriod = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get signInFrequencyPeriodInput() {\n    return this._signInFrequencyPeriod;\n  }\n}\nexport interface ConditionalAccessPolicyTimeouts {\n  /**\n  * Docs at Terraform Registry: {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#create ConditionalAccessPolicy#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/conditional_access_policy#delete ConditionalAccessPolicy#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/conditional_access_policy#read ConditionalAccessPolicy#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/conditional_access_policy#update ConditionalAccessPolicy#update}\n  */\n  readonly update?: string;\n}\n\nexport function conditionalAccessPolicyTimeoutsToTerraform(struct?: ConditionalAccessPolicyTimeouts | 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 conditionalAccessPolicyTimeoutsToHclTerraform(struct?: ConditionalAccessPolicyTimeouts | 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 ConditionalAccessPolicyTimeoutsOutputReference 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(): ConditionalAccessPolicyTimeouts | 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: ConditionalAccessPolicyTimeouts | 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/conditional_access_policy azuread_conditional_access_policy}\n*/\nexport class ConditionalAccessPolicy extends cdktn.TerraformResource {\n\n  // =================\n  // STATIC PROPERTIES\n  // =================\n  public static readonly tfResourceType = \"azuread_conditional_access_policy\";\n\n  // ==============\n  // STATIC Methods\n  // ==============\n  /**\n  * Generates CDKTN code for importing a ConditionalAccessPolicy 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 ConditionalAccessPolicy to import\n  * @param importFromId The id of the existing ConditionalAccessPolicy that should be imported. Refer to the {@link https://registry.terraform.io/providers/hashicorp/azuread/3.7.0/docs/resources/conditional_access_policy#import import section} in the documentation of this resource for the id to use\n  * @param provider? Optional instance of the provider where the ConditionalAccessPolicy 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_conditional_access_policy\", 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/conditional_access_policy azuread_conditional_access_policy} 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 ConditionalAccessPolicyConfig\n  */\n  public constructor(scope: Construct, id: string, config: ConditionalAccessPolicyConfig) {\n    super(scope, id, {\n      terraformResourceType: 'azuread_conditional_access_policy',\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._displayName = config.displayName;\n    this._id = config.id;\n    this._state = config.state;\n    this._conditions.internalValue = config.conditions;\n    this._grantControls.internalValue = config.grantControls;\n    this._sessionControls.internalValue = config.sessionControls;\n    this._timeouts.internalValue = config.timeouts;\n  }\n\n  // ==========\n  // ATTRIBUTES\n  // ==========\n\n  // display_name - computed: false, optional: false, required: true\n  private _displayName?: string; \n  public get displayName() {\n    return this.getStringAttribute('display_name');\n  }\n  public set displayName(value: string) {\n    this._displayName = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get displayNameInput() {\n    return this._displayName;\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  // object_id - computed: true, optional: false, required: false\n  public get objectId() {\n    return this.getStringAttribute('object_id');\n  }\n\n  // state - computed: false, optional: false, required: true\n  private _state?: string; \n  public get state() {\n    return this.getStringAttribute('state');\n  }\n  public set state(value: string) {\n    this._state = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get stateInput() {\n    return this._state;\n  }\n\n  // conditions - computed: false, optional: false, required: true\n  private _conditions = new ConditionalAccessPolicyConditionsOutputReference(this, \"conditions\");\n  public get conditions() {\n    return this._conditions;\n  }\n  public putConditions(value: ConditionalAccessPolicyConditions) {\n    this._conditions.internalValue = value;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get conditionsInput() {\n    return this._conditions.internalValue;\n  }\n\n  // grant_controls - computed: false, optional: true, required: false\n  private _grantControls = new ConditionalAccessPolicyGrantControlsOutputReference(this, \"grant_controls\");\n  public get grantControls() {\n    return this._grantControls;\n  }\n  public putGrantControls(value: ConditionalAccessPolicyGrantControls) {\n    this._grantControls.internalValue = value;\n  }\n  public resetGrantControls() {\n    this._grantControls.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get grantControlsInput() {\n    return this._grantControls.internalValue;\n  }\n\n  // session_controls - computed: false, optional: true, required: false\n  private _sessionControls = new ConditionalAccessPolicySessionControlsOutputReference(this, \"session_controls\");\n  public get sessionControls() {\n    return this._sessionControls;\n  }\n  public putSessionControls(value: ConditionalAccessPolicySessionControls) {\n    this._sessionControls.internalValue = value;\n  }\n  public resetSessionControls() {\n    this._sessionControls.internalValue = undefined;\n  }\n  // Temporarily expose input value. Use with caution.\n  public get sessionControlsInput() {\n    return this._sessionControls.internalValue;\n  }\n\n  // timeouts - computed: false, optional: true, required: false\n  private _timeouts = new ConditionalAccessPolicyTimeoutsOutputReference(this, \"timeouts\");\n  public get timeouts() {\n    return this._timeouts;\n  }\n  public putTimeouts(value: ConditionalAccessPolicyTimeouts) {\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      display_name: cdktn.stringToTerraform(this._displayName),\n      id: cdktn.stringToTerraform(this._id),\n      state: cdktn.stringToTerraform(this._state),\n      conditions: conditionalAccessPolicyConditionsToTerraform(this._conditions.internalValue),\n      grant_controls: conditionalAccessPolicyGrantControlsToTerraform(this._grantControls.internalValue),\n      session_controls: conditionalAccessPolicySessionControlsToTerraform(this._sessionControls.internalValue),\n      timeouts: conditionalAccessPolicyTimeoutsToTerraform(this._timeouts.internalValue),\n    };\n  }\n\n  protected synthesizeHclAttributes(): { [name: string]: any } {\n    const attrs = {\n      display_name: {\n        value: cdktn.stringToHclTerraform(this._displayName),\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      state: {\n        value: cdktn.stringToHclTerraform(this._state),\n        isBlock: false,\n        type: \"simple\",\n        storageClassType: \"string\",\n      },\n      conditions: {\n        value: conditionalAccessPolicyConditionsToHclTerraform(this._conditions.internalValue),\n        isBlock: true,\n        type: \"list\",\n        storageClassType: \"ConditionalAccessPolicyConditionsList\",\n      },\n      grant_controls: {\n        value: conditionalAccessPolicyGrantControlsToHclTerraform(this._grantControls.internalValue),\n        isBlock: true,\n        type: \"list\",\n        storageClassType: \"ConditionalAccessPolicyGrantControlsList\",\n      },\n      session_controls: {\n        value: conditionalAccessPolicySessionControlsToHclTerraform(this._sessionControls.internalValue),\n        isBlock: true,\n        type: \"list\",\n        storageClassType: \"ConditionalAccessPolicySessionControlsList\",\n      },\n      timeouts: {\n        value: conditionalAccessPolicyTimeoutsToHclTerraform(this._timeouts.internalValue),\n        isBlock: true,\n        type: \"struct\",\n        storageClassType: \"ConditionalAccessPolicyTimeouts\",\n      },\n    };\n\n    // remove undefined attributes\n    return Object.fromEntries(Object.entries(attrs).filter(([_, value]) => value !== undefined && value.value !== undefined ))\n  }\n}\n"]}
|