@turinhub/tale-js-sdk 1.3.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/README.md +6 -6
  2. package/dist/acl/index.d.ts +62 -49
  3. package/dist/acl/index.js +262 -67
  4. package/dist/acl/types.d.ts +63 -98
  5. package/dist/attachment/index.d.ts +17 -0
  6. package/dist/attachment/index.js +247 -0
  7. package/dist/attachment/types.d.ts +82 -0
  8. package/dist/attachment/types.js +1 -0
  9. package/dist/attachment-type/index.d.ts +15 -0
  10. package/dist/attachment-type/index.js +203 -0
  11. package/dist/attachment-type/types.d.ts +60 -0
  12. package/dist/attachment-type/types.js +1 -0
  13. package/dist/auth/index.d.ts +21 -21
  14. package/dist/auth/index.js +66 -66
  15. package/dist/auth/types.d.ts +51 -51
  16. package/dist/cms/file.d.ts +88 -70
  17. package/dist/cms/file.js +228 -77
  18. package/dist/cms/folder.d.ts +9 -9
  19. package/dist/cms/folder.js +18 -18
  20. package/dist/cms/types.d.ts +58 -38
  21. package/dist/common/types.d.ts +47 -63
  22. package/dist/index.d.ts +4 -1
  23. package/dist/index.js +2 -0
  24. package/dist/rbac/index.d.ts +37 -42
  25. package/dist/rbac/index.js +96 -98
  26. package/dist/rbac/types.d.ts +38 -40
  27. package/dist/status.d.ts +11 -11
  28. package/dist/status.js +30 -3
  29. package/dist/task/index.d.ts +15 -147
  30. package/dist/task/index.js +170 -161
  31. package/dist/task/types.d.ts +57 -81
  32. package/dist/task-type/index.d.ts +7 -7
  33. package/dist/task-type/index.js +12 -12
  34. package/dist/task-type/types.d.ts +18 -34
  35. package/dist/token.d.ts +3 -3
  36. package/dist/token.js +4 -4
  37. package/dist/user/index.d.ts +28 -29
  38. package/dist/user/index.js +69 -74
  39. package/dist/user/types.d.ts +32 -33
  40. package/dist/user-attribute/index.d.ts +4 -7
  41. package/dist/user-attribute/index.js +19 -22
  42. package/dist/user-attribute/types.d.ts +29 -29
  43. package/dist/user-group/index.d.ts +4 -223
  44. package/dist/user-group/index.js +61 -479
  45. package/dist/user-group/types.d.ts +1 -1
  46. package/package.json +1 -1
@@ -32,10 +32,10 @@ function parseApiResponse(json, errorMessage, statusCode) {
32
32
  * @example
33
33
  * ```typescript
34
34
  * const definition = await createUserAttributeDefinition({
35
- * attribute_name: "department",
35
+ * attributeName: "department",
36
36
  * description: "User's department",
37
- * schema_definition: { type: "string" },
38
- * is_enabled: true,
37
+ * schemaDefinition: { type: "string" },
38
+ * isEnabled: true,
39
39
  * });
40
40
  * ```
41
41
  */
@@ -46,7 +46,7 @@ export async function createUserAttributeDefinition(request, options) {
46
46
  if (!base) {
47
47
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
48
48
  }
49
- const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v1/definition");
49
+ const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v2/definition");
50
50
  let response;
51
51
  try {
52
52
  response = await globalThis.fetch(url.toString(), {
@@ -83,7 +83,7 @@ export async function updateUserAttributeDefinition(openId, request, options) {
83
83
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
84
84
  }
85
85
  const url = new URL(String(base).replace(/\/+$/, "") +
86
- `/user-attribute/v1/definition/${encodeURIComponent(openId)}`);
86
+ `/user-attribute/v2/definition/${encodeURIComponent(openId)}`);
87
87
  let response;
88
88
  try {
89
89
  response = await globalThis.fetch(url.toString(), {
@@ -118,7 +118,7 @@ export async function deleteUserAttributeDefinition(openId, options) {
118
118
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
119
119
  }
120
120
  const url = new URL(String(base).replace(/\/+$/, "") +
121
- `/user-attribute/v1/definition/${encodeURIComponent(openId)}`);
121
+ `/user-attribute/v2/definition/${encodeURIComponent(openId)}`);
122
122
  let response;
123
123
  try {
124
124
  response = await globalThis.fetch(url.toString(), {
@@ -162,7 +162,7 @@ export async function getUserAttributeDefinition(openId, options) {
162
162
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
163
163
  }
164
164
  const url = new URL(String(base).replace(/\/+$/, "") +
165
- `/user-attribute/v1/definition/${encodeURIComponent(openId)}`);
165
+ `/user-attribute/v2/definition/${encodeURIComponent(openId)}`);
166
166
  let response;
167
167
  try {
168
168
  response = await globalThis.fetch(url.toString(), {
@@ -207,7 +207,7 @@ export async function listUserAttributeDefinitions(request) {
207
207
  if (!base) {
208
208
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
209
209
  }
210
- const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v1/definition");
210
+ const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v2/definition");
211
211
  const { appToken, baseUrl, ...requestParams } = request || {};
212
212
  const queryParams = {
213
213
  page: 0,
@@ -252,7 +252,7 @@ export async function listEnabledUserAttributeDefinitions(options) {
252
252
  if (!base) {
253
253
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
254
254
  }
255
- const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v1/definition/enabled");
255
+ const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v2/definition/enabled");
256
256
  let response;
257
257
  try {
258
258
  response = await globalThis.fetch(url.toString(), {
@@ -292,7 +292,7 @@ export async function toggleUserAttributeDefinitionStatus(openId, isEnabled, opt
292
292
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
293
293
  }
294
294
  const url = new URL(String(base).replace(/\/+$/, "") +
295
- `/user-attribute/v1/definition/${encodeURIComponent(openId)}/status`);
295
+ `/user-attribute/v2/definition/${encodeURIComponent(openId)}/status`);
296
296
  url.searchParams.append("enabled", String(isEnabled));
297
297
  let response;
298
298
  try {
@@ -331,7 +331,7 @@ export async function setUserAttribute(userId, attributeDefinitionId, request, o
331
331
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
332
332
  }
333
333
  const url = new URL(String(base).replace(/\/+$/, "") +
334
- `/user-attribute/v1/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
334
+ `/user-attribute/v2/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
335
335
  let response;
336
336
  try {
337
337
  response = await globalThis.fetch(url.toString(), {
@@ -368,7 +368,7 @@ export async function getUserAttribute(userId, attributeDefinitionId, options) {
368
368
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
369
369
  }
370
370
  const url = new URL(String(base).replace(/\/+$/, "") +
371
- `/user-attribute/v1/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
371
+ `/user-attribute/v2/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
372
372
  let response;
373
373
  try {
374
374
  response = await globalThis.fetch(url.toString(), {
@@ -403,7 +403,7 @@ export async function deleteUserAttribute(userId, attributeDefinitionId, options
403
403
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
404
404
  }
405
405
  const url = new URL(String(base).replace(/\/+$/, "") +
406
- `/user-attribute/v1/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
406
+ `/user-attribute/v2/user/${encodeURIComponent(userId)}/attribute/${encodeURIComponent(attributeDefinitionId)}`);
407
407
  let response;
408
408
  try {
409
409
  response = await globalThis.fetch(url.toString(), {
@@ -447,7 +447,7 @@ export async function getUserAttributes(userId, options) {
447
447
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
448
448
  }
449
449
  const url = new URL(String(base).replace(/\/+$/, "") +
450
- `/user-attribute/v1/user/${encodeURIComponent(userId)}/attribute`);
450
+ `/user-attribute/v2/user/${encodeURIComponent(userId)}/attribute`);
451
451
  let response;
452
452
  try {
453
453
  response = await globalThis.fetch(url.toString(), {
@@ -487,7 +487,7 @@ export async function listUserAttributes(userId, request) {
487
487
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
488
488
  }
489
489
  const url = new URL(String(base).replace(/\/+$/, "") +
490
- `/user-attribute/v1/user/${encodeURIComponent(userId)}/attribute/page`);
490
+ `/user-attribute/v2/user/${encodeURIComponent(userId)}/attribute/page`);
491
491
  const { appToken, baseUrl, ...requestParams } = request || {};
492
492
  const queryParams = {
493
493
  page: 0,
@@ -535,11 +535,12 @@ export async function listAttributeUsers(attributeDefinitionId, request) {
535
535
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
536
536
  }
537
537
  const url = new URL(String(base).replace(/\/+$/, "") +
538
- `/user-attribute/v1/definition/${encodeURIComponent(attributeDefinitionId)}/users`);
538
+ `/user-attribute/v2/definition/${encodeURIComponent(attributeDefinitionId)}/users`);
539
539
  const { appToken, baseUrl, ...requestParams } = request || {};
540
540
  const queryParams = {
541
541
  page: 0,
542
542
  size: 20,
543
+ sort: "createdAt,desc",
543
544
  ...requestParams,
544
545
  };
545
546
  Object.entries(queryParams).forEach(([key, value]) => {
@@ -561,11 +562,7 @@ export async function listAttributeUsers(attributeDefinitionId, request) {
561
562
  throw new NetworkError(`Failed to list attribute users: ${error instanceof Error ? error.message : "Unknown error"}`);
562
563
  }
563
564
  const json = await response.json();
564
- const data = parseApiResponse(json, "Failed to list attribute users", response.status);
565
- if (!Array.isArray(data.content)) {
566
- throw new ApiError("Invalid attribute users response: content is not an array", response.status);
567
- }
568
- return data;
565
+ return parseApiResponse(json, "Failed to list attribute users", response.status);
569
566
  }
570
567
  /**
571
568
  * Lists all user attributes grouped by user with pagination.
@@ -584,7 +581,7 @@ export async function listAllUserAttributes(request) {
584
581
  if (!base) {
585
582
  throw new ConfigurationError("Missing required environment variable: TALE_BASE_URL");
586
583
  }
587
- const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v1/user/attribute/page");
584
+ const url = new URL(String(base).replace(/\/+$/, "") + "/user-attribute/v2/user/attribute/page");
588
585
  const { appToken, baseUrl, ...requestParams } = request || {};
589
586
  const queryParams = {
590
587
  page: 0,
@@ -3,78 +3,78 @@ import type { CommonOptions } from "../common/types.js";
3
3
  * User attribute definition
4
4
  */
5
5
  export interface UserAttributeDefinition {
6
- open_id: string;
7
- attribute_name: string;
6
+ openId: string;
7
+ attributeName: string;
8
8
  description?: string;
9
- schema_definition: Record<string, unknown>;
10
- is_enabled: boolean;
11
- created_at: string;
12
- updated_at: string;
9
+ schemaDefinition: Record<string, unknown>;
10
+ isEnabled: boolean;
11
+ createdAt: string;
12
+ updatedAt: string;
13
13
  remark?: string;
14
14
  }
15
15
  /**
16
16
  * User attribute value (matches backend UserAttributeDTO)
17
17
  */
18
18
  export interface UserAttributeDTO {
19
- user_id: string;
20
- attribute_definition_id: string;
21
- attribute_name: string;
22
- attribute_value: Record<string, unknown>;
23
- created_at: string;
24
- updated_at: string;
19
+ userId: string;
20
+ attributeDefinitionId: string;
21
+ attributeName: string;
22
+ attributeValue: Record<string, unknown>;
23
+ createdAt: string;
24
+ updatedAt: string;
25
25
  remark?: string;
26
26
  }
27
27
  /**
28
- * User attribute item (without user_id, matches backend UserAttributeItemDTO)
28
+ * User attribute item (without userId, matches backend UserAttributeItemDTO)
29
29
  */
30
30
  export interface UserAttributeItemDTO {
31
- attribute_definition_id: string;
32
- attribute_name: string;
33
- attribute_value: Record<string, unknown>;
34
- created_at: string;
35
- updated_at: string;
31
+ attributeDefinitionId: string;
32
+ attributeName: string;
33
+ attributeValue: Record<string, unknown>;
34
+ createdAt: string;
35
+ updatedAt: string;
36
36
  remark?: string;
37
37
  }
38
38
  /**
39
39
  * User attribute grouped by user (matches backend UserAttributeGroupedDTO)
40
40
  */
41
41
  export interface UserAttributeGroupedDTO {
42
- user_id: string;
42
+ userId: string;
43
43
  username: string;
44
44
  nickname: string;
45
45
  email: string;
46
46
  phone: string;
47
- avatar_url?: string;
47
+ avatarUrl?: string;
48
48
  remark?: string;
49
- is_frozen: boolean;
50
- registered_at: string;
49
+ isFrozen: boolean;
50
+ registeredAt: string;
51
51
  attributes: UserAttributeItemDTO[];
52
52
  }
53
53
  /**
54
54
  * Request for creating a user attribute definition
55
55
  */
56
56
  export interface CreateUserAttributeDefinitionRequest {
57
- attribute_name: string;
57
+ attributeName: string;
58
58
  description?: string;
59
- schema_definition: Record<string, unknown>;
60
- is_enabled?: boolean;
59
+ schemaDefinition: Record<string, unknown>;
60
+ isEnabled?: boolean;
61
61
  remark?: string;
62
62
  }
63
63
  /**
64
64
  * Request for updating a user attribute definition
65
65
  */
66
66
  export interface UpdateUserAttributeDefinitionRequest {
67
- attribute_name?: string;
67
+ attributeName?: string;
68
68
  description?: string;
69
- schema_definition?: Record<string, unknown>;
70
- is_enabled?: boolean;
69
+ schemaDefinition?: Record<string, unknown>;
70
+ isEnabled?: boolean;
71
71
  remark?: string;
72
72
  }
73
73
  /**
74
74
  * Request for setting a user attribute value
75
75
  */
76
76
  export interface SetUserAttributeRequest {
77
- attribute_value: Record<string, unknown>;
77
+ attributeValue: Record<string, unknown>;
78
78
  remark?: string;
79
79
  }
80
80
  /**
@@ -1,231 +1,12 @@
1
1
  import type { PageResponse } from "../common/types.js";
2
2
  import type { UserGroupInfo, UserGroupMember, CreateUserGroupRequest, UpdateUserGroupRequest, UserGroupMemberRequest, UserGroupOptions, ListUserGroupsRequest, ListUserGroupMembersRequest } from "./types.js";
3
3
  export type { UserGroupInfo, UserGroupMember, CreateUserGroupRequest, UpdateUserGroupRequest, UserGroupMemberRequest, UserGroupOptions, ListUserGroupsRequest, ListUserGroupMembersRequest, } from "./types.js";
4
- /**
5
- * Gets a user group by ID.
6
- *
7
- * @param groupId - User group ID
8
- * @param options - Optional configuration
9
- * @returns Promise resolving to user group information
10
- * @throws {ConfigurationError} When required environment variables are missing
11
- * @throws {ApiError} When API request fails
12
- * @throws {NetworkError} When network request fails
13
- *
14
- * @example
15
- * ```typescript
16
- * import { getUserGroup } from '@tale/client';
17
- *
18
- * try {
19
- * const group = await getUserGroup('group_id_here');
20
- * console.log('Group name:', group.name);
21
- * } catch (error) {
22
- * console.error('Failed to get user group:', error.message);
23
- * }
24
- * ```
25
- */
26
4
  export declare function getUserGroup(groupId: string, options?: UserGroupOptions): Promise<UserGroupInfo>;
27
- /**
28
- * Lists user groups with pagination and optional keyword filtering.
29
- *
30
- * @param options - Optional parameters for pagination and filtering
31
- * @returns Promise resolving to paginated user group list
32
- * @throws {ConfigurationError} When required environment variables are missing
33
- * @throws {ApiError} When API request fails
34
- * @throws {NetworkError} When network request fails
35
- *
36
- * @example
37
- * ```typescript
38
- * import { listUserGroups } from '@tale/client';
39
- *
40
- * try {
41
- * const result = await listUserGroups({
42
- * page: 0,
43
- * size: 20,
44
- * keyword: 'admin'
45
- * });
46
- * console.log(`Found ${result.totalElements} user groups`);
47
- * } catch (error) {
48
- * console.error('Failed to list user groups:', error.message);
49
- * }
50
- * ```
51
- */
52
5
  export declare function listUserGroups(options?: ListUserGroupsRequest & UserGroupOptions): Promise<PageResponse<UserGroupInfo>>;
53
- /**
54
- * Creates a new user group.
55
- *
56
- * @param request - User group creation request
57
- * @param options - Optional configuration
58
- * @returns Promise resolving to created user group
59
- * @throws {ConfigurationError} When required environment variables are missing
60
- * @throws {ApiError} When API request fails
61
- * @throws {NetworkError} When network request fails
62
- *
63
- * @example
64
- * ```typescript
65
- * import { createUserGroup } from '@tale/client';
66
- *
67
- * try {
68
- * const group = await createUserGroup({
69
- * name: 'Administrators',
70
- * description: 'Admin users',
71
- * type: 'system'
72
- * });
73
- * console.log('Group created:', group.group_id);
74
- * } catch (error) {
75
- * console.error('Failed to create user group:', error.message);
76
- * }
77
- * ```
78
- */
79
- export declare function createUserGroup(request: CreateUserGroupRequest, options?: UserGroupOptions): Promise<UserGroupInfo>;
80
- /**
81
- * Updates an existing user group.
82
- *
83
- * @param groupId - User group ID to update
84
- * @param request - Update request with fields to modify
85
- * @param options - Optional configuration
86
- * @returns Promise resolving to updated user group
87
- * @throws {ConfigurationError} When required environment variables are missing
88
- * @throws {ApiError} When API request fails
89
- * @throws {NetworkError} When network request fails
90
- *
91
- * @example
92
- * ```typescript
93
- * import { updateUserGroup } from '@tale/client';
94
- *
95
- * try {
96
- * const group = await updateUserGroup('group_id_here', {
97
- * name: 'Updated Name',
98
- * description: 'Updated description'
99
- * });
100
- * console.log('Group updated:', group.name);
101
- * } catch (error) {
102
- * console.error('Failed to update user group:', error.message);
103
- * }
104
- * ```
105
- */
106
- export declare function updateUserGroup(groupId: string, request: UpdateUserGroupRequest, options?: UserGroupOptions): Promise<UserGroupInfo>;
107
- /**
108
- * Deletes a user group.
109
- *
110
- * @param groupId - User group ID to delete
111
- * @param options - Optional configuration
112
- * @returns Promise that resolves when deletion is successful
113
- * @throws {ConfigurationError} When required environment variables are missing
114
- * @throws {ApiError} When API request fails
115
- * @throws {NetworkError} When network request fails
116
- *
117
- * @example
118
- * ```typescript
119
- * import { deleteUserGroup } from '@tale/client';
120
- *
121
- * try {
122
- * await deleteUserGroup('group_id_here');
123
- * console.log('Group deleted successfully');
124
- * } catch (error) {
125
- * console.error('Failed to delete user group:', error.message);
126
- * }
127
- * ```
128
- */
6
+ export declare function createUserGroup(requestBody: CreateUserGroupRequest, options?: UserGroupOptions): Promise<UserGroupInfo>;
7
+ export declare function updateUserGroup(groupId: string, requestBody: UpdateUserGroupRequest, options?: UserGroupOptions): Promise<UserGroupInfo>;
129
8
  export declare function deleteUserGroup(groupId: string, options?: UserGroupOptions): Promise<void>;
130
- /**
131
- * Gets members of a user group with pagination.
132
- *
133
- * @param groupId - User group ID
134
- * @param options - Optional parameters for pagination
135
- * @returns Promise resolving to paginated member list
136
- * @throws {ConfigurationError} When required environment variables are missing
137
- * @throws {ApiError} When API request fails
138
- * @throws {NetworkError} When network request fails
139
- *
140
- * @example
141
- * ```typescript
142
- * import { listUserGroupMembers } from '@tale/client';
143
- *
144
- * try {
145
- * const result = await listUserGroupMembers('group_id_here', {
146
- * page: 0,
147
- * size: 20
148
- * });
149
- * console.log(`Found ${result.totalElements} members`);
150
- * } catch (error) {
151
- * console.error('Failed to list user group members:', error.message);
152
- * }
153
- * ```
154
- */
155
9
  export declare function listUserGroupMembers(groupId: string, options?: ListUserGroupMembersRequest & UserGroupOptions): Promise<PageResponse<UserGroupMember>>;
156
- /**
157
- * Adds members to a user group.
158
- *
159
- * @param groupId - User group ID
160
- * @param request - Request containing user IDs to add
161
- * @param options - Optional configuration
162
- * @returns Promise that resolves when members are added
163
- * @throws {ConfigurationError} When required environment variables are missing
164
- * @throws {ApiError} When API request fails
165
- * @throws {NetworkError} When network request fails
166
- *
167
- * @example
168
- * ```typescript
169
- * import { addUserGroupMembers } from '@tale/client';
170
- *
171
- * try {
172
- * await addUserGroupMembers('group_id_here', {
173
- * user_ids: ['user1', 'user2', 'user3']
174
- * });
175
- * console.log('Members added successfully');
176
- * } catch (error) {
177
- * console.error('Failed to add members:', error.message);
178
- * }
179
- * ```
180
- */
181
- export declare function addUserGroupMembers(groupId: string, request: UserGroupMemberRequest, options?: UserGroupOptions): Promise<void>;
182
- /**
183
- * Removes members from a user group.
184
- *
185
- * @param groupId - User group ID
186
- * @param request - Request containing user IDs to remove
187
- * @param options - Optional configuration
188
- * @returns Promise that resolves when members are removed
189
- * @throws {ConfigurationError} When required environment variables are missing
190
- * @throws {ApiError} When API request fails
191
- * @throws {NetworkError} When network request fails
192
- *
193
- * @example
194
- * ```typescript
195
- * import { removeUserGroupMembers } from '@tale/client';
196
- *
197
- * try {
198
- * await removeUserGroupMembers('group_id_here', {
199
- * user_ids: ['user1', 'user2']
200
- * });
201
- * console.log('Members removed successfully');
202
- * } catch (error) {
203
- * console.error('Failed to remove members:', error.message);
204
- * }
205
- * ```
206
- */
207
- export declare function removeUserGroupMembers(groupId: string, request: UserGroupMemberRequest, options?: UserGroupOptions): Promise<void>;
208
- /**
209
- * Gets all user groups that a user belongs to.
210
- *
211
- * @param userId - User ID
212
- * @param options - Optional configuration
213
- * @returns Promise resolving to list of user groups
214
- * @throws {ConfigurationError} When required environment variables are missing
215
- * @throws {ApiError} When API request fails
216
- * @throws {NetworkError} When network request fails
217
- *
218
- * @example
219
- * ```typescript
220
- * import { getUserGroups } from '@tale/client';
221
- *
222
- * try {
223
- * const groups = await getUserGroups('user_id_here');
224
- * console.log(`User belongs to ${groups.length} groups`);
225
- * groups.forEach(group => console.log('-', group.name));
226
- * } catch (error) {
227
- * console.error('Failed to get user groups:', error.message);
228
- * }
229
- * ```
230
- */
10
+ export declare function addUserGroupMembers(groupId: string, requestBody: UserGroupMemberRequest, options?: UserGroupOptions): Promise<void>;
11
+ export declare function removeUserGroupMembers(groupId: string, requestBody: UserGroupMemberRequest, options?: UserGroupOptions): Promise<void>;
231
12
  export declare function getUserGroups(userId: string, options?: UserGroupOptions): Promise<UserGroupInfo[]>;