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.

Files changed (87) hide show
  1. pulumi_azuread/__init__.py +48 -1
  2. pulumi_azuread/_inputs.py +3803 -919
  3. pulumi_azuread/_utilities.py +52 -12
  4. pulumi_azuread/access_package.py +84 -78
  5. pulumi_azuread/access_package_assignment_policy.py +202 -196
  6. pulumi_azuread/access_package_catalog.py +82 -76
  7. pulumi_azuread/access_package_catalog_role_assignment.py +73 -67
  8. pulumi_azuread/access_package_resource_catalog_association.py +73 -67
  9. pulumi_azuread/access_package_resource_package_association.py +79 -73
  10. pulumi_azuread/administrative_unit.py +120 -100
  11. pulumi_azuread/administrative_unit_member.py +66 -50
  12. pulumi_azuread/administrative_unit_role_member.py +75 -69
  13. pulumi_azuread/app_role_assignment.py +164 -264
  14. pulumi_azuread/application.py +766 -692
  15. pulumi_azuread/application_api_access.py +84 -80
  16. pulumi_azuread/application_app_role.py +120 -116
  17. pulumi_azuread/application_certificate.py +349 -211
  18. pulumi_azuread/application_fallback_public_client.py +50 -44
  19. pulumi_azuread/application_federated_identity_credential.py +142 -197
  20. pulumi_azuread/application_from_template.py +90 -84
  21. pulumi_azuread/application_identifier_uri.py +56 -52
  22. pulumi_azuread/application_known_clients.py +50 -44
  23. pulumi_azuread/application_optional_claims.py +87 -81
  24. pulumi_azuread/application_owner.py +76 -42
  25. pulumi_azuread/application_password.py +159 -205
  26. pulumi_azuread/application_permission_scope.py +160 -156
  27. pulumi_azuread/application_pre_authorized.py +120 -236
  28. pulumi_azuread/application_redirect_uris.py +75 -69
  29. pulumi_azuread/application_registration.py +315 -309
  30. pulumi_azuread/authentication_strength_policy.py +73 -67
  31. pulumi_azuread/claims_mapping_policy.py +48 -42
  32. pulumi_azuread/conditional_access_policy.py +248 -232
  33. pulumi_azuread/config/__init__.py +2 -1
  34. pulumi_azuread/config/__init__.pyi +23 -17
  35. pulumi_azuread/config/vars.py +47 -37
  36. pulumi_azuread/custom_directory_role.py +128 -122
  37. pulumi_azuread/directory_role.py +60 -54
  38. pulumi_azuread/directory_role_assignment.py +194 -181
  39. pulumi_azuread/directory_role_eligibility_schedule_request.py +86 -80
  40. pulumi_azuread/directory_role_member.py +54 -48
  41. pulumi_azuread/get_access_package.py +45 -31
  42. pulumi_azuread/get_access_package_catalog.py +40 -27
  43. pulumi_azuread/get_access_package_catalog_role.py +39 -25
  44. pulumi_azuread/get_administrative_unit.py +42 -27
  45. pulumi_azuread/get_application.py +135 -94
  46. pulumi_azuread/get_application_published_app_ids.py +42 -47
  47. pulumi_azuread/get_application_template.py +49 -33
  48. pulumi_azuread/get_client_config.py +24 -15
  49. pulumi_azuread/get_directory_object.py +32 -21
  50. pulumi_azuread/get_directory_role_templates.py +20 -12
  51. pulumi_azuread/get_directory_roles.py +23 -14
  52. pulumi_azuread/get_domains.py +65 -46
  53. pulumi_azuread/get_group.py +147 -88
  54. pulumi_azuread/get_group_role_management_policy.py +178 -0
  55. pulumi_azuread/get_groups.py +71 -51
  56. pulumi_azuread/get_named_location.py +47 -22
  57. pulumi_azuread/get_service_principal.py +108 -90
  58. pulumi_azuread/get_service_principals.py +60 -64
  59. pulumi_azuread/get_user.py +186 -118
  60. pulumi_azuread/get_users.py +96 -53
  61. pulumi_azuread/group.py +622 -464
  62. pulumi_azuread/group_member.py +56 -50
  63. pulumi_azuread/group_role_management_policy.py +544 -0
  64. pulumi_azuread/group_without_members.py +1610 -0
  65. pulumi_azuread/invitation.py +126 -120
  66. pulumi_azuread/named_location.py +90 -76
  67. pulumi_azuread/outputs.py +2844 -1308
  68. pulumi_azuread/privileged_access_group_assignment_schedule.py +695 -0
  69. pulumi_azuread/privileged_access_group_eligibility_schedule.py +695 -0
  70. pulumi_azuread/provider.py +292 -246
  71. pulumi_azuread/pulumi-plugin.json +2 -1
  72. pulumi_azuread/service_principal.py +400 -461
  73. pulumi_azuread/service_principal_certificate.py +230 -145
  74. pulumi_azuread/service_principal_claims_mapping_policy_assignment.py +53 -47
  75. pulumi_azuread/service_principal_delegated_permission_grant.py +146 -140
  76. pulumi_azuread/service_principal_password.py +156 -141
  77. pulumi_azuread/service_principal_token_signing_certificate.py +119 -124
  78. pulumi_azuread/synchronization_job.py +105 -111
  79. pulumi_azuread/synchronization_job_provision_on_demand.py +396 -0
  80. pulumi_azuread/synchronization_secret.py +64 -70
  81. pulumi_azuread/user.py +776 -730
  82. pulumi_azuread/user_flow_attribute.py +76 -70
  83. {pulumi_azuread-5.48.0a1706744699.dist-info → pulumi_azuread-6.8.0a1766208344.dist-info}/METADATA +21 -20
  84. pulumi_azuread-6.8.0a1766208344.dist-info/RECORD +87 -0
  85. {pulumi_azuread-5.48.0a1706744699.dist-info → pulumi_azuread-6.8.0a1766208344.dist-info}/WHEEL +1 -1
  86. pulumi_azuread-5.48.0a1706744699.dist-info/RECORD +0 -81
  87. {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 the Pulumi Terraform Bridge (tfgen) Tool. ***
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 copy
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 object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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 object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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 object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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 object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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[pulumi.InputType['SynchronizationSecretCredentialArgs']]]]] = None,
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
- example_application_template = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
121
- example_application = azuread.Application("exampleApplication",
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=example_application_template.template_id,
124
- feature_tags=[azuread.ApplicationFeatureTagArgs(
125
- enterprise=True,
126
- gallery=True,
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
- azuread.SynchronizationSecretCredentialArgs(
135
- key="BaseAddress",
136
- value="abc",
137
- ),
138
- azuread.SynchronizationSecretCredentialArgs(
139
- key="SecretToken",
140
- value="some-token",
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[pulumi.InputType['SynchronizationSecretCredentialArgs']]]] credentials: One or more `credential` blocks as documented below.
152
- :param pulumi.Input[str] service_principal_id: The object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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
- example_application_template = azuread.get_application_template(display_name="Azure Databricks SCIM Provisioning Connector")
178
- example_application = azuread.Application("exampleApplication",
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=example_application_template.template_id,
181
- feature_tags=[azuread.ApplicationFeatureTagArgs(
182
- enterprise=True,
183
- gallery=True,
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
- azuread.SynchronizationSecretCredentialArgs(
192
- key="BaseAddress",
193
- value="abc",
194
- ),
195
- azuread.SynchronizationSecretCredentialArgs(
196
- key="SecretToken",
197
- value="some-token",
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[pulumi.InputType['SynchronizationSecretCredentialArgs']]]]] = None,
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[pulumi.InputType['SynchronizationSecretCredentialArgs']]]]] = None,
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[pulumi.InputType['SynchronizationSecretCredentialArgs']]]] credentials: One or more `credential` blocks as documented below.
256
- :param pulumi.Input[str] service_principal_id: The object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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 object ID of the service principal for which this synchronization secrets should be stored. Changing this field forces a new resource to be created.
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