universal-chat.ts 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. import type { IOnCompleted, IOnData, IOnError, IOnThought } from './base'
  2. import {
  3. del, get, patch, post, ssePost,
  4. } from './base'
  5. import type { Feedbacktype } from '@/app/components/app/chat/type'
  6. const baseUrl = 'universal-chat'
  7. function getUrl(url: string) {
  8. return `${baseUrl}/${url.startsWith('/') ? url.slice(1) : url}`
  9. }
  10. export const sendChatMessage = async (body: Record<string, any>, { onData, onCompleted, onError, onThought, getAbortController }: {
  11. onData: IOnData
  12. onCompleted: IOnCompleted
  13. onError: IOnError
  14. onThought: IOnThought
  15. getAbortController?: (abortController: AbortController) => void
  16. }) => {
  17. return ssePost(getUrl('messages'), {
  18. body: {
  19. ...body,
  20. response_mode: 'streaming',
  21. },
  22. }, { onData, onCompleted, onThought, onError, getAbortController })
  23. }
  24. export const stopChatMessageResponding = async (taskId: string) => {
  25. return post(getUrl(`messages/${taskId}/stop`))
  26. }
  27. export const fetchConversations = async (last_id?: string, pinned?: boolean, limit?: number) => {
  28. return get(getUrl('conversations'), { params: { ...{ limit: limit || 20 }, ...(last_id ? { last_id } : {}), ...(pinned !== undefined ? { pinned } : {}) } })
  29. }
  30. export const pinConversation = async (id: string) => {
  31. return patch(getUrl(`conversations/${id}/pin`))
  32. }
  33. export const unpinConversation = async (id: string) => {
  34. return patch(getUrl(`conversations/${id}/unpin`))
  35. }
  36. export const delConversation = async (id: string) => {
  37. return del(getUrl(`conversations/${id}`))
  38. }
  39. export const fetchChatList = async (conversationId: string) => {
  40. return get(getUrl('messages'), { params: { conversation_id: conversationId, limit: 20, last_id: '' } })
  41. }
  42. // init value. wait for server update
  43. export const fetchAppParams = async () => {
  44. return get(getUrl('parameters'))
  45. }
  46. export const updateFeedback = async ({ url, body }: { url: string; body: Feedbacktype }) => {
  47. return post(getUrl(url), { body })
  48. }
  49. export const fetchMoreLikeThis = async (messageId: string) => {
  50. return get(getUrl(`/messages/${messageId}/more-like-this`), {
  51. params: {
  52. response_mode: 'blocking',
  53. },
  54. })
  55. }
  56. export const fetchSuggestedQuestions = (messageId: string) => {
  57. return get(getUrl(`/messages/${messageId}/suggested-questions`))
  58. }
  59. export const audioToText = (url: string, body: FormData) => {
  60. return post(url, { body }, { bodyStringify: false, deleteContentType: true }) as Promise<{ text: string }>
  61. }