pulumi-azuread 5.48.0a1706744699__py3-none-any.whl → 6.8.0a1766208344__py3-none-any.whl
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.
Potentially problematic release.
This version of pulumi-azuread might be problematic. Click here for more details.
- pulumi_azuread/__init__.py +48 -1
- pulumi_azuread/_inputs.py +3803 -919
- pulumi_azuread/_utilities.py +52 -12
- pulumi_azuread/access_package.py +84 -78
- pulumi_azuread/access_package_assignment_policy.py +202 -196
- pulumi_azuread/access_package_catalog.py +82 -76
- pulumi_azuread/access_package_catalog_role_assignment.py +73 -67
- pulumi_azuread/access_package_resource_catalog_association.py +73 -67
- pulumi_azuread/access_package_resource_package_association.py +79 -73
- pulumi_azuread/administrative_unit.py +120 -100
- pulumi_azuread/administrative_unit_member.py +66 -50
- pulumi_azuread/administrative_unit_role_member.py +75 -69
- pulumi_azuread/app_role_assignment.py +164 -264
- pulumi_azuread/application.py +766 -692
- pulumi_azuread/application_api_access.py +84 -80
- pulumi_azuread/application_app_role.py +120 -116
- pulumi_azuread/application_certificate.py +349 -211
- pulumi_azuread/application_fallback_public_client.py +50 -44
- pulumi_azuread/application_federated_identity_credential.py +142 -197
- pulumi_azuread/application_from_template.py +90 -84
- pulumi_azuread/application_identifier_uri.py +56 -52
- pulumi_azuread/application_known_clients.py +50 -44
- pulumi_azuread/application_optional_claims.py +87 -81
- pulumi_azuread/application_owner.py +76 -42
- pulumi_azuread/application_password.py +159 -205
- pulumi_azuread/application_permission_scope.py +160 -156
- pulumi_azuread/application_pre_authorized.py +120 -236
- pulumi_azuread/application_redirect_uris.py +75 -69
- pulumi_azuread/application_registration.py +315 -309
- pulumi_azuread/authentication_strength_policy.py +73 -67
- pulumi_azuread/claims_mapping_policy.py +48 -42
- pulumi_azuread/conditional_access_policy.py +248 -232
- pulumi_azuread/config/__init__.py +2 -1
- pulumi_azuread/config/__init__.pyi +23 -17
- pulumi_azuread/config/vars.py +47 -37
- pulumi_azuread/custom_directory_role.py +128 -122
- pulumi_azuread/directory_role.py +60 -54
- pulumi_azuread/directory_role_assignment.py +194 -181
- pulumi_azuread/directory_role_eligibility_schedule_request.py +86 -80
- pulumi_azuread/directory_role_member.py +54 -48
- pulumi_azuread/get_access_package.py +45 -31
- pulumi_azuread/get_access_package_catalog.py +40 -27
- pulumi_azuread/get_access_package_catalog_role.py +39 -25
- pulumi_azuread/get_administrative_unit.py +42 -27
- pulumi_azuread/get_application.py +135 -94
- pulumi_azuread/get_application_published_app_ids.py +42 -47
- pulumi_azuread/get_application_template.py +49 -33
- pulumi_azuread/get_client_config.py +24 -15
- pulumi_azuread/get_directory_object.py +32 -21
- pulumi_azuread/get_directory_role_templates.py +20 -12
- pulumi_azuread/get_directory_roles.py +23 -14
- pulumi_azuread/get_domains.py +65 -46
- pulumi_azuread/get_group.py +147 -88
- pulumi_azuread/get_group_role_management_policy.py +178 -0
- pulumi_azuread/get_groups.py +71 -51
- pulumi_azuread/get_named_location.py +47 -22
- pulumi_azuread/get_service_principal.py +108 -90
- pulumi_azuread/get_service_principals.py +60 -64
- pulumi_azuread/get_user.py +186 -118
- pulumi_azuread/get_users.py +96 -53
- pulumi_azuread/group.py +622 -464
- pulumi_azuread/group_member.py +56 -50
- pulumi_azuread/group_role_management_policy.py +544 -0
- pulumi_azuread/group_without_members.py +1610 -0
- pulumi_azuread/invitation.py +126 -120
- pulumi_azuread/named_location.py +90 -76
- pulumi_azuread/outputs.py +2844 -1308
- pulumi_azuread/privileged_access_group_assignment_schedule.py +695 -0
- pulumi_azuread/privileged_access_group_eligibility_schedule.py +695 -0
- pulumi_azuread/provider.py +292 -246
- pulumi_azuread/pulumi-plugin.json +2 -1
- pulumi_azuread/service_principal.py +400 -461
- pulumi_azuread/service_principal_certificate.py +230 -145
- pulumi_azuread/service_principal_claims_mapping_policy_assignment.py +53 -47
- pulumi_azuread/service_principal_delegated_permission_grant.py +146 -140
- pulumi_azuread/service_principal_password.py +156 -141
- pulumi_azuread/service_principal_token_signing_certificate.py +119 -124
- pulumi_azuread/synchronization_job.py +105 -111
- pulumi_azuread/synchronization_job_provision_on_demand.py +396 -0
- pulumi_azuread/synchronization_secret.py +64 -70
- pulumi_azuread/user.py +776 -730
- pulumi_azuread/user_flow_attribute.py +76 -70
- {pulumi_azuread-5.48.0a1706744699.dist-info → pulumi_azuread-6.8.0a1766208344.dist-info}/METADATA +21 -20
- pulumi_azuread-6.8.0a1766208344.dist-info/RECORD +87 -0
- {pulumi_azuread-5.48.0a1706744699.dist-info → pulumi_azuread-6.8.0a1766208344.dist-info}/WHEEL +1 -1
- pulumi_azuread-5.48.0a1706744699.dist-info/RECORD +0 -81
- {pulumi_azuread-5.48.0a1706744699.dist-info → pulumi_azuread-6.8.0a1766208344.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,396 @@
|
|
|
1
|
+
# coding=utf-8
|
|
2
|
+
# *** WARNING: this file was generated by pulumi-language-python. ***
|
|
3
|
+
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
|
4
|
+
|
|
5
|
+
import builtins as _builtins
|
|
6
|
+
import warnings
|
|
7
|
+
import sys
|
|
8
|
+
import pulumi
|
|
9
|
+
import pulumi.runtime
|
|
10
|
+
from typing import Any, Mapping, Optional, Sequence, Union, overload
|
|
11
|
+
if sys.version_info >= (3, 11):
|
|
12
|
+
from typing import NotRequired, TypedDict, TypeAlias
|
|
13
|
+
else:
|
|
14
|
+
from typing_extensions import NotRequired, TypedDict, TypeAlias
|
|
15
|
+
from . import _utilities
|
|
16
|
+
from . import outputs
|
|
17
|
+
from ._inputs import *
|
|
18
|
+
|
|
19
|
+
__all__ = ['SynchronizationJobProvisionOnDemandArgs', 'SynchronizationJobProvisionOnDemand']
|
|
20
|
+
|
|
21
|
+
@pulumi.input_type
|
|
22
|
+
class SynchronizationJobProvisionOnDemandArgs:
|
|
23
|
+
def __init__(__self__, *,
|
|
24
|
+
parameters: pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]],
|
|
25
|
+
service_principal_id: pulumi.Input[_builtins.str],
|
|
26
|
+
synchronization_job_id: pulumi.Input[_builtins.str],
|
|
27
|
+
triggers: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]] = None):
|
|
28
|
+
"""
|
|
29
|
+
The set of arguments for constructing a SynchronizationJobProvisionOnDemand resource.
|
|
30
|
+
:param pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]] parameters: One or more `parameter` blocks as documented below.
|
|
31
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for the synchronization job.
|
|
32
|
+
:param pulumi.Input[_builtins.str] synchronization_job_id: The ID of the synchronization job.
|
|
33
|
+
"""
|
|
34
|
+
pulumi.set(__self__, "parameters", parameters)
|
|
35
|
+
pulumi.set(__self__, "service_principal_id", service_principal_id)
|
|
36
|
+
pulumi.set(__self__, "synchronization_job_id", synchronization_job_id)
|
|
37
|
+
if triggers is not None:
|
|
38
|
+
pulumi.set(__self__, "triggers", triggers)
|
|
39
|
+
|
|
40
|
+
@_builtins.property
|
|
41
|
+
@pulumi.getter
|
|
42
|
+
def parameters(self) -> pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]]:
|
|
43
|
+
"""
|
|
44
|
+
One or more `parameter` blocks as documented below.
|
|
45
|
+
"""
|
|
46
|
+
return pulumi.get(self, "parameters")
|
|
47
|
+
|
|
48
|
+
@parameters.setter
|
|
49
|
+
def parameters(self, value: pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]]):
|
|
50
|
+
pulumi.set(self, "parameters", value)
|
|
51
|
+
|
|
52
|
+
@_builtins.property
|
|
53
|
+
@pulumi.getter(name="servicePrincipalId")
|
|
54
|
+
def service_principal_id(self) -> pulumi.Input[_builtins.str]:
|
|
55
|
+
"""
|
|
56
|
+
The ID of the service principal for the synchronization job.
|
|
57
|
+
"""
|
|
58
|
+
return pulumi.get(self, "service_principal_id")
|
|
59
|
+
|
|
60
|
+
@service_principal_id.setter
|
|
61
|
+
def service_principal_id(self, value: pulumi.Input[_builtins.str]):
|
|
62
|
+
pulumi.set(self, "service_principal_id", value)
|
|
63
|
+
|
|
64
|
+
@_builtins.property
|
|
65
|
+
@pulumi.getter(name="synchronizationJobId")
|
|
66
|
+
def synchronization_job_id(self) -> pulumi.Input[_builtins.str]:
|
|
67
|
+
"""
|
|
68
|
+
The ID of the synchronization job.
|
|
69
|
+
"""
|
|
70
|
+
return pulumi.get(self, "synchronization_job_id")
|
|
71
|
+
|
|
72
|
+
@synchronization_job_id.setter
|
|
73
|
+
def synchronization_job_id(self, value: pulumi.Input[_builtins.str]):
|
|
74
|
+
pulumi.set(self, "synchronization_job_id", value)
|
|
75
|
+
|
|
76
|
+
@_builtins.property
|
|
77
|
+
@pulumi.getter
|
|
78
|
+
def triggers(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]]:
|
|
79
|
+
return pulumi.get(self, "triggers")
|
|
80
|
+
|
|
81
|
+
@triggers.setter
|
|
82
|
+
def triggers(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]]):
|
|
83
|
+
pulumi.set(self, "triggers", value)
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
@pulumi.input_type
|
|
87
|
+
class _SynchronizationJobProvisionOnDemandState:
|
|
88
|
+
def __init__(__self__, *,
|
|
89
|
+
parameters: Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]]] = None,
|
|
90
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
91
|
+
synchronization_job_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
92
|
+
triggers: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]] = None):
|
|
93
|
+
"""
|
|
94
|
+
Input properties used for looking up and filtering SynchronizationJobProvisionOnDemand resources.
|
|
95
|
+
:param pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]] parameters: One or more `parameter` blocks as documented below.
|
|
96
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for the synchronization job.
|
|
97
|
+
:param pulumi.Input[_builtins.str] synchronization_job_id: The ID of the synchronization job.
|
|
98
|
+
"""
|
|
99
|
+
if parameters is not None:
|
|
100
|
+
pulumi.set(__self__, "parameters", parameters)
|
|
101
|
+
if service_principal_id is not None:
|
|
102
|
+
pulumi.set(__self__, "service_principal_id", service_principal_id)
|
|
103
|
+
if synchronization_job_id is not None:
|
|
104
|
+
pulumi.set(__self__, "synchronization_job_id", synchronization_job_id)
|
|
105
|
+
if triggers is not None:
|
|
106
|
+
pulumi.set(__self__, "triggers", triggers)
|
|
107
|
+
|
|
108
|
+
@_builtins.property
|
|
109
|
+
@pulumi.getter
|
|
110
|
+
def parameters(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]]]:
|
|
111
|
+
"""
|
|
112
|
+
One or more `parameter` blocks as documented below.
|
|
113
|
+
"""
|
|
114
|
+
return pulumi.get(self, "parameters")
|
|
115
|
+
|
|
116
|
+
@parameters.setter
|
|
117
|
+
def parameters(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationJobProvisionOnDemandParameterArgs']]]]):
|
|
118
|
+
pulumi.set(self, "parameters", value)
|
|
119
|
+
|
|
120
|
+
@_builtins.property
|
|
121
|
+
@pulumi.getter(name="servicePrincipalId")
|
|
122
|
+
def service_principal_id(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
123
|
+
"""
|
|
124
|
+
The ID of the service principal for the synchronization job.
|
|
125
|
+
"""
|
|
126
|
+
return pulumi.get(self, "service_principal_id")
|
|
127
|
+
|
|
128
|
+
@service_principal_id.setter
|
|
129
|
+
def service_principal_id(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
130
|
+
pulumi.set(self, "service_principal_id", value)
|
|
131
|
+
|
|
132
|
+
@_builtins.property
|
|
133
|
+
@pulumi.getter(name="synchronizationJobId")
|
|
134
|
+
def synchronization_job_id(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
135
|
+
"""
|
|
136
|
+
The ID of the synchronization job.
|
|
137
|
+
"""
|
|
138
|
+
return pulumi.get(self, "synchronization_job_id")
|
|
139
|
+
|
|
140
|
+
@synchronization_job_id.setter
|
|
141
|
+
def synchronization_job_id(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
142
|
+
pulumi.set(self, "synchronization_job_id", value)
|
|
143
|
+
|
|
144
|
+
@_builtins.property
|
|
145
|
+
@pulumi.getter
|
|
146
|
+
def triggers(self) -> Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]]:
|
|
147
|
+
return pulumi.get(self, "triggers")
|
|
148
|
+
|
|
149
|
+
@triggers.setter
|
|
150
|
+
def triggers(self, value: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]]):
|
|
151
|
+
pulumi.set(self, "triggers", value)
|
|
152
|
+
|
|
153
|
+
|
|
154
|
+
@pulumi.type_token("azuread:index/synchronizationJobProvisionOnDemand:SynchronizationJobProvisionOnDemand")
|
|
155
|
+
class SynchronizationJobProvisionOnDemand(pulumi.CustomResource):
|
|
156
|
+
@overload
|
|
157
|
+
def __init__(__self__,
|
|
158
|
+
resource_name: str,
|
|
159
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
160
|
+
parameters: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationJobProvisionOnDemandParameterArgs', 'SynchronizationJobProvisionOnDemandParameterArgsDict']]]]] = None,
|
|
161
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
162
|
+
synchronization_job_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
163
|
+
triggers: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]] = None,
|
|
164
|
+
__props__=None):
|
|
165
|
+
"""
|
|
166
|
+
Manages synchronization job on demand provisioning associated with a service principal (enterprise application) within Azure Active Directory.
|
|
167
|
+
|
|
168
|
+
## API Permissions
|
|
169
|
+
|
|
170
|
+
The following API permissions are required in order to use this resource.
|
|
171
|
+
|
|
172
|
+
When authenticated with a service principal, this resource requires one of the following application roles: `Synchronization.ReadWrite.All`
|
|
173
|
+
|
|
174
|
+
## Example Usage
|
|
175
|
+
|
|
176
|
+
*Basic example*
|
|
177
|
+
|
|
178
|
+
```python
|
|
179
|
+
import pulumi
|
|
180
|
+
import pulumi_azuread as azuread
|
|
181
|
+
|
|
182
|
+
current = azuread.get_client_config()
|
|
183
|
+
example_group = azuread.Group("example",
|
|
184
|
+
display_name="example",
|
|
185
|
+
owners=[current.object_id],
|
|
186
|
+
security_enabled=True)
|
|
187
|
+
example = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
|
|
188
|
+
example_application_from_template = azuread.ApplicationFromTemplate("example",
|
|
189
|
+
display_name="example",
|
|
190
|
+
template_id=example.template_id)
|
|
191
|
+
example_get_service_principal = azuread.get_service_principal_output(object_id=example_application_from_template.service_principal_object_id)
|
|
192
|
+
example_synchronization_secret = azuread.SynchronizationSecret("example",
|
|
193
|
+
service_principal_id=example_get_service_principal.id,
|
|
194
|
+
credentials=[
|
|
195
|
+
{
|
|
196
|
+
"key": "BaseAddress",
|
|
197
|
+
"value": "https://adb-example.azuredatabricks.net/api/2.0/preview/scim",
|
|
198
|
+
},
|
|
199
|
+
{
|
|
200
|
+
"key": "SecretToken",
|
|
201
|
+
"value": "some-token",
|
|
202
|
+
},
|
|
203
|
+
])
|
|
204
|
+
example_synchronization_job = azuread.SynchronizationJob("example",
|
|
205
|
+
service_principal_id=example_get_service_principal.id,
|
|
206
|
+
template_id="dataBricks",
|
|
207
|
+
enabled=True)
|
|
208
|
+
example_synchronization_job_provision_on_demand = azuread.SynchronizationJobProvisionOnDemand("example",
|
|
209
|
+
service_principal_id=example_synchronization_job.service_principal_id,
|
|
210
|
+
synchronization_job_id=example_synchronization_job.id,
|
|
211
|
+
parameters=[{
|
|
212
|
+
"rule_id": "",
|
|
213
|
+
"subjects": [{
|
|
214
|
+
"object_id": example_group.object_id,
|
|
215
|
+
"object_type_name": "Group",
|
|
216
|
+
}],
|
|
217
|
+
}])
|
|
218
|
+
```
|
|
219
|
+
|
|
220
|
+
## Import
|
|
221
|
+
|
|
222
|
+
This resource does not support importing.
|
|
223
|
+
|
|
224
|
+
:param str resource_name: The name of the resource.
|
|
225
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
226
|
+
:param pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationJobProvisionOnDemandParameterArgs', 'SynchronizationJobProvisionOnDemandParameterArgsDict']]]] parameters: One or more `parameter` blocks as documented below.
|
|
227
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for the synchronization job.
|
|
228
|
+
:param pulumi.Input[_builtins.str] synchronization_job_id: The ID of the synchronization job.
|
|
229
|
+
"""
|
|
230
|
+
...
|
|
231
|
+
@overload
|
|
232
|
+
def __init__(__self__,
|
|
233
|
+
resource_name: str,
|
|
234
|
+
args: SynchronizationJobProvisionOnDemandArgs,
|
|
235
|
+
opts: Optional[pulumi.ResourceOptions] = None):
|
|
236
|
+
"""
|
|
237
|
+
Manages synchronization job on demand provisioning associated with a service principal (enterprise application) within Azure Active Directory.
|
|
238
|
+
|
|
239
|
+
## API Permissions
|
|
240
|
+
|
|
241
|
+
The following API permissions are required in order to use this resource.
|
|
242
|
+
|
|
243
|
+
When authenticated with a service principal, this resource requires one of the following application roles: `Synchronization.ReadWrite.All`
|
|
244
|
+
|
|
245
|
+
## Example Usage
|
|
246
|
+
|
|
247
|
+
*Basic example*
|
|
248
|
+
|
|
249
|
+
```python
|
|
250
|
+
import pulumi
|
|
251
|
+
import pulumi_azuread as azuread
|
|
252
|
+
|
|
253
|
+
current = azuread.get_client_config()
|
|
254
|
+
example_group = azuread.Group("example",
|
|
255
|
+
display_name="example",
|
|
256
|
+
owners=[current.object_id],
|
|
257
|
+
security_enabled=True)
|
|
258
|
+
example = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
|
|
259
|
+
example_application_from_template = azuread.ApplicationFromTemplate("example",
|
|
260
|
+
display_name="example",
|
|
261
|
+
template_id=example.template_id)
|
|
262
|
+
example_get_service_principal = azuread.get_service_principal_output(object_id=example_application_from_template.service_principal_object_id)
|
|
263
|
+
example_synchronization_secret = azuread.SynchronizationSecret("example",
|
|
264
|
+
service_principal_id=example_get_service_principal.id,
|
|
265
|
+
credentials=[
|
|
266
|
+
{
|
|
267
|
+
"key": "BaseAddress",
|
|
268
|
+
"value": "https://adb-example.azuredatabricks.net/api/2.0/preview/scim",
|
|
269
|
+
},
|
|
270
|
+
{
|
|
271
|
+
"key": "SecretToken",
|
|
272
|
+
"value": "some-token",
|
|
273
|
+
},
|
|
274
|
+
])
|
|
275
|
+
example_synchronization_job = azuread.SynchronizationJob("example",
|
|
276
|
+
service_principal_id=example_get_service_principal.id,
|
|
277
|
+
template_id="dataBricks",
|
|
278
|
+
enabled=True)
|
|
279
|
+
example_synchronization_job_provision_on_demand = azuread.SynchronizationJobProvisionOnDemand("example",
|
|
280
|
+
service_principal_id=example_synchronization_job.service_principal_id,
|
|
281
|
+
synchronization_job_id=example_synchronization_job.id,
|
|
282
|
+
parameters=[{
|
|
283
|
+
"rule_id": "",
|
|
284
|
+
"subjects": [{
|
|
285
|
+
"object_id": example_group.object_id,
|
|
286
|
+
"object_type_name": "Group",
|
|
287
|
+
}],
|
|
288
|
+
}])
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
## Import
|
|
292
|
+
|
|
293
|
+
This resource does not support importing.
|
|
294
|
+
|
|
295
|
+
:param str resource_name: The name of the resource.
|
|
296
|
+
:param SynchronizationJobProvisionOnDemandArgs args: The arguments to use to populate this resource's properties.
|
|
297
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
298
|
+
"""
|
|
299
|
+
...
|
|
300
|
+
def __init__(__self__, resource_name: str, *args, **kwargs):
|
|
301
|
+
resource_args, opts = _utilities.get_resource_args_opts(SynchronizationJobProvisionOnDemandArgs, pulumi.ResourceOptions, *args, **kwargs)
|
|
302
|
+
if resource_args is not None:
|
|
303
|
+
__self__._internal_init(resource_name, opts, **resource_args.__dict__)
|
|
304
|
+
else:
|
|
305
|
+
__self__._internal_init(resource_name, *args, **kwargs)
|
|
306
|
+
|
|
307
|
+
def _internal_init(__self__,
|
|
308
|
+
resource_name: str,
|
|
309
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
310
|
+
parameters: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationJobProvisionOnDemandParameterArgs', 'SynchronizationJobProvisionOnDemandParameterArgsDict']]]]] = None,
|
|
311
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
312
|
+
synchronization_job_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
313
|
+
triggers: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]] = None,
|
|
314
|
+
__props__=None):
|
|
315
|
+
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
|
|
316
|
+
if not isinstance(opts, pulumi.ResourceOptions):
|
|
317
|
+
raise TypeError('Expected resource options to be a ResourceOptions instance')
|
|
318
|
+
if opts.id is None:
|
|
319
|
+
if __props__ is not None:
|
|
320
|
+
raise TypeError('__props__ is only valid when passed in combination with a valid opts.id to get an existing resource')
|
|
321
|
+
__props__ = SynchronizationJobProvisionOnDemandArgs.__new__(SynchronizationJobProvisionOnDemandArgs)
|
|
322
|
+
|
|
323
|
+
if parameters is None and not opts.urn:
|
|
324
|
+
raise TypeError("Missing required property 'parameters'")
|
|
325
|
+
__props__.__dict__["parameters"] = parameters
|
|
326
|
+
if service_principal_id is None and not opts.urn:
|
|
327
|
+
raise TypeError("Missing required property 'service_principal_id'")
|
|
328
|
+
__props__.__dict__["service_principal_id"] = service_principal_id
|
|
329
|
+
if synchronization_job_id is None and not opts.urn:
|
|
330
|
+
raise TypeError("Missing required property 'synchronization_job_id'")
|
|
331
|
+
__props__.__dict__["synchronization_job_id"] = synchronization_job_id
|
|
332
|
+
__props__.__dict__["triggers"] = triggers
|
|
333
|
+
super(SynchronizationJobProvisionOnDemand, __self__).__init__(
|
|
334
|
+
'azuread:index/synchronizationJobProvisionOnDemand:SynchronizationJobProvisionOnDemand',
|
|
335
|
+
resource_name,
|
|
336
|
+
__props__,
|
|
337
|
+
opts)
|
|
338
|
+
|
|
339
|
+
@staticmethod
|
|
340
|
+
def get(resource_name: str,
|
|
341
|
+
id: pulumi.Input[str],
|
|
342
|
+
opts: Optional[pulumi.ResourceOptions] = None,
|
|
343
|
+
parameters: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationJobProvisionOnDemandParameterArgs', 'SynchronizationJobProvisionOnDemandParameterArgsDict']]]]] = None,
|
|
344
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
345
|
+
synchronization_job_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
346
|
+
triggers: Optional[pulumi.Input[Mapping[str, pulumi.Input[_builtins.str]]]] = None) -> 'SynchronizationJobProvisionOnDemand':
|
|
347
|
+
"""
|
|
348
|
+
Get an existing SynchronizationJobProvisionOnDemand resource's state with the given name, id, and optional extra
|
|
349
|
+
properties used to qualify the lookup.
|
|
350
|
+
|
|
351
|
+
:param str resource_name: The unique name of the resulting resource.
|
|
352
|
+
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
|
|
353
|
+
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
354
|
+
:param pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationJobProvisionOnDemandParameterArgs', 'SynchronizationJobProvisionOnDemandParameterArgsDict']]]] parameters: One or more `parameter` blocks as documented below.
|
|
355
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for the synchronization job.
|
|
356
|
+
:param pulumi.Input[_builtins.str] synchronization_job_id: The ID of the synchronization job.
|
|
357
|
+
"""
|
|
358
|
+
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
|
|
359
|
+
|
|
360
|
+
__props__ = _SynchronizationJobProvisionOnDemandState.__new__(_SynchronizationJobProvisionOnDemandState)
|
|
361
|
+
|
|
362
|
+
__props__.__dict__["parameters"] = parameters
|
|
363
|
+
__props__.__dict__["service_principal_id"] = service_principal_id
|
|
364
|
+
__props__.__dict__["synchronization_job_id"] = synchronization_job_id
|
|
365
|
+
__props__.__dict__["triggers"] = triggers
|
|
366
|
+
return SynchronizationJobProvisionOnDemand(resource_name, opts=opts, __props__=__props__)
|
|
367
|
+
|
|
368
|
+
@_builtins.property
|
|
369
|
+
@pulumi.getter
|
|
370
|
+
def parameters(self) -> pulumi.Output[Sequence['outputs.SynchronizationJobProvisionOnDemandParameter']]:
|
|
371
|
+
"""
|
|
372
|
+
One or more `parameter` blocks as documented below.
|
|
373
|
+
"""
|
|
374
|
+
return pulumi.get(self, "parameters")
|
|
375
|
+
|
|
376
|
+
@_builtins.property
|
|
377
|
+
@pulumi.getter(name="servicePrincipalId")
|
|
378
|
+
def service_principal_id(self) -> pulumi.Output[_builtins.str]:
|
|
379
|
+
"""
|
|
380
|
+
The ID of the service principal for the synchronization job.
|
|
381
|
+
"""
|
|
382
|
+
return pulumi.get(self, "service_principal_id")
|
|
383
|
+
|
|
384
|
+
@_builtins.property
|
|
385
|
+
@pulumi.getter(name="synchronizationJobId")
|
|
386
|
+
def synchronization_job_id(self) -> pulumi.Output[_builtins.str]:
|
|
387
|
+
"""
|
|
388
|
+
The ID of the synchronization job.
|
|
389
|
+
"""
|
|
390
|
+
return pulumi.get(self, "synchronization_job_id")
|
|
391
|
+
|
|
392
|
+
@_builtins.property
|
|
393
|
+
@pulumi.getter
|
|
394
|
+
def triggers(self) -> pulumi.Output[Optional[Mapping[str, _builtins.str]]]:
|
|
395
|
+
return pulumi.get(self, "triggers")
|
|
396
|
+
|
|
@@ -1,12 +1,17 @@
|
|
|
1
1
|
# coding=utf-8
|
|
2
|
-
# *** WARNING: this file was generated by
|
|
2
|
+
# *** WARNING: this file was generated by pulumi-language-python. ***
|
|
3
3
|
# *** Do not edit by hand unless you're certain you know what you are doing! ***
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import builtins as _builtins
|
|
6
6
|
import warnings
|
|
7
|
+
import sys
|
|
7
8
|
import pulumi
|
|
8
9
|
import pulumi.runtime
|
|
9
10
|
from typing import Any, Mapping, Optional, Sequence, Union, overload
|
|
11
|
+
if sys.version_info >= (3, 11):
|
|
12
|
+
from typing import NotRequired, TypedDict, TypeAlias
|
|
13
|
+
else:
|
|
14
|
+
from typing_extensions import NotRequired, TypedDict, TypeAlias
|
|
10
15
|
from . import _utilities
|
|
11
16
|
from . import outputs
|
|
12
17
|
from ._inputs import *
|
|
@@ -16,30 +21,30 @@ __all__ = ['SynchronizationSecretArgs', 'SynchronizationSecret']
|
|
|
16
21
|
@pulumi.input_type
|
|
17
22
|
class SynchronizationSecretArgs:
|
|
18
23
|
def __init__(__self__, *,
|
|
19
|
-
service_principal_id: pulumi.Input[str],
|
|
24
|
+
service_principal_id: pulumi.Input[_builtins.str],
|
|
20
25
|
credentials: Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]]] = None):
|
|
21
26
|
"""
|
|
22
27
|
The set of arguments for constructing a SynchronizationSecret resource.
|
|
23
|
-
:param pulumi.Input[str] service_principal_id: The
|
|
28
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
24
29
|
:param pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]] credentials: One or more `credential` blocks as documented below.
|
|
25
30
|
"""
|
|
26
31
|
pulumi.set(__self__, "service_principal_id", service_principal_id)
|
|
27
32
|
if credentials is not None:
|
|
28
33
|
pulumi.set(__self__, "credentials", credentials)
|
|
29
34
|
|
|
30
|
-
@property
|
|
35
|
+
@_builtins.property
|
|
31
36
|
@pulumi.getter(name="servicePrincipalId")
|
|
32
|
-
def service_principal_id(self) -> pulumi.Input[str]:
|
|
37
|
+
def service_principal_id(self) -> pulumi.Input[_builtins.str]:
|
|
33
38
|
"""
|
|
34
|
-
The
|
|
39
|
+
The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
35
40
|
"""
|
|
36
41
|
return pulumi.get(self, "service_principal_id")
|
|
37
42
|
|
|
38
43
|
@service_principal_id.setter
|
|
39
|
-
def service_principal_id(self, value: pulumi.Input[str]):
|
|
44
|
+
def service_principal_id(self, value: pulumi.Input[_builtins.str]):
|
|
40
45
|
pulumi.set(self, "service_principal_id", value)
|
|
41
46
|
|
|
42
|
-
@property
|
|
47
|
+
@_builtins.property
|
|
43
48
|
@pulumi.getter
|
|
44
49
|
def credentials(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]]]:
|
|
45
50
|
"""
|
|
@@ -56,18 +61,18 @@ class SynchronizationSecretArgs:
|
|
|
56
61
|
class _SynchronizationSecretState:
|
|
57
62
|
def __init__(__self__, *,
|
|
58
63
|
credentials: Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]]] = None,
|
|
59
|
-
service_principal_id: Optional[pulumi.Input[str]] = None):
|
|
64
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None):
|
|
60
65
|
"""
|
|
61
66
|
Input properties used for looking up and filtering SynchronizationSecret resources.
|
|
62
67
|
:param pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]] credentials: One or more `credential` blocks as documented below.
|
|
63
|
-
:param pulumi.Input[str] service_principal_id: The
|
|
68
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
64
69
|
"""
|
|
65
70
|
if credentials is not None:
|
|
66
71
|
pulumi.set(__self__, "credentials", credentials)
|
|
67
72
|
if service_principal_id is not None:
|
|
68
73
|
pulumi.set(__self__, "service_principal_id", service_principal_id)
|
|
69
74
|
|
|
70
|
-
@property
|
|
75
|
+
@_builtins.property
|
|
71
76
|
@pulumi.getter
|
|
72
77
|
def credentials(self) -> Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]]]:
|
|
73
78
|
"""
|
|
@@ -79,26 +84,27 @@ class _SynchronizationSecretState:
|
|
|
79
84
|
def credentials(self, value: Optional[pulumi.Input[Sequence[pulumi.Input['SynchronizationSecretCredentialArgs']]]]):
|
|
80
85
|
pulumi.set(self, "credentials", value)
|
|
81
86
|
|
|
82
|
-
@property
|
|
87
|
+
@_builtins.property
|
|
83
88
|
@pulumi.getter(name="servicePrincipalId")
|
|
84
|
-
def service_principal_id(self) -> Optional[pulumi.Input[str]]:
|
|
89
|
+
def service_principal_id(self) -> Optional[pulumi.Input[_builtins.str]]:
|
|
85
90
|
"""
|
|
86
|
-
The
|
|
91
|
+
The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
87
92
|
"""
|
|
88
93
|
return pulumi.get(self, "service_principal_id")
|
|
89
94
|
|
|
90
95
|
@service_principal_id.setter
|
|
91
|
-
def service_principal_id(self, value: Optional[pulumi.Input[str]]):
|
|
96
|
+
def service_principal_id(self, value: Optional[pulumi.Input[_builtins.str]]):
|
|
92
97
|
pulumi.set(self, "service_principal_id", value)
|
|
93
98
|
|
|
94
99
|
|
|
100
|
+
@pulumi.type_token("azuread:index/synchronizationSecret:SynchronizationSecret")
|
|
95
101
|
class SynchronizationSecret(pulumi.CustomResource):
|
|
96
102
|
@overload
|
|
97
103
|
def __init__(__self__,
|
|
98
104
|
resource_name: str,
|
|
99
105
|
opts: Optional[pulumi.ResourceOptions] = None,
|
|
100
|
-
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[
|
|
101
|
-
service_principal_id: Optional[pulumi.Input[str]] = None,
|
|
106
|
+
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationSecretCredentialArgs', 'SynchronizationSecretCredentialArgsDict']]]]] = None,
|
|
107
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
102
108
|
__props__=None):
|
|
103
109
|
"""
|
|
104
110
|
Manages synchronization secrets associated with a service principal (enterprise application) within Azure Active Directory.
|
|
@@ -117,28 +123,22 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
117
123
|
import pulumi
|
|
118
124
|
import pulumi_azuread as azuread
|
|
119
125
|
|
|
120
|
-
|
|
121
|
-
|
|
126
|
+
example = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
|
|
127
|
+
example_application_from_template = azuread.ApplicationFromTemplate("example",
|
|
122
128
|
display_name="example",
|
|
123
|
-
template_id=
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
)])
|
|
128
|
-
example_service_principal = azuread.ServicePrincipal("exampleServicePrincipal",
|
|
129
|
-
application_id=example_application.application_id,
|
|
130
|
-
use_existing=True)
|
|
131
|
-
example_synchronization_secret = azuread.SynchronizationSecret("exampleSynchronizationSecret",
|
|
132
|
-
service_principal_id=example_service_principal.id,
|
|
129
|
+
template_id=example.template_id)
|
|
130
|
+
example_get_service_principal = azuread.get_service_principal_output(object_id=example_application_from_template.service_principal_object_id)
|
|
131
|
+
example_synchronization_secret = azuread.SynchronizationSecret("example",
|
|
132
|
+
service_principal_id=example_get_service_principal.id,
|
|
133
133
|
credentials=[
|
|
134
|
-
|
|
135
|
-
key
|
|
136
|
-
value
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
key
|
|
140
|
-
value
|
|
141
|
-
|
|
134
|
+
{
|
|
135
|
+
"key": "BaseAddress",
|
|
136
|
+
"value": "abc",
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
"key": "SecretToken",
|
|
140
|
+
"value": "some-token",
|
|
141
|
+
},
|
|
142
142
|
])
|
|
143
143
|
```
|
|
144
144
|
|
|
@@ -148,8 +148,8 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
148
148
|
|
|
149
149
|
:param str resource_name: The name of the resource.
|
|
150
150
|
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
151
|
-
:param pulumi.Input[Sequence[pulumi.Input[
|
|
152
|
-
:param pulumi.Input[str] service_principal_id: The
|
|
151
|
+
:param pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationSecretCredentialArgs', 'SynchronizationSecretCredentialArgsDict']]]] credentials: One or more `credential` blocks as documented below.
|
|
152
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
153
153
|
"""
|
|
154
154
|
...
|
|
155
155
|
@overload
|
|
@@ -174,28 +174,22 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
174
174
|
import pulumi
|
|
175
175
|
import pulumi_azuread as azuread
|
|
176
176
|
|
|
177
|
-
|
|
178
|
-
|
|
177
|
+
example = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
|
|
178
|
+
example_application_from_template = azuread.ApplicationFromTemplate("example",
|
|
179
179
|
display_name="example",
|
|
180
|
-
template_id=
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
)])
|
|
185
|
-
example_service_principal = azuread.ServicePrincipal("exampleServicePrincipal",
|
|
186
|
-
application_id=example_application.application_id,
|
|
187
|
-
use_existing=True)
|
|
188
|
-
example_synchronization_secret = azuread.SynchronizationSecret("exampleSynchronizationSecret",
|
|
189
|
-
service_principal_id=example_service_principal.id,
|
|
180
|
+
template_id=example.template_id)
|
|
181
|
+
example_get_service_principal = azuread.get_service_principal_output(object_id=example_application_from_template.service_principal_object_id)
|
|
182
|
+
example_synchronization_secret = azuread.SynchronizationSecret("example",
|
|
183
|
+
service_principal_id=example_get_service_principal.id,
|
|
190
184
|
credentials=[
|
|
191
|
-
|
|
192
|
-
key
|
|
193
|
-
value
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
key
|
|
197
|
-
value
|
|
198
|
-
|
|
185
|
+
{
|
|
186
|
+
"key": "BaseAddress",
|
|
187
|
+
"value": "abc",
|
|
188
|
+
},
|
|
189
|
+
{
|
|
190
|
+
"key": "SecretToken",
|
|
191
|
+
"value": "some-token",
|
|
192
|
+
},
|
|
199
193
|
])
|
|
200
194
|
```
|
|
201
195
|
|
|
@@ -218,8 +212,8 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
218
212
|
def _internal_init(__self__,
|
|
219
213
|
resource_name: str,
|
|
220
214
|
opts: Optional[pulumi.ResourceOptions] = None,
|
|
221
|
-
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[
|
|
222
|
-
service_principal_id: Optional[pulumi.Input[str]] = None,
|
|
215
|
+
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationSecretCredentialArgs', 'SynchronizationSecretCredentialArgsDict']]]]] = None,
|
|
216
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None,
|
|
223
217
|
__props__=None):
|
|
224
218
|
opts = pulumi.ResourceOptions.merge(_utilities.get_resource_opts_defaults(), opts)
|
|
225
219
|
if not isinstance(opts, pulumi.ResourceOptions):
|
|
@@ -243,8 +237,8 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
243
237
|
def get(resource_name: str,
|
|
244
238
|
id: pulumi.Input[str],
|
|
245
239
|
opts: Optional[pulumi.ResourceOptions] = None,
|
|
246
|
-
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[
|
|
247
|
-
service_principal_id: Optional[pulumi.Input[str]] = None) -> 'SynchronizationSecret':
|
|
240
|
+
credentials: Optional[pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationSecretCredentialArgs', 'SynchronizationSecretCredentialArgsDict']]]]] = None,
|
|
241
|
+
service_principal_id: Optional[pulumi.Input[_builtins.str]] = None) -> 'SynchronizationSecret':
|
|
248
242
|
"""
|
|
249
243
|
Get an existing SynchronizationSecret resource's state with the given name, id, and optional extra
|
|
250
244
|
properties used to qualify the lookup.
|
|
@@ -252,8 +246,8 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
252
246
|
:param str resource_name: The unique name of the resulting resource.
|
|
253
247
|
:param pulumi.Input[str] id: The unique provider ID of the resource to lookup.
|
|
254
248
|
:param pulumi.ResourceOptions opts: Options for the resource.
|
|
255
|
-
:param pulumi.Input[Sequence[pulumi.Input[
|
|
256
|
-
:param pulumi.Input[str] service_principal_id: The
|
|
249
|
+
:param pulumi.Input[Sequence[pulumi.Input[Union['SynchronizationSecretCredentialArgs', 'SynchronizationSecretCredentialArgsDict']]]] credentials: One or more `credential` blocks as documented below.
|
|
250
|
+
:param pulumi.Input[_builtins.str] service_principal_id: The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
257
251
|
"""
|
|
258
252
|
opts = pulumi.ResourceOptions.merge(opts, pulumi.ResourceOptions(id=id))
|
|
259
253
|
|
|
@@ -263,7 +257,7 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
263
257
|
__props__.__dict__["service_principal_id"] = service_principal_id
|
|
264
258
|
return SynchronizationSecret(resource_name, opts=opts, __props__=__props__)
|
|
265
259
|
|
|
266
|
-
@property
|
|
260
|
+
@_builtins.property
|
|
267
261
|
@pulumi.getter
|
|
268
262
|
def credentials(self) -> pulumi.Output[Optional[Sequence['outputs.SynchronizationSecretCredential']]]:
|
|
269
263
|
"""
|
|
@@ -271,11 +265,11 @@ class SynchronizationSecret(pulumi.CustomResource):
|
|
|
271
265
|
"""
|
|
272
266
|
return pulumi.get(self, "credentials")
|
|
273
267
|
|
|
274
|
-
@property
|
|
268
|
+
@_builtins.property
|
|
275
269
|
@pulumi.getter(name="servicePrincipalId")
|
|
276
|
-
def service_principal_id(self) -> pulumi.Output[str]:
|
|
270
|
+
def service_principal_id(self) -> pulumi.Output[_builtins.str]:
|
|
277
271
|
"""
|
|
278
|
-
The
|
|
272
|
+
The ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
|
|
279
273
|
"""
|
|
280
274
|
return pulumi.get(self, "service_principal_id")
|
|
281
275
|
|