librechat-data-provider 0.8.402 → 0.8.404

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 (109) hide show
  1. package/dist/index.es.js +1 -1
  2. package/dist/index.es.js.map +1 -1
  3. package/dist/index.js +1 -1
  4. package/dist/index.js.map +1 -1
  5. package/dist/react-query/index.es.js +1 -1
  6. package/dist/react-query/index.es.js.map +1 -1
  7. package/dist/types/accessPermissions.d.ts +744 -0
  8. package/dist/types/actions.d.ts +118 -0
  9. package/dist/types/api-endpoints.d.ts +150 -0
  10. package/dist/types/artifacts.d.ts +97 -0
  11. package/dist/types/azure.d.ts +22 -0
  12. package/dist/types/bedrock.d.ts +1220 -0
  13. package/dist/types/config.d.ts +14849 -0
  14. package/dist/types/config.spec.d.ts +1 -0
  15. package/dist/types/createPayload.d.ts +5 -0
  16. package/dist/types/data-service.d.ts +287 -0
  17. package/dist/types/feedback.d.ts +36 -0
  18. package/dist/types/file-config.d.ts +263 -0
  19. package/dist/types/file-config.spec.d.ts +1 -0
  20. package/dist/types/generate.d.ts +597 -0
  21. package/dist/types/headers-helpers.d.ts +2 -0
  22. package/{src/index.ts → dist/types/index.d.ts} +0 -15
  23. package/dist/types/keys.d.ts +92 -0
  24. package/dist/types/mcp.d.ts +2760 -0
  25. package/dist/types/messages.d.ts +10 -0
  26. package/dist/types/models.d.ts +1547 -0
  27. package/dist/types/parameterSettings.d.ts +69 -0
  28. package/dist/types/parsers.d.ts +110 -0
  29. package/dist/types/permissions.d.ts +522 -0
  30. package/dist/types/react-query/react-query-service.d.ts +85 -0
  31. package/dist/types/request.d.ts +25 -0
  32. package/dist/types/roles.d.ts +554 -0
  33. package/dist/types/roles.spec.d.ts +1 -0
  34. package/dist/types/schemas.d.ts +5110 -0
  35. package/dist/types/schemas.spec.d.ts +1 -0
  36. package/dist/types/types/agents.d.ts +433 -0
  37. package/dist/types/types/assistants.d.ts +547 -0
  38. package/dist/types/types/files.d.ts +172 -0
  39. package/dist/types/types/graph.d.ts +135 -0
  40. package/{src/types/mcpServers.ts → dist/types/types/mcpServers.d.ts} +12 -18
  41. package/dist/types/types/mutations.d.ts +209 -0
  42. package/dist/types/types/queries.d.ts +169 -0
  43. package/dist/types/types/runs.d.ts +36 -0
  44. package/dist/types/types/web.d.ts +520 -0
  45. package/dist/types/types.d.ts +503 -0
  46. package/dist/types/utils.d.ts +12 -0
  47. package/package.json +5 -1
  48. package/babel.config.js +0 -4
  49. package/check_updates.sh +0 -52
  50. package/jest.config.js +0 -19
  51. package/react-query/package-lock.json +0 -292
  52. package/react-query/package.json +0 -10
  53. package/rollup.config.js +0 -74
  54. package/server-rollup.config.js +0 -40
  55. package/specs/actions.spec.ts +0 -2533
  56. package/specs/api-endpoints-subdir.spec.ts +0 -140
  57. package/specs/api-endpoints.spec.ts +0 -74
  58. package/specs/azure.spec.ts +0 -844
  59. package/specs/bedrock.spec.ts +0 -862
  60. package/specs/filetypes.spec.ts +0 -175
  61. package/specs/generate.spec.ts +0 -770
  62. package/specs/headers-helpers.spec.ts +0 -24
  63. package/specs/mcp.spec.ts +0 -147
  64. package/specs/openapiSpecs.ts +0 -524
  65. package/specs/parsers.spec.ts +0 -601
  66. package/specs/request-interceptor.spec.ts +0 -304
  67. package/specs/utils.spec.ts +0 -196
  68. package/src/accessPermissions.ts +0 -346
  69. package/src/actions.ts +0 -813
  70. package/src/api-endpoints.ts +0 -440
  71. package/src/artifacts.ts +0 -3104
  72. package/src/azure.ts +0 -328
  73. package/src/bedrock.ts +0 -425
  74. package/src/config.spec.ts +0 -315
  75. package/src/config.ts +0 -2006
  76. package/src/createPayload.ts +0 -46
  77. package/src/data-service.ts +0 -1087
  78. package/src/feedback.ts +0 -141
  79. package/src/file-config.spec.ts +0 -1248
  80. package/src/file-config.ts +0 -764
  81. package/src/generate.ts +0 -634
  82. package/src/headers-helpers.ts +0 -13
  83. package/src/keys.ts +0 -99
  84. package/src/mcp.ts +0 -271
  85. package/src/messages.ts +0 -50
  86. package/src/models.ts +0 -69
  87. package/src/parameterSettings.ts +0 -1111
  88. package/src/parsers.ts +0 -563
  89. package/src/permissions.ts +0 -188
  90. package/src/react-query/react-query-service.ts +0 -566
  91. package/src/request.ts +0 -171
  92. package/src/roles.spec.ts +0 -132
  93. package/src/roles.ts +0 -225
  94. package/src/schemas.spec.ts +0 -355
  95. package/src/schemas.ts +0 -1234
  96. package/src/types/agents.ts +0 -470
  97. package/src/types/assistants.ts +0 -654
  98. package/src/types/files.ts +0 -191
  99. package/src/types/graph.ts +0 -145
  100. package/src/types/mutations.ts +0 -422
  101. package/src/types/queries.ts +0 -208
  102. package/src/types/runs.ts +0 -40
  103. package/src/types/web.ts +0 -588
  104. package/src/types.ts +0 -676
  105. package/src/utils.ts +0 -85
  106. package/tsconfig.json +0 -28
  107. package/tsconfig.spec.json +0 -10
  108. /package/{src/react-query/index.ts → dist/types/react-query/index.d.ts} +0 -0
  109. /package/{src/types/index.ts → dist/types/types/index.d.ts} +0 -0
@@ -1,1087 +0,0 @@
1
- import type { AxiosResponse } from 'axios';
2
- import type * as t from './types';
3
- import * as endpoints from './api-endpoints';
4
- import * as a from './types/assistants';
5
- import * as ag from './types/agents';
6
- import * as m from './types/mutations';
7
- import * as q from './types/queries';
8
- import * as f from './types/files';
9
- import * as mcp from './types/mcpServers';
10
- import * as config from './config';
11
- import request from './request';
12
- import * as s from './schemas';
13
- import * as r from './roles';
14
- import * as permissions from './accessPermissions';
15
-
16
- export function revokeUserKey(name: string): Promise<unknown> {
17
- return request.delete(endpoints.revokeUserKey(name));
18
- }
19
-
20
- export function revokeAllUserKeys(): Promise<unknown> {
21
- return request.delete(endpoints.revokeAllUserKeys());
22
- }
23
-
24
- export function deleteUser(payload?: t.TDeleteUserRequest): Promise<unknown> {
25
- return request.deleteWithOptions(endpoints.deleteUser(), { data: payload });
26
- }
27
-
28
- export type FavoriteItem = {
29
- agentId?: string;
30
- model?: string;
31
- endpoint?: string;
32
- };
33
-
34
- export function getFavorites(): Promise<FavoriteItem[]> {
35
- return request.get(`${endpoints.apiBaseUrl()}/api/user/settings/favorites`);
36
- }
37
-
38
- export function updateFavorites(favorites: FavoriteItem[]): Promise<FavoriteItem[]> {
39
- return request.post(`${endpoints.apiBaseUrl()}/api/user/settings/favorites`, { favorites });
40
- }
41
-
42
- export function getSharedMessages(shareId: string): Promise<t.TSharedMessagesResponse> {
43
- return request.get(endpoints.shareMessages(shareId));
44
- }
45
-
46
- export const listSharedLinks = async (
47
- params: q.SharedLinksListParams,
48
- ): Promise<q.SharedLinksResponse> => {
49
- const { pageSize, isPublic, sortBy, sortDirection, search, cursor } = params;
50
-
51
- return request.get(
52
- endpoints.getSharedLinks(pageSize, isPublic, sortBy, sortDirection, search, cursor),
53
- );
54
- };
55
-
56
- export function getSharedLink(conversationId: string): Promise<t.TSharedLinkGetResponse> {
57
- return request.get(endpoints.getSharedLink(conversationId));
58
- }
59
-
60
- export function createSharedLink(
61
- conversationId: string,
62
- targetMessageId?: string,
63
- ): Promise<t.TSharedLinkResponse> {
64
- return request.post(endpoints.createSharedLink(conversationId), { targetMessageId });
65
- }
66
-
67
- export function updateSharedLink(shareId: string): Promise<t.TSharedLinkResponse> {
68
- return request.patch(endpoints.updateSharedLink(shareId));
69
- }
70
-
71
- export function deleteSharedLink(shareId: string): Promise<m.TDeleteSharedLinkResponse> {
72
- return request.delete(endpoints.shareMessages(shareId));
73
- }
74
-
75
- export function updateUserKey(payload: t.TUpdateUserKeyRequest) {
76
- const { value } = payload;
77
- if (!value) {
78
- throw new Error('value is required');
79
- }
80
-
81
- return request.put(endpoints.keys(), payload);
82
- }
83
-
84
- export function getAgentApiKeys(): Promise<t.TAgentApiKeyListResponse> {
85
- return request.get(endpoints.apiKeys());
86
- }
87
-
88
- export function createAgentApiKey(
89
- payload: t.TAgentApiKeyCreateRequest,
90
- ): Promise<t.TAgentApiKeyCreateResponse> {
91
- return request.post(endpoints.apiKeys(), payload);
92
- }
93
-
94
- export function deleteAgentApiKey(id: string): Promise<void> {
95
- return request.delete(endpoints.apiKeyById(id));
96
- }
97
-
98
- export function getPresets(): Promise<s.TPreset[]> {
99
- return request.get(endpoints.presets());
100
- }
101
-
102
- export function createPreset(payload: s.TPreset): Promise<s.TPreset> {
103
- return request.post(endpoints.presets(), payload);
104
- }
105
-
106
- export function updatePreset(payload: s.TPreset): Promise<s.TPreset> {
107
- return request.post(endpoints.presets(), payload);
108
- }
109
-
110
- export function deletePreset(arg: s.TPreset | undefined): Promise<m.PresetDeleteResponse> {
111
- return request.post(endpoints.deletePreset(), arg);
112
- }
113
-
114
- export function getSearchEnabled(): Promise<boolean> {
115
- return request.get(endpoints.searchEnabled());
116
- }
117
-
118
- export function getUser(): Promise<t.TUser> {
119
- return request.get(endpoints.user());
120
- }
121
-
122
- export function getUserBalance(): Promise<t.TBalanceResponse> {
123
- return request.get(endpoints.balance());
124
- }
125
-
126
- export const updateTokenCount = (text: string) => {
127
- return request.post(endpoints.tokenizer(), { arg: text });
128
- };
129
-
130
- export const login = (payload: t.TLoginUser): Promise<t.TLoginResponse> => {
131
- return request.post(endpoints.login(), payload);
132
- };
133
-
134
- export const logout = (): Promise<m.TLogoutResponse> => {
135
- return request.post(endpoints.logout());
136
- };
137
-
138
- export const register = (payload: t.TRegisterUser) => {
139
- return request.post(endpoints.register(), payload);
140
- };
141
-
142
- export const userKeyQuery = (name: string): Promise<t.TCheckUserKeyResponse> =>
143
- request.get(endpoints.userKeyQuery(name));
144
-
145
- export const getLoginGoogle = () => {
146
- return request.get(endpoints.loginGoogle());
147
- };
148
-
149
- export const requestPasswordReset = (
150
- payload: t.TRequestPasswordReset,
151
- ): Promise<t.TRequestPasswordResetResponse> => {
152
- return request.post(endpoints.requestPasswordReset(), payload);
153
- };
154
-
155
- export const resetPassword = (payload: t.TResetPassword) => {
156
- return request.post(endpoints.resetPassword(), payload);
157
- };
158
-
159
- export const verifyEmail = (payload: t.TVerifyEmail): Promise<t.VerifyEmailResponse> => {
160
- return request.post(endpoints.verifyEmail(), payload);
161
- };
162
-
163
- export const resendVerificationEmail = (
164
- payload: t.TResendVerificationEmail,
165
- ): Promise<t.VerifyEmailResponse> => {
166
- return request.post(endpoints.resendVerificationEmail(), payload);
167
- };
168
-
169
- export const getAvailablePlugins = (): Promise<s.TPlugin[]> => {
170
- return request.get(endpoints.plugins());
171
- };
172
-
173
- export const updateUserPlugins = (payload: t.TUpdateUserPlugins) => {
174
- return request.post(endpoints.userPlugins(), payload);
175
- };
176
-
177
- export const reinitializeMCPServer = (serverName: string) => {
178
- return request.post(endpoints.mcpReinitialize(serverName));
179
- };
180
-
181
- export const bindMCPOAuth = (serverName: string): Promise<{ success: boolean }> => {
182
- return request.post(endpoints.mcpOAuthBind(serverName));
183
- };
184
-
185
- export const bindActionOAuth = (actionId: string): Promise<{ success: boolean }> => {
186
- return request.post(endpoints.actionOAuthBind(actionId));
187
- };
188
-
189
- export const getMCPConnectionStatus = (): Promise<q.MCPConnectionStatusResponse> => {
190
- return request.get(endpoints.mcpConnectionStatus());
191
- };
192
-
193
- export const getMCPServerConnectionStatus = (
194
- serverName: string,
195
- ): Promise<q.MCPServerConnectionStatusResponse> => {
196
- return request.get(endpoints.mcpServerConnectionStatus(serverName));
197
- };
198
-
199
- export const getMCPAuthValues = (serverName: string): Promise<q.MCPAuthValuesResponse> => {
200
- return request.get(endpoints.mcpAuthValues(serverName));
201
- };
202
-
203
- export function cancelMCPOAuth(serverName: string): Promise<m.CancelMCPOAuthResponse> {
204
- return request.post(endpoints.cancelMCPOAuth(serverName), {});
205
- }
206
-
207
- /* Config */
208
-
209
- export const getStartupConfig = (): Promise<
210
- config.TStartupConfig & {
211
- mcpCustomUserVars?: Record<string, { title: string; description: string }>;
212
- }
213
- > => {
214
- return request.get(endpoints.config());
215
- };
216
-
217
- export const getAIEndpoints = (): Promise<t.TEndpointsConfig> => {
218
- return request.get(endpoints.aiEndpoints());
219
- };
220
-
221
- export const getModels = async (): Promise<t.TModelsConfig> => {
222
- return request.get(endpoints.models());
223
- };
224
-
225
- /* Assistants */
226
-
227
- export const createAssistant = ({
228
- version,
229
- ...data
230
- }: a.AssistantCreateParams): Promise<a.Assistant> => {
231
- return request.post(endpoints.assistants({ version }), data);
232
- };
233
-
234
- export const getAssistantById = ({
235
- endpoint,
236
- assistant_id,
237
- version,
238
- }: {
239
- endpoint: s.AssistantsEndpoint;
240
- assistant_id: string;
241
- version: number | string | number;
242
- }): Promise<a.Assistant> => {
243
- return request.get(
244
- endpoints.assistants({
245
- path: assistant_id,
246
- endpoint,
247
- version,
248
- }),
249
- );
250
- };
251
-
252
- export const updateAssistant = ({
253
- assistant_id,
254
- data,
255
- version,
256
- }: {
257
- assistant_id: string;
258
- data: a.AssistantUpdateParams;
259
- version: number | string;
260
- }): Promise<a.Assistant> => {
261
- return request.patch(
262
- endpoints.assistants({
263
- path: assistant_id,
264
- version,
265
- }),
266
- data,
267
- );
268
- };
269
-
270
- export const deleteAssistant = ({
271
- assistant_id,
272
- model,
273
- endpoint,
274
- version,
275
- }: m.DeleteAssistantBody & { version: number | string }): Promise<void> => {
276
- return request.delete(
277
- endpoints.assistants({
278
- path: assistant_id,
279
- options: { model, endpoint },
280
- version,
281
- }),
282
- );
283
- };
284
-
285
- export const listAssistants = (
286
- params: a.AssistantListParams,
287
- version: number | string,
288
- ): Promise<a.AssistantListResponse> => {
289
- return request.get(
290
- endpoints.assistants({
291
- version,
292
- options: params,
293
- }),
294
- );
295
- };
296
-
297
- export function getAssistantDocs({
298
- endpoint,
299
- version,
300
- }: {
301
- endpoint: s.AssistantsEndpoint | string;
302
- version: number | string;
303
- }): Promise<a.AssistantDocument[]> {
304
- if (!s.isAssistantsEndpoint(endpoint)) {
305
- return Promise.resolve([]);
306
- }
307
- return request.get(
308
- endpoints.assistants({
309
- path: 'documents',
310
- version,
311
- options: { endpoint },
312
- endpoint: endpoint as s.AssistantsEndpoint,
313
- }),
314
- );
315
- }
316
-
317
- /* Tools */
318
-
319
- export const getAvailableTools = (
320
- _endpoint: s.AssistantsEndpoint | s.EModelEndpoint.agents,
321
- version?: number | string,
322
- ): Promise<s.TPlugin[]> => {
323
- let path = '';
324
- if (s.isAssistantsEndpoint(_endpoint)) {
325
- const endpoint = _endpoint as s.AssistantsEndpoint;
326
- path = endpoints.assistants({
327
- path: 'tools',
328
- endpoint: endpoint,
329
- version: version ?? config.defaultAssistantsVersion[endpoint],
330
- });
331
- } else {
332
- path = endpoints.agents({
333
- path: 'tools',
334
- });
335
- }
336
-
337
- return request.get(path);
338
- };
339
-
340
- /* MCP Tools - Decoupled from regular tools */
341
-
342
- export const getMCPTools = (): Promise<q.MCPServersResponse> => {
343
- return request.get(endpoints.mcp.tools);
344
- };
345
-
346
- export const getVerifyAgentToolAuth = (
347
- params: q.VerifyToolAuthParams,
348
- ): Promise<q.VerifyToolAuthResponse> => {
349
- return request.get(
350
- endpoints.agents({
351
- path: `tools/${params.toolId}/auth`,
352
- }),
353
- );
354
- };
355
-
356
- export const callTool = <T extends m.ToolId>({
357
- toolId,
358
- toolParams,
359
- }: {
360
- toolId: T;
361
- toolParams: m.ToolParams<T>;
362
- }): Promise<m.ToolCallResponse> => {
363
- return request.post(
364
- endpoints.agents({
365
- path: `tools/${toolId}/call`,
366
- }),
367
- toolParams,
368
- );
369
- };
370
-
371
- export const getToolCalls = (params: q.GetToolCallParams): Promise<q.ToolCallResults> => {
372
- return request.get(
373
- endpoints.agents({
374
- path: 'tools/calls',
375
- options: params,
376
- }),
377
- );
378
- };
379
-
380
- /* Files */
381
-
382
- export const getFiles = (): Promise<f.TFile[]> => {
383
- return request.get(endpoints.files());
384
- };
385
-
386
- export const getAgentFiles = (agentId: string): Promise<f.TFile[]> => {
387
- return request.get(endpoints.agentFiles(agentId));
388
- };
389
-
390
- export const getFileConfig = (): Promise<f.FileConfig> => {
391
- return request.get(`${endpoints.files()}/config`);
392
- };
393
-
394
- export const uploadImage = (
395
- data: FormData,
396
- signal?: AbortSignal | null,
397
- ): Promise<f.TFileUpload> => {
398
- const requestConfig = signal ? { signal } : undefined;
399
- return request.postMultiPart(endpoints.images(), data, requestConfig);
400
- };
401
-
402
- export const uploadFile = (data: FormData, signal?: AbortSignal | null): Promise<f.TFileUpload> => {
403
- const requestConfig = signal ? { signal } : undefined;
404
- return request.postMultiPart(endpoints.files(), data, requestConfig);
405
- };
406
-
407
- /* actions */
408
-
409
- export const updateAction = (data: m.UpdateActionVariables): Promise<m.UpdateActionResponse> => {
410
- const { assistant_id, version, ...body } = data;
411
- return request.post(
412
- endpoints.assistants({
413
- path: `actions/${assistant_id}`,
414
- version,
415
- }),
416
- body,
417
- );
418
- };
419
-
420
- export function getActions(): Promise<ag.Action[]> {
421
- return request.get(
422
- endpoints.agents({
423
- path: 'actions',
424
- }),
425
- );
426
- }
427
-
428
- export const deleteAction = async ({
429
- assistant_id,
430
- action_id,
431
- model,
432
- version,
433
- endpoint,
434
- }: m.DeleteActionVariables & { version: number | string }): Promise<void> =>
435
- request.delete(
436
- endpoints.assistants({
437
- path: `actions/${assistant_id}/${action_id}/${model}`,
438
- version,
439
- endpoint,
440
- }),
441
- );
442
-
443
- /**
444
- * Agents
445
- */
446
-
447
- export const createAgent = ({ ...data }: a.AgentCreateParams): Promise<a.Agent> => {
448
- return request.post(endpoints.agents({}), data);
449
- };
450
-
451
- export const getAgentById = ({ agent_id }: { agent_id: string }): Promise<a.Agent> => {
452
- return request.get(
453
- endpoints.agents({
454
- path: agent_id,
455
- }),
456
- );
457
- };
458
-
459
- export const getExpandedAgentById = ({ agent_id }: { agent_id: string }): Promise<a.Agent> => {
460
- return request.get(
461
- endpoints.agents({
462
- path: `${agent_id}/expanded`,
463
- }),
464
- );
465
- };
466
-
467
- export const updateAgent = ({
468
- agent_id,
469
- data,
470
- }: {
471
- agent_id: string;
472
- data: a.AgentUpdateParams;
473
- }): Promise<a.Agent> => {
474
- return request.patch(
475
- endpoints.agents({
476
- path: agent_id,
477
- }),
478
- data,
479
- );
480
- };
481
-
482
- export const duplicateAgent = ({
483
- agent_id,
484
- }: m.DuplicateAgentBody): Promise<{ agent: a.Agent; actions: ag.Action[] }> => {
485
- return request.post(
486
- endpoints.agents({
487
- path: `${agent_id}/duplicate`,
488
- }),
489
- );
490
- };
491
-
492
- export const deleteAgent = ({ agent_id }: m.DeleteAgentBody): Promise<void> => {
493
- return request.delete(
494
- endpoints.agents({
495
- path: agent_id,
496
- }),
497
- );
498
- };
499
-
500
- export const listAgents = (params: a.AgentListParams): Promise<a.AgentListResponse> => {
501
- return request.get(
502
- endpoints.agents({
503
- options: params,
504
- }),
505
- );
506
- };
507
-
508
- export const revertAgentVersion = ({
509
- agent_id,
510
- version_index,
511
- }: {
512
- agent_id: string;
513
- version_index: number;
514
- }): Promise<a.Agent> => request.post(endpoints.revertAgentVersion(agent_id), { version_index });
515
-
516
- /* Marketplace */
517
-
518
- /**
519
- * Get agent categories with counts for marketplace tabs
520
- */
521
- export const getAgentCategories = (): Promise<t.TMarketplaceCategory[]> => {
522
- return request.get(endpoints.agents({ path: 'categories' }));
523
- };
524
-
525
- /**
526
- * Unified marketplace agents endpoint with query string controls
527
- */
528
- export const getMarketplaceAgents = (params: {
529
- requiredPermission: number;
530
- category?: string;
531
- search?: string;
532
- limit?: number;
533
- cursor?: string;
534
- promoted?: 0 | 1;
535
- }): Promise<a.AgentListResponse> => {
536
- return request.get(
537
- endpoints.agents({
538
- // path: 'marketplace',
539
- options: params,
540
- }),
541
- );
542
- };
543
-
544
- /* Tools */
545
-
546
- export const getAvailableAgentTools = (): Promise<s.TPlugin[]> => {
547
- return request.get(
548
- endpoints.agents({
549
- path: 'tools',
550
- }),
551
- );
552
- };
553
-
554
- /* Actions */
555
-
556
- export const updateAgentAction = (
557
- data: m.UpdateAgentActionVariables,
558
- ): Promise<m.UpdateAgentActionResponse> => {
559
- const { agent_id, ...body } = data;
560
- return request.post(
561
- endpoints.agents({
562
- path: `actions/${agent_id}`,
563
- }),
564
- body,
565
- );
566
- };
567
-
568
- export const deleteAgentAction = async ({
569
- agent_id,
570
- action_id,
571
- }: m.DeleteAgentActionVariables): Promise<void> =>
572
- request.delete(
573
- endpoints.agents({
574
- path: `actions/${agent_id}/${action_id}`,
575
- }),
576
- );
577
-
578
- /**
579
- * MCP Servers
580
- */
581
-
582
- /**
583
- *
584
- * Ensure and List loaded mcp server configs from the cache Enriched with effective permissions.
585
- */
586
- export const getMCPServers = async (): Promise<mcp.MCPServersListResponse> => {
587
- return request.get(endpoints.mcp.servers);
588
- };
589
-
590
- /**
591
- * Get a single MCP server by ID
592
- */
593
- export const getMCPServer = async (serverName: string): Promise<mcp.MCPServerDBObjectResponse> => {
594
- return request.get(endpoints.mcpServer(serverName));
595
- };
596
-
597
- /**
598
- * Create a new MCP server
599
- */
600
- export const createMCPServer = async (
601
- data: mcp.MCPServerCreateParams,
602
- ): Promise<mcp.MCPServerDBObjectResponse> => {
603
- return request.post(endpoints.mcp.servers, data);
604
- };
605
-
606
- /**
607
- * Update an existing MCP server
608
- */
609
- export const updateMCPServer = async (
610
- serverName: string,
611
- data: mcp.MCPServerUpdateParams,
612
- ): Promise<mcp.MCPServerDBObjectResponse> => {
613
- return request.patch(endpoints.mcpServer(serverName), data);
614
- };
615
-
616
- /**
617
- * Delete an MCP server
618
- */
619
- export const deleteMCPServer = async (serverName: string): Promise<{ success: boolean }> => {
620
- return request.delete(endpoints.mcpServer(serverName));
621
- };
622
-
623
- /**
624
- * Imports a conversations file.
625
- *
626
- * @param data - The FormData containing the file to import.
627
- * @returns A Promise that resolves to the import start response.
628
- */
629
- export const importConversationsFile = (data: FormData): Promise<t.TImportResponse> => {
630
- return request.postMultiPart(endpoints.importConversation(), data);
631
- };
632
-
633
- export const uploadAvatar = (data: FormData): Promise<f.AvatarUploadResponse> => {
634
- return request.postMultiPart(endpoints.avatar(), data);
635
- };
636
-
637
- export const uploadAssistantAvatar = (data: m.AssistantAvatarVariables): Promise<a.Assistant> => {
638
- return request.postMultiPart(
639
- endpoints.assistants({
640
- isAvatar: true,
641
- path: `${data.assistant_id}/avatar`,
642
- options: { model: data.model, endpoint: data.endpoint },
643
- version: data.version,
644
- }),
645
- data.formData,
646
- );
647
- };
648
-
649
- export const uploadAgentAvatar = (data: m.AgentAvatarVariables): Promise<a.Agent> => {
650
- return request.postMultiPart(
651
- `${endpoints.images()}/agents/${data.agent_id}/avatar`,
652
- data.formData,
653
- );
654
- };
655
-
656
- export const getFileDownload = async (userId: string, file_id: string): Promise<AxiosResponse> => {
657
- return request.getResponse(`${endpoints.files()}/download/${userId}/${file_id}`, {
658
- responseType: 'blob',
659
- headers: {
660
- Accept: 'application/octet-stream',
661
- },
662
- });
663
- };
664
-
665
- export const getCodeOutputDownload = async (url: string): Promise<AxiosResponse> => {
666
- return request.getResponse(url, {
667
- responseType: 'blob',
668
- headers: {
669
- Accept: 'application/octet-stream',
670
- },
671
- });
672
- };
673
-
674
- export const deleteFiles = async (payload: {
675
- files: f.BatchFile[];
676
- agent_id?: string;
677
- assistant_id?: string;
678
- tool_resource?: a.EToolResources;
679
- }): Promise<f.DeleteFilesResponse> =>
680
- request.deleteWithOptions(endpoints.files(), {
681
- data: payload,
682
- });
683
-
684
- /* Speech */
685
-
686
- export const speechToText = (data: FormData): Promise<f.SpeechToTextResponse> => {
687
- return request.postMultiPart(endpoints.speechToText(), data);
688
- };
689
-
690
- export const textToSpeech = (data: FormData): Promise<ArrayBuffer> => {
691
- return request.postTTS(endpoints.textToSpeechManual(), data);
692
- };
693
-
694
- export const getVoices = (): Promise<f.VoiceResponse> => {
695
- return request.get(endpoints.textToSpeechVoices());
696
- };
697
-
698
- export const getCustomConfigSpeech = (): Promise<t.TCustomConfigSpeechResponse> => {
699
- return request.get(endpoints.getCustomConfigSpeech());
700
- };
701
-
702
- /* conversations */
703
-
704
- export function duplicateConversation(
705
- payload: t.TDuplicateConvoRequest,
706
- ): Promise<t.TDuplicateConvoResponse> {
707
- return request.post(endpoints.duplicateConversation(), payload);
708
- }
709
-
710
- export function forkConversation(payload: t.TForkConvoRequest): Promise<t.TForkConvoResponse> {
711
- return request.post(endpoints.forkConversation(), payload);
712
- }
713
-
714
- export function deleteConversation(payload: t.TDeleteConversationRequest) {
715
- return request.deleteWithOptions(endpoints.deleteConversation(), { data: { arg: payload } });
716
- }
717
-
718
- export function clearAllConversations(): Promise<unknown> {
719
- return request.delete(endpoints.deleteAllConversation());
720
- }
721
-
722
- export const listConversations = (
723
- params?: q.ConversationListParams,
724
- ): Promise<q.ConversationListResponse> => {
725
- return request.get(endpoints.conversations(params ?? {}));
726
- };
727
-
728
- export function getConversations(cursor: string): Promise<t.TGetConversationsResponse> {
729
- return request.get(endpoints.conversations({ cursor }));
730
- }
731
-
732
- export function getConversationById(id: string): Promise<s.TConversation> {
733
- return request.get(endpoints.conversationById(id));
734
- }
735
-
736
- export function updateConversation(
737
- payload: t.TUpdateConversationRequest,
738
- ): Promise<t.TUpdateConversationResponse> {
739
- return request.post(endpoints.updateConversation(), { arg: payload });
740
- }
741
-
742
- export function archiveConversation(
743
- payload: t.TArchiveConversationRequest,
744
- ): Promise<t.TArchiveConversationResponse> {
745
- return request.post(endpoints.archiveConversation(), { arg: payload });
746
- }
747
-
748
- export function genTitle(payload: m.TGenTitleRequest): Promise<m.TGenTitleResponse> {
749
- return request.get(endpoints.genTitle(payload.conversationId));
750
- }
751
-
752
- export const listMessages = (params?: q.MessagesListParams): Promise<q.MessagesListResponse> => {
753
- return request.get(endpoints.messages(params ?? {}));
754
- };
755
-
756
- export function updateMessage(payload: t.TUpdateMessageRequest): Promise<unknown> {
757
- const { conversationId, messageId, text } = payload;
758
- if (!conversationId) {
759
- throw new Error('conversationId is required');
760
- }
761
-
762
- return request.put(endpoints.messages({ conversationId, messageId }), { text });
763
- }
764
-
765
- export function updateMessageContent(payload: t.TUpdateMessageContent): Promise<unknown> {
766
- const { conversationId, messageId, index, text } = payload;
767
- if (!conversationId) {
768
- throw new Error('conversationId is required');
769
- }
770
-
771
- return request.put(endpoints.messages({ conversationId, messageId }), { text, index });
772
- }
773
-
774
- export const editArtifact = async ({
775
- messageId,
776
- ...params
777
- }: m.TEditArtifactRequest): Promise<m.TEditArtifactResponse> => {
778
- return request.post(endpoints.messagesArtifacts(messageId), params);
779
- };
780
-
781
- export const branchMessage = async (
782
- payload: m.TBranchMessageRequest,
783
- ): Promise<m.TBranchMessageResponse> => {
784
- return request.post(endpoints.messagesBranch(), payload);
785
- };
786
-
787
- export function getMessagesByConvoId(conversationId: string): Promise<s.TMessage[]> {
788
- if (
789
- conversationId === config.Constants.NEW_CONVO ||
790
- conversationId === config.Constants.PENDING_CONVO
791
- ) {
792
- return Promise.resolve([]);
793
- }
794
- return request.get(endpoints.messages({ conversationId }));
795
- }
796
-
797
- export function getPrompt(id: string): Promise<{ prompt: t.TPrompt }> {
798
- return request.get(endpoints.getPrompt(id));
799
- }
800
-
801
- export function getPrompts(filter: t.TPromptsWithFilterRequest): Promise<t.TPrompt[]> {
802
- return request.get(endpoints.getPromptsWithFilters(filter));
803
- }
804
-
805
- export function getAllPromptGroups(): Promise<q.AllPromptGroupsResponse> {
806
- return request.get(endpoints.getAllPromptGroups());
807
- }
808
-
809
- export function getPromptGroups(
810
- filter: t.TPromptGroupsWithFilterRequest,
811
- ): Promise<t.PromptGroupListResponse> {
812
- return request.get(endpoints.getPromptGroupsWithFilters(filter));
813
- }
814
-
815
- export function getPromptGroup(id: string): Promise<t.TPromptGroup> {
816
- return request.get(endpoints.getPromptGroup(id));
817
- }
818
-
819
- export function createPrompt(payload: t.TCreatePrompt): Promise<t.TCreatePromptResponse> {
820
- return request.post(endpoints.postPrompt(), payload);
821
- }
822
-
823
- export function addPromptToGroup(
824
- groupId: string,
825
- payload: t.TCreatePrompt,
826
- ): Promise<t.TCreatePromptResponse> {
827
- return request.post(endpoints.addPromptToGroup(groupId), payload);
828
- }
829
-
830
- export function updatePromptGroup(
831
- variables: t.TUpdatePromptGroupVariables,
832
- ): Promise<t.TUpdatePromptGroupResponse> {
833
- return request.patch(endpoints.updatePromptGroup(variables.id), variables.payload);
834
- }
835
-
836
- export function deletePrompt(payload: t.TDeletePromptVariables): Promise<t.TDeletePromptResponse> {
837
- return request.delete(endpoints.deletePrompt(payload));
838
- }
839
-
840
- export function makePromptProduction(id: string): Promise<t.TMakePromptProductionResponse> {
841
- return request.patch(endpoints.updatePromptTag(id));
842
- }
843
-
844
- export function updatePromptLabels(
845
- variables: t.TUpdatePromptLabelsRequest,
846
- ): Promise<t.TUpdatePromptLabelsResponse> {
847
- return request.patch(endpoints.updatePromptLabels(variables.id), variables.payload);
848
- }
849
-
850
- export function deletePromptGroup(id: string): Promise<t.TDeletePromptGroupResponse> {
851
- return request.delete(endpoints.deletePromptGroup(id));
852
- }
853
-
854
- export function getCategories(): Promise<t.TGetCategoriesResponse> {
855
- return request.get(endpoints.getCategories());
856
- }
857
-
858
- export function getRandomPrompts(
859
- variables: t.TGetRandomPromptsRequest,
860
- ): Promise<t.TGetRandomPromptsResponse> {
861
- return request.get(endpoints.getRandomPrompts(variables.limit, variables.skip));
862
- }
863
-
864
- /* Roles */
865
- export function getRole(roleName: string): Promise<r.TRole> {
866
- return request.get(endpoints.getRole(roleName));
867
- }
868
-
869
- export function updatePromptPermissions(
870
- variables: m.UpdatePromptPermVars,
871
- ): Promise<m.UpdatePermResponse> {
872
- return request.put(endpoints.updatePromptPermissions(variables.roleName), variables.updates);
873
- }
874
-
875
- export function updateAgentPermissions(
876
- variables: m.UpdateAgentPermVars,
877
- ): Promise<m.UpdatePermResponse> {
878
- return request.put(endpoints.updateAgentPermissions(variables.roleName), variables.updates);
879
- }
880
-
881
- export function updateMemoryPermissions(
882
- variables: m.UpdateMemoryPermVars,
883
- ): Promise<m.UpdatePermResponse> {
884
- return request.put(endpoints.updateMemoryPermissions(variables.roleName), variables.updates);
885
- }
886
-
887
- export function updatePeoplePickerPermissions(
888
- variables: m.UpdatePeoplePickerPermVars,
889
- ): Promise<m.UpdatePermResponse> {
890
- return request.put(
891
- endpoints.updatePeoplePickerPermissions(variables.roleName),
892
- variables.updates,
893
- );
894
- }
895
-
896
- export function updateMCPServersPermissions(
897
- variables: m.UpdateMCPServersPermVars,
898
- ): Promise<m.UpdatePermResponse> {
899
- return request.put(endpoints.updateMCPServersPermissions(variables.roleName), variables.updates);
900
- }
901
-
902
- export function updateRemoteAgentsPermissions(
903
- variables: m.UpdateRemoteAgentsPermVars,
904
- ): Promise<m.UpdatePermResponse> {
905
- return request.put(
906
- endpoints.updateRemoteAgentsPermissions(variables.roleName),
907
- variables.updates,
908
- );
909
- }
910
-
911
- export function updateMarketplacePermissions(
912
- variables: m.UpdateMarketplacePermVars,
913
- ): Promise<m.UpdatePermResponse> {
914
- return request.put(endpoints.updateMarketplacePermissions(variables.roleName), variables.updates);
915
- }
916
-
917
- /* Tags */
918
- export function getConversationTags(): Promise<t.TConversationTagsResponse> {
919
- return request.get(endpoints.conversationTags());
920
- }
921
-
922
- export function createConversationTag(
923
- payload: t.TConversationTagRequest,
924
- ): Promise<t.TConversationTagResponse> {
925
- return request.post(endpoints.conversationTags(), payload);
926
- }
927
-
928
- export function updateConversationTag(
929
- tag: string,
930
- payload: t.TConversationTagRequest,
931
- ): Promise<t.TConversationTagResponse> {
932
- return request.put(endpoints.conversationTags(tag), payload);
933
- }
934
- export function deleteConversationTag(tag: string): Promise<t.TConversationTagResponse> {
935
- return request.delete(endpoints.conversationTags(tag));
936
- }
937
-
938
- export function addTagToConversation(
939
- conversationId: string,
940
- payload: t.TTagConversationRequest,
941
- ): Promise<t.TTagConversationResponse> {
942
- return request.put(endpoints.addTagToConversation(conversationId), payload);
943
- }
944
- export function rebuildConversationTags(): Promise<t.TConversationTagsResponse> {
945
- return request.post(endpoints.conversationTags('rebuild'));
946
- }
947
-
948
- export function healthCheck(): Promise<string> {
949
- return request.get(endpoints.health());
950
- }
951
-
952
- export function getUserTerms(): Promise<t.TUserTermsResponse> {
953
- return request.get(endpoints.userTerms());
954
- }
955
-
956
- export function acceptTerms(): Promise<t.TAcceptTermsResponse> {
957
- return request.post(endpoints.acceptUserTerms());
958
- }
959
-
960
- export function getBanner(): Promise<t.TBannerResponse> {
961
- return request.get(endpoints.banner());
962
- }
963
-
964
- export function updateFeedback(
965
- conversationId: string,
966
- messageId: string,
967
- payload: t.TUpdateFeedbackRequest,
968
- ): Promise<t.TUpdateFeedbackResponse> {
969
- return request.put(endpoints.feedback(conversationId, messageId), payload);
970
- }
971
-
972
- // 2FA
973
- export function enableTwoFactor(payload?: t.TEnable2FARequest): Promise<t.TEnable2FAResponse> {
974
- return request.post(endpoints.enableTwoFactor(), payload);
975
- }
976
-
977
- export function verifyTwoFactor(payload: t.TVerify2FARequest): Promise<t.TVerify2FAResponse> {
978
- return request.post(endpoints.verifyTwoFactor(), payload);
979
- }
980
-
981
- export function confirmTwoFactor(payload: t.TVerify2FARequest): Promise<t.TVerify2FAResponse> {
982
- return request.post(endpoints.confirmTwoFactor(), payload);
983
- }
984
-
985
- export function disableTwoFactor(payload?: t.TDisable2FARequest): Promise<t.TDisable2FAResponse> {
986
- return request.post(endpoints.disableTwoFactor(), payload);
987
- }
988
-
989
- export function regenerateBackupCodes(
990
- payload?: t.TRegenerateBackupCodesRequest,
991
- ): Promise<t.TRegenerateBackupCodesResponse> {
992
- return request.post(endpoints.regenerateBackupCodes(), payload);
993
- }
994
-
995
- export function verifyTwoFactorTemp(
996
- payload: t.TVerify2FATempRequest,
997
- ): Promise<t.TVerify2FATempResponse> {
998
- return request.post(endpoints.verifyTwoFactorTemp(), payload);
999
- }
1000
-
1001
- /* Memories */
1002
- export const getMemories = (): Promise<q.MemoriesResponse> => {
1003
- return request.get(endpoints.memories());
1004
- };
1005
-
1006
- export const deleteMemory = (key: string): Promise<void> => {
1007
- return request.delete(endpoints.memory(key));
1008
- };
1009
-
1010
- export const updateMemory = (
1011
- key: string,
1012
- value: string,
1013
- originalKey?: string,
1014
- ): Promise<q.TUserMemory> => {
1015
- return request.patch(endpoints.memory(originalKey || key), { key, value });
1016
- };
1017
-
1018
- export const updateMemoryPreferences = (preferences: {
1019
- memories: boolean;
1020
- }): Promise<{ updated: boolean; preferences: { memories: boolean } }> => {
1021
- return request.patch(endpoints.memoryPreferences(), preferences);
1022
- };
1023
-
1024
- export const createMemory = (data: {
1025
- key: string;
1026
- value: string;
1027
- }): Promise<{ created: boolean; memory: q.TUserMemory }> => {
1028
- return request.post(endpoints.memories(), data);
1029
- };
1030
-
1031
- export function searchPrincipals(
1032
- params: q.PrincipalSearchParams,
1033
- ): Promise<q.PrincipalSearchResponse> {
1034
- return request.get(endpoints.searchPrincipals(params));
1035
- }
1036
-
1037
- export function getAccessRoles(
1038
- resourceType: permissions.ResourceType,
1039
- ): Promise<q.AccessRolesResponse> {
1040
- return request.get(endpoints.getAccessRoles(resourceType));
1041
- }
1042
-
1043
- export function getResourcePermissions(
1044
- resourceType: permissions.ResourceType,
1045
- resourceId: string,
1046
- ): Promise<permissions.TGetResourcePermissionsResponse> {
1047
- return request.get(endpoints.getResourcePermissions(resourceType, resourceId));
1048
- }
1049
-
1050
- export function updateResourcePermissions(
1051
- resourceType: permissions.ResourceType,
1052
- resourceId: string,
1053
- data: permissions.TUpdateResourcePermissionsRequest,
1054
- ): Promise<permissions.TUpdateResourcePermissionsResponse> {
1055
- return request.put(endpoints.updateResourcePermissions(resourceType, resourceId), data);
1056
- }
1057
-
1058
- export function getEffectivePermissions(
1059
- resourceType: permissions.ResourceType,
1060
- resourceId: string,
1061
- ): Promise<permissions.TEffectivePermissionsResponse> {
1062
- return request.get(endpoints.getEffectivePermissions(resourceType, resourceId));
1063
- }
1064
-
1065
- export function getAllEffectivePermissions(
1066
- resourceType: permissions.ResourceType,
1067
- ): Promise<permissions.TAllEffectivePermissionsResponse> {
1068
- return request.get(endpoints.getAllEffectivePermissions(resourceType));
1069
- }
1070
-
1071
- // SharePoint Graph API Token
1072
- export function getGraphApiToken(params: q.GraphTokenParams): Promise<q.GraphTokenResponse> {
1073
- return request.get(endpoints.graphToken(params.scopes));
1074
- }
1075
-
1076
- export function getDomainServerBaseUrl(): string {
1077
- return `${endpoints.apiBaseUrl()}/api`;
1078
- }
1079
-
1080
- /* Active Jobs */
1081
- export interface ActiveJobsResponse {
1082
- activeJobIds: string[];
1083
- }
1084
-
1085
- export const getActiveJobs = (): Promise<ActiveJobsResponse> => {
1086
- return request.get(endpoints.activeJobs());
1087
- };