gcore 0.3.0__py3-none-any.whl → 0.4.0__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 gcore might be problematic. Click here for more details.

Files changed (120) hide show
  1. gcore/__init__.py +2 -1
  2. gcore/_base_client.py +22 -0
  3. gcore/_client.py +9 -0
  4. gcore/_version.py +1 -1
  5. gcore/pagination.py +61 -1
  6. gcore/resources/__init__.py +14 -0
  7. gcore/resources/cloud/baremetal/flavors.py +11 -137
  8. gcore/resources/cloud/baremetal/images.py +10 -12
  9. gcore/resources/cloud/baremetal/servers.py +31 -28
  10. gcore/resources/cloud/billing_reservations.py +2 -2
  11. gcore/resources/cloud/file_shares/file_shares.py +7 -8
  12. gcore/resources/cloud/floating_ips.py +7 -12
  13. gcore/resources/cloud/gpu_baremetal_clusters/gpu_baremetal_clusters.py +31 -20
  14. gcore/resources/cloud/gpu_baremetal_clusters/images.py +9 -10
  15. gcore/resources/cloud/gpu_baremetal_clusters/interfaces.py +2 -2
  16. gcore/resources/cloud/gpu_baremetal_clusters/servers.py +8 -4
  17. gcore/resources/cloud/inference/deployments/deployments.py +10 -2
  18. gcore/resources/cloud/inference/registry_credentials.py +2 -2
  19. gcore/resources/cloud/inference/secrets.py +8 -8
  20. gcore/resources/cloud/instances/flavors.py +9 -233
  21. gcore/resources/cloud/instances/images.py +47 -37
  22. gcore/resources/cloud/instances/instances.py +47 -32
  23. gcore/resources/cloud/instances/interfaces.py +2 -2
  24. gcore/resources/cloud/ip_ranges.py +34 -2
  25. gcore/resources/cloud/load_balancers/l7_policies/l7_policies.py +10 -2
  26. gcore/resources/cloud/load_balancers/listeners.py +17 -8
  27. gcore/resources/cloud/load_balancers/load_balancers.py +73 -21
  28. gcore/resources/cloud/load_balancers/metrics.py +2 -2
  29. gcore/resources/cloud/load_balancers/pools/health_monitors.py +2 -2
  30. gcore/resources/cloud/load_balancers/pools/members.py +6 -2
  31. gcore/resources/cloud/networks/networks.py +81 -17
  32. gcore/resources/cloud/networks/routers.py +18 -18
  33. gcore/resources/cloud/networks/subnets.py +51 -11
  34. gcore/resources/cloud/projects.py +38 -24
  35. gcore/resources/cloud/quotas/quotas.py +6 -6
  36. gcore/resources/cloud/quotas/requests.py +8 -8
  37. gcore/resources/cloud/registries/artifacts.py +4 -4
  38. gcore/resources/cloud/registries/registries.py +14 -16
  39. gcore/resources/cloud/registries/repositories.py +4 -4
  40. gcore/resources/cloud/registries/tags.py +2 -2
  41. gcore/resources/cloud/registries/users.py +21 -22
  42. gcore/resources/cloud/reserved_fixed_ips/reserved_fixed_ips.py +20 -20
  43. gcore/resources/cloud/reserved_fixed_ips/vip.py +10 -10
  44. gcore/resources/cloud/security_groups/rules.py +6 -6
  45. gcore/resources/cloud/security_groups/security_groups.py +70 -31
  46. gcore/resources/cloud/tasks.py +4 -4
  47. gcore/resources/cloud/users/role_assignments.py +12 -14
  48. gcore/resources/cloud/volumes.py +139 -49
  49. gcore/resources/iam/__init__.py +47 -0
  50. gcore/resources/iam/api_tokens.py +521 -0
  51. gcore/resources/iam/iam.py +199 -0
  52. gcore/resources/iam/users.py +642 -0
  53. gcore/resources/waap/__init__.py +0 -14
  54. gcore/resources/waap/waap.py +0 -32
  55. gcore/types/cloud/baremetal/__init__.py +0 -1
  56. gcore/types/cloud/baremetal/image_list_params.py +1 -5
  57. gcore/types/cloud/baremetal/server_create_params.py +4 -8
  58. gcore/types/cloud/baremetal/server_list_params.py +1 -5
  59. gcore/types/cloud/ddos_profile.py +9 -3
  60. gcore/types/cloud/file_share_create_params.py +3 -5
  61. gcore/types/cloud/floating_ip_create_params.py +2 -4
  62. gcore/types/cloud/floating_ip_list_params.py +1 -5
  63. gcore/types/cloud/gpu_baremetal_cluster_create_params.py +2 -3
  64. gcore/types/cloud/gpu_baremetal_clusters/image_upload_params.py +2 -4
  65. gcore/types/cloud/health_monitor.py +6 -1
  66. gcore/types/cloud/instance_create_params.py +7 -8
  67. gcore/types/cloud/instance_list_params.py +1 -5
  68. gcore/types/cloud/instances/__init__.py +0 -2
  69. gcore/types/cloud/instances/image_create_from_volume_params.py +2 -4
  70. gcore/types/cloud/instances/image_list_params.py +1 -5
  71. gcore/types/cloud/instances/image_upload_params.py +2 -4
  72. gcore/types/cloud/load_balancer_create_params.py +8 -4
  73. gcore/types/cloud/load_balancer_list_params.py +1 -5
  74. gcore/types/cloud/load_balancer_update_params.py +24 -0
  75. gcore/types/cloud/load_balancers/pool_create_params.py +6 -1
  76. gcore/types/cloud/load_balancers/pool_update_params.py +6 -1
  77. gcore/types/cloud/load_balancers/pools/member_add_params.py +6 -1
  78. gcore/types/cloud/member.py +6 -1
  79. gcore/types/cloud/network_create_params.py +2 -3
  80. gcore/types/cloud/network_list_params.py +4 -5
  81. gcore/types/cloud/network_update_params.py +28 -2
  82. gcore/types/cloud/networks/router_list_params.py +2 -2
  83. gcore/types/cloud/networks/subnet_create_params.py +2 -3
  84. gcore/types/cloud/networks/subnet_list_params.py +1 -5
  85. gcore/types/cloud/networks/subnet_update_params.py +25 -0
  86. gcore/types/cloud/registries/__init__.py +1 -0
  87. gcore/types/cloud/registries/user_refresh_secret_response.py +31 -0
  88. gcore/types/cloud/reserved_fixed_ip_list_params.py +2 -2
  89. gcore/types/cloud/security_group_list_params.py +3 -7
  90. gcore/types/cloud/security_group_update_params.py +25 -0
  91. gcore/types/cloud/tag_update_map_param.py +2 -2
  92. gcore/types/cloud/volume_list_params.py +1 -5
  93. gcore/types/cloud/volume_update_params.py +29 -3
  94. gcore/types/iam/__init__.py +17 -0
  95. gcore/types/iam/account_overview.py +488 -0
  96. gcore/types/iam/api_token.py +78 -0
  97. gcore/types/iam/api_token_create.py +15 -0
  98. gcore/types/iam/api_token_create_params.py +42 -0
  99. gcore/types/iam/api_token_list.py +81 -0
  100. gcore/types/iam/api_token_list_params.py +41 -0
  101. gcore/types/iam/user.py +86 -0
  102. gcore/types/iam/user_detailed.py +104 -0
  103. gcore/types/iam/user_invite.py +15 -0
  104. gcore/types/iam/user_invite_params.py +37 -0
  105. gcore/types/iam/user_list_params.py +15 -0
  106. gcore/types/iam/user_update.py +104 -0
  107. gcore/types/iam/user_update_params.py +52 -0
  108. gcore/types/waap/__init__.py +0 -1
  109. gcore/types/waap/domains/custom_rule_create_params.py +7 -3
  110. gcore/types/waap/domains/custom_rule_update_params.py +7 -3
  111. gcore/types/waap/waap_custom_rule.py +7 -3
  112. {gcore-0.3.0.dist-info → gcore-0.4.0.dist-info}/METADATA +40 -3
  113. {gcore-0.3.0.dist-info → gcore-0.4.0.dist-info}/RECORD +115 -101
  114. gcore/resources/waap/clients.py +0 -135
  115. gcore/types/cloud/baremetal/flavor_list_suitable_params.py +0 -22
  116. gcore/types/cloud/instances/flavor_list_for_resize_params.py +0 -16
  117. gcore/types/cloud/instances/flavor_list_suitable_params.py +0 -59
  118. gcore/types/waap/client_me_response.py +0 -34
  119. {gcore-0.3.0.dist-info → gcore-0.4.0.dist-info}/WHEEL +0 -0
  120. {gcore-0.3.0.dist-info → gcore-0.4.0.dist-info}/licenses/LICENSE +0 -0
@@ -0,0 +1,642 @@
1
+ # File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details.
2
+
3
+ from __future__ import annotations
4
+
5
+ from typing import List, Iterable, Optional
6
+ from typing_extensions import Literal
7
+
8
+ import httpx
9
+
10
+ from ..._types import NOT_GIVEN, Body, Query, Headers, NoneType, NotGiven
11
+ from ..._utils import maybe_transform, async_maybe_transform
12
+ from ..._compat import cached_property
13
+ from ..._resource import SyncAPIResource, AsyncAPIResource
14
+ from ..._response import (
15
+ to_raw_response_wrapper,
16
+ to_streamed_response_wrapper,
17
+ async_to_raw_response_wrapper,
18
+ async_to_streamed_response_wrapper,
19
+ )
20
+ from ...types.iam import user_list_params, user_invite_params, user_update_params
21
+ from ...pagination import SyncOffsetPageIam, AsyncOffsetPageIam
22
+ from ..._base_client import AsyncPaginator, make_request_options
23
+ from ...types.iam.user import User
24
+ from ...types.iam.user_invite import UserInvite
25
+ from ...types.iam.user_update import UserUpdate
26
+ from ...types.iam.user_detailed import UserDetailed
27
+
28
+ __all__ = ["UsersResource", "AsyncUsersResource"]
29
+
30
+
31
+ class UsersResource(SyncAPIResource):
32
+ @cached_property
33
+ def with_raw_response(self) -> UsersResourceWithRawResponse:
34
+ """
35
+ This property can be used as a prefix for any HTTP method call to return
36
+ the raw response object instead of the parsed content.
37
+
38
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
39
+ """
40
+ return UsersResourceWithRawResponse(self)
41
+
42
+ @cached_property
43
+ def with_streaming_response(self) -> UsersResourceWithStreamingResponse:
44
+ """
45
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
46
+
47
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
48
+ """
49
+ return UsersResourceWithStreamingResponse(self)
50
+
51
+ def update(
52
+ self,
53
+ user_id: int,
54
+ *,
55
+ auth_types: List[Literal["password", "sso", "github", "google-oauth2"]] | NotGiven = NOT_GIVEN,
56
+ company: str | NotGiven = NOT_GIVEN,
57
+ email: str | NotGiven = NOT_GIVEN,
58
+ groups: Iterable[user_update_params.Group] | NotGiven = NOT_GIVEN,
59
+ lang: Literal["de", "en", "ru", "zh", "az"] | NotGiven = NOT_GIVEN,
60
+ name: Optional[str] | NotGiven = NOT_GIVEN,
61
+ phone: Optional[str] | NotGiven = NOT_GIVEN,
62
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
63
+ # The extra values given here take precedence over values defined on the client or passed to this method.
64
+ extra_headers: Headers | None = None,
65
+ extra_query: Query | None = None,
66
+ extra_body: Body | None = None,
67
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
68
+ ) -> UserUpdate:
69
+ """This method updates user's details.
70
+
71
+ Args:
72
+ auth_types: System field.
73
+
74
+ List of auth types available for the account.
75
+
76
+ company: User's company.
77
+
78
+ email: User's email address.
79
+
80
+ groups:
81
+ User's group in the current account. IAM supports 5 groups:
82
+
83
+ - Users
84
+ - Administrators
85
+ - Engineers
86
+ - Purge and Prefetch only (API)
87
+ - Purge and Prefetch only (API+Web)
88
+
89
+ lang: User's language. Defines language of the control panel and email messages.
90
+
91
+ name: User's name.
92
+
93
+ phone: User's phone.
94
+
95
+ extra_headers: Send extra headers
96
+
97
+ extra_query: Add additional query parameters to the request
98
+
99
+ extra_body: Add additional JSON properties to the request
100
+
101
+ timeout: Override the client-level default timeout for this request, in seconds
102
+ """
103
+ return self._patch(
104
+ f"/iam/users/{user_id}",
105
+ body=maybe_transform(
106
+ {
107
+ "auth_types": auth_types,
108
+ "company": company,
109
+ "email": email,
110
+ "groups": groups,
111
+ "lang": lang,
112
+ "name": name,
113
+ "phone": phone,
114
+ },
115
+ user_update_params.UserUpdateParams,
116
+ ),
117
+ options=make_request_options(
118
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
119
+ ),
120
+ cast_to=UserUpdate,
121
+ )
122
+
123
+ def list(
124
+ self,
125
+ *,
126
+ limit: int | NotGiven = NOT_GIVEN,
127
+ offset: int | NotGiven = NOT_GIVEN,
128
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
129
+ # The extra values given here take precedence over values defined on the client or passed to this method.
130
+ extra_headers: Headers | None = None,
131
+ extra_query: Query | None = None,
132
+ extra_body: Body | None = None,
133
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
134
+ ) -> SyncOffsetPageIam[User]:
135
+ """Get a list of users.
136
+
137
+ Pass a value for the `limit` parameter in your request if
138
+ you want retrieve a paginated result. Otherwise API returns a list with all
139
+ users without pagination.
140
+
141
+ Args:
142
+ limit: The maximum number of items.
143
+
144
+ offset: Offset relative to the beginning of list.
145
+
146
+ extra_headers: Send extra headers
147
+
148
+ extra_query: Add additional query parameters to the request
149
+
150
+ extra_body: Add additional JSON properties to the request
151
+
152
+ timeout: Override the client-level default timeout for this request, in seconds
153
+ """
154
+ return self._get_api_list(
155
+ "/iam/users",
156
+ page=SyncOffsetPageIam[User],
157
+ options=make_request_options(
158
+ extra_headers=extra_headers,
159
+ extra_query=extra_query,
160
+ extra_body=extra_body,
161
+ timeout=timeout,
162
+ query=maybe_transform(
163
+ {
164
+ "limit": limit,
165
+ "offset": offset,
166
+ },
167
+ user_list_params.UserListParams,
168
+ ),
169
+ ),
170
+ model=User,
171
+ )
172
+
173
+ def delete(
174
+ self,
175
+ user_id: int,
176
+ *,
177
+ client_id: int,
178
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
179
+ # The extra values given here take precedence over values defined on the client or passed to this method.
180
+ extra_headers: Headers | None = None,
181
+ extra_query: Query | None = None,
182
+ extra_body: Body | None = None,
183
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
184
+ ) -> None:
185
+ """Revokes user's access to the specified account.
186
+
187
+ If the specified user doesn't
188
+ have access to multiple accounts, the user is deleted.
189
+
190
+ Args:
191
+ extra_headers: Send extra headers
192
+
193
+ extra_query: Add additional query parameters to the request
194
+
195
+ extra_body: Add additional JSON properties to the request
196
+
197
+ timeout: Override the client-level default timeout for this request, in seconds
198
+ """
199
+ extra_headers = {"Accept": "*/*", **(extra_headers or {})}
200
+ return self._delete(
201
+ f"/iam/clients/{client_id}/client-users/{user_id}",
202
+ options=make_request_options(
203
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
204
+ ),
205
+ cast_to=NoneType,
206
+ )
207
+
208
+ def get(
209
+ self,
210
+ user_id: int,
211
+ *,
212
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
213
+ # The extra values given here take precedence over values defined on the client or passed to this method.
214
+ extra_headers: Headers | None = None,
215
+ extra_query: Query | None = None,
216
+ extra_body: Body | None = None,
217
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
218
+ ) -> UserDetailed:
219
+ """
220
+ Get user's details
221
+
222
+ Args:
223
+ extra_headers: Send extra headers
224
+
225
+ extra_query: Add additional query parameters to the request
226
+
227
+ extra_body: Add additional JSON properties to the request
228
+
229
+ timeout: Override the client-level default timeout for this request, in seconds
230
+ """
231
+ return self._get(
232
+ f"/iam/users/{user_id}",
233
+ options=make_request_options(
234
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
235
+ ),
236
+ cast_to=UserDetailed,
237
+ )
238
+
239
+ def invite(
240
+ self,
241
+ *,
242
+ client_id: int,
243
+ email: str,
244
+ user_role: user_invite_params.UserRole,
245
+ lang: Literal["de", "en", "ru", "zh", "az"] | NotGiven = NOT_GIVEN,
246
+ name: str | NotGiven = NOT_GIVEN,
247
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
248
+ # The extra values given here take precedence over values defined on the client or passed to this method.
249
+ extra_headers: Headers | None = None,
250
+ extra_query: Query | None = None,
251
+ extra_body: Body | None = None,
252
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
253
+ ) -> UserInvite:
254
+ """Invite a user to the account.
255
+
256
+ User will receive an email. The new user will
257
+ receive an invitation email with a link to create an account password, the
258
+ existing user will be notified about the invitation to the account.
259
+
260
+ Args:
261
+ client_id: ID of account.
262
+
263
+ email: User email.
264
+
265
+ lang: User's language. Defines language of the control panel and email messages.
266
+
267
+ name: User name.
268
+
269
+ extra_headers: Send extra headers
270
+
271
+ extra_query: Add additional query parameters to the request
272
+
273
+ extra_body: Add additional JSON properties to the request
274
+
275
+ timeout: Override the client-level default timeout for this request, in seconds
276
+ """
277
+ return self._post(
278
+ "/iam/clients/invite_user",
279
+ body=maybe_transform(
280
+ {
281
+ "client_id": client_id,
282
+ "email": email,
283
+ "user_role": user_role,
284
+ "lang": lang,
285
+ "name": name,
286
+ },
287
+ user_invite_params.UserInviteParams,
288
+ ),
289
+ options=make_request_options(
290
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
291
+ ),
292
+ cast_to=UserInvite,
293
+ )
294
+
295
+
296
+ class AsyncUsersResource(AsyncAPIResource):
297
+ @cached_property
298
+ def with_raw_response(self) -> AsyncUsersResourceWithRawResponse:
299
+ """
300
+ This property can be used as a prefix for any HTTP method call to return
301
+ the raw response object instead of the parsed content.
302
+
303
+ For more information, see https://www.github.com/G-Core/gcore-python#accessing-raw-response-data-eg-headers
304
+ """
305
+ return AsyncUsersResourceWithRawResponse(self)
306
+
307
+ @cached_property
308
+ def with_streaming_response(self) -> AsyncUsersResourceWithStreamingResponse:
309
+ """
310
+ An alternative to `.with_raw_response` that doesn't eagerly read the response body.
311
+
312
+ For more information, see https://www.github.com/G-Core/gcore-python#with_streaming_response
313
+ """
314
+ return AsyncUsersResourceWithStreamingResponse(self)
315
+
316
+ async def update(
317
+ self,
318
+ user_id: int,
319
+ *,
320
+ auth_types: List[Literal["password", "sso", "github", "google-oauth2"]] | NotGiven = NOT_GIVEN,
321
+ company: str | NotGiven = NOT_GIVEN,
322
+ email: str | NotGiven = NOT_GIVEN,
323
+ groups: Iterable[user_update_params.Group] | NotGiven = NOT_GIVEN,
324
+ lang: Literal["de", "en", "ru", "zh", "az"] | NotGiven = NOT_GIVEN,
325
+ name: Optional[str] | NotGiven = NOT_GIVEN,
326
+ phone: Optional[str] | NotGiven = NOT_GIVEN,
327
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
328
+ # The extra values given here take precedence over values defined on the client or passed to this method.
329
+ extra_headers: Headers | None = None,
330
+ extra_query: Query | None = None,
331
+ extra_body: Body | None = None,
332
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
333
+ ) -> UserUpdate:
334
+ """This method updates user's details.
335
+
336
+ Args:
337
+ auth_types: System field.
338
+
339
+ List of auth types available for the account.
340
+
341
+ company: User's company.
342
+
343
+ email: User's email address.
344
+
345
+ groups:
346
+ User's group in the current account. IAM supports 5 groups:
347
+
348
+ - Users
349
+ - Administrators
350
+ - Engineers
351
+ - Purge and Prefetch only (API)
352
+ - Purge and Prefetch only (API+Web)
353
+
354
+ lang: User's language. Defines language of the control panel and email messages.
355
+
356
+ name: User's name.
357
+
358
+ phone: User's phone.
359
+
360
+ extra_headers: Send extra headers
361
+
362
+ extra_query: Add additional query parameters to the request
363
+
364
+ extra_body: Add additional JSON properties to the request
365
+
366
+ timeout: Override the client-level default timeout for this request, in seconds
367
+ """
368
+ return await self._patch(
369
+ f"/iam/users/{user_id}",
370
+ body=await async_maybe_transform(
371
+ {
372
+ "auth_types": auth_types,
373
+ "company": company,
374
+ "email": email,
375
+ "groups": groups,
376
+ "lang": lang,
377
+ "name": name,
378
+ "phone": phone,
379
+ },
380
+ user_update_params.UserUpdateParams,
381
+ ),
382
+ options=make_request_options(
383
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
384
+ ),
385
+ cast_to=UserUpdate,
386
+ )
387
+
388
+ def list(
389
+ self,
390
+ *,
391
+ limit: int | NotGiven = NOT_GIVEN,
392
+ offset: int | NotGiven = NOT_GIVEN,
393
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
394
+ # The extra values given here take precedence over values defined on the client or passed to this method.
395
+ extra_headers: Headers | None = None,
396
+ extra_query: Query | None = None,
397
+ extra_body: Body | None = None,
398
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
399
+ ) -> AsyncPaginator[User, AsyncOffsetPageIam[User]]:
400
+ """Get a list of users.
401
+
402
+ Pass a value for the `limit` parameter in your request if
403
+ you want retrieve a paginated result. Otherwise API returns a list with all
404
+ users without pagination.
405
+
406
+ Args:
407
+ limit: The maximum number of items.
408
+
409
+ offset: Offset relative to the beginning of list.
410
+
411
+ extra_headers: Send extra headers
412
+
413
+ extra_query: Add additional query parameters to the request
414
+
415
+ extra_body: Add additional JSON properties to the request
416
+
417
+ timeout: Override the client-level default timeout for this request, in seconds
418
+ """
419
+ return self._get_api_list(
420
+ "/iam/users",
421
+ page=AsyncOffsetPageIam[User],
422
+ options=make_request_options(
423
+ extra_headers=extra_headers,
424
+ extra_query=extra_query,
425
+ extra_body=extra_body,
426
+ timeout=timeout,
427
+ query=maybe_transform(
428
+ {
429
+ "limit": limit,
430
+ "offset": offset,
431
+ },
432
+ user_list_params.UserListParams,
433
+ ),
434
+ ),
435
+ model=User,
436
+ )
437
+
438
+ async def delete(
439
+ self,
440
+ user_id: int,
441
+ *,
442
+ client_id: int,
443
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
444
+ # The extra values given here take precedence over values defined on the client or passed to this method.
445
+ extra_headers: Headers | None = None,
446
+ extra_query: Query | None = None,
447
+ extra_body: Body | None = None,
448
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
449
+ ) -> None:
450
+ """Revokes user's access to the specified account.
451
+
452
+ If the specified user doesn't
453
+ have access to multiple accounts, the user is deleted.
454
+
455
+ Args:
456
+ extra_headers: Send extra headers
457
+
458
+ extra_query: Add additional query parameters to the request
459
+
460
+ extra_body: Add additional JSON properties to the request
461
+
462
+ timeout: Override the client-level default timeout for this request, in seconds
463
+ """
464
+ extra_headers = {"Accept": "*/*", **(extra_headers or {})}
465
+ return await self._delete(
466
+ f"/iam/clients/{client_id}/client-users/{user_id}",
467
+ options=make_request_options(
468
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
469
+ ),
470
+ cast_to=NoneType,
471
+ )
472
+
473
+ async def get(
474
+ self,
475
+ user_id: int,
476
+ *,
477
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
478
+ # The extra values given here take precedence over values defined on the client or passed to this method.
479
+ extra_headers: Headers | None = None,
480
+ extra_query: Query | None = None,
481
+ extra_body: Body | None = None,
482
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
483
+ ) -> UserDetailed:
484
+ """
485
+ Get user's details
486
+
487
+ Args:
488
+ extra_headers: Send extra headers
489
+
490
+ extra_query: Add additional query parameters to the request
491
+
492
+ extra_body: Add additional JSON properties to the request
493
+
494
+ timeout: Override the client-level default timeout for this request, in seconds
495
+ """
496
+ return await self._get(
497
+ f"/iam/users/{user_id}",
498
+ options=make_request_options(
499
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
500
+ ),
501
+ cast_to=UserDetailed,
502
+ )
503
+
504
+ async def invite(
505
+ self,
506
+ *,
507
+ client_id: int,
508
+ email: str,
509
+ user_role: user_invite_params.UserRole,
510
+ lang: Literal["de", "en", "ru", "zh", "az"] | NotGiven = NOT_GIVEN,
511
+ name: str | NotGiven = NOT_GIVEN,
512
+ # Use the following arguments if you need to pass additional parameters to the API that aren't available via kwargs.
513
+ # The extra values given here take precedence over values defined on the client or passed to this method.
514
+ extra_headers: Headers | None = None,
515
+ extra_query: Query | None = None,
516
+ extra_body: Body | None = None,
517
+ timeout: float | httpx.Timeout | None | NotGiven = NOT_GIVEN,
518
+ ) -> UserInvite:
519
+ """Invite a user to the account.
520
+
521
+ User will receive an email. The new user will
522
+ receive an invitation email with a link to create an account password, the
523
+ existing user will be notified about the invitation to the account.
524
+
525
+ Args:
526
+ client_id: ID of account.
527
+
528
+ email: User email.
529
+
530
+ lang: User's language. Defines language of the control panel and email messages.
531
+
532
+ name: User name.
533
+
534
+ extra_headers: Send extra headers
535
+
536
+ extra_query: Add additional query parameters to the request
537
+
538
+ extra_body: Add additional JSON properties to the request
539
+
540
+ timeout: Override the client-level default timeout for this request, in seconds
541
+ """
542
+ return await self._post(
543
+ "/iam/clients/invite_user",
544
+ body=await async_maybe_transform(
545
+ {
546
+ "client_id": client_id,
547
+ "email": email,
548
+ "user_role": user_role,
549
+ "lang": lang,
550
+ "name": name,
551
+ },
552
+ user_invite_params.UserInviteParams,
553
+ ),
554
+ options=make_request_options(
555
+ extra_headers=extra_headers, extra_query=extra_query, extra_body=extra_body, timeout=timeout
556
+ ),
557
+ cast_to=UserInvite,
558
+ )
559
+
560
+
561
+ class UsersResourceWithRawResponse:
562
+ def __init__(self, users: UsersResource) -> None:
563
+ self._users = users
564
+
565
+ self.update = to_raw_response_wrapper(
566
+ users.update,
567
+ )
568
+ self.list = to_raw_response_wrapper(
569
+ users.list,
570
+ )
571
+ self.delete = to_raw_response_wrapper(
572
+ users.delete,
573
+ )
574
+ self.get = to_raw_response_wrapper(
575
+ users.get,
576
+ )
577
+ self.invite = to_raw_response_wrapper(
578
+ users.invite,
579
+ )
580
+
581
+
582
+ class AsyncUsersResourceWithRawResponse:
583
+ def __init__(self, users: AsyncUsersResource) -> None:
584
+ self._users = users
585
+
586
+ self.update = async_to_raw_response_wrapper(
587
+ users.update,
588
+ )
589
+ self.list = async_to_raw_response_wrapper(
590
+ users.list,
591
+ )
592
+ self.delete = async_to_raw_response_wrapper(
593
+ users.delete,
594
+ )
595
+ self.get = async_to_raw_response_wrapper(
596
+ users.get,
597
+ )
598
+ self.invite = async_to_raw_response_wrapper(
599
+ users.invite,
600
+ )
601
+
602
+
603
+ class UsersResourceWithStreamingResponse:
604
+ def __init__(self, users: UsersResource) -> None:
605
+ self._users = users
606
+
607
+ self.update = to_streamed_response_wrapper(
608
+ users.update,
609
+ )
610
+ self.list = to_streamed_response_wrapper(
611
+ users.list,
612
+ )
613
+ self.delete = to_streamed_response_wrapper(
614
+ users.delete,
615
+ )
616
+ self.get = to_streamed_response_wrapper(
617
+ users.get,
618
+ )
619
+ self.invite = to_streamed_response_wrapper(
620
+ users.invite,
621
+ )
622
+
623
+
624
+ class AsyncUsersResourceWithStreamingResponse:
625
+ def __init__(self, users: AsyncUsersResource) -> None:
626
+ self._users = users
627
+
628
+ self.update = async_to_streamed_response_wrapper(
629
+ users.update,
630
+ )
631
+ self.list = async_to_streamed_response_wrapper(
632
+ users.list,
633
+ )
634
+ self.delete = async_to_streamed_response_wrapper(
635
+ users.delete,
636
+ )
637
+ self.get = async_to_streamed_response_wrapper(
638
+ users.get,
639
+ )
640
+ self.invite = async_to_streamed_response_wrapper(
641
+ users.invite,
642
+ )
@@ -16,14 +16,6 @@ from .waap import (
16
16
  WaapResourceWithStreamingResponse,
17
17
  AsyncWaapResourceWithStreamingResponse,
18
18
  )
19
- from .clients import (
20
- ClientsResource,
21
- AsyncClientsResource,
22
- ClientsResourceWithRawResponse,
23
- AsyncClientsResourceWithRawResponse,
24
- ClientsResourceWithStreamingResponse,
25
- AsyncClientsResourceWithStreamingResponse,
26
- )
27
19
  from .domains import (
28
20
  DomainsResource,
29
21
  AsyncDomainsResource,
@@ -74,12 +66,6 @@ from .custom_page_sets import (
74
66
  )
75
67
 
76
68
  __all__ = [
77
- "ClientsResource",
78
- "AsyncClientsResource",
79
- "ClientsResourceWithRawResponse",
80
- "AsyncClientsResourceWithRawResponse",
81
- "ClientsResourceWithStreamingResponse",
82
- "AsyncClientsResourceWithStreamingResponse",
83
69
  "StatisticsResource",
84
70
  "AsyncStatisticsResource",
85
71
  "StatisticsResourceWithRawResponse",