datasets.ts 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. import type { Fetcher } from 'swr'
  2. import qs from 'qs'
  3. import { del, get, patch, post, put } from './base'
  4. import type {
  5. CreateDocumentReq,
  6. DataSet,
  7. DataSetListResponse,
  8. DocumentDetailResponse,
  9. DocumentListResponse,
  10. FileIndexingEstimateResponse,
  11. HitTestingRecordsResponse,
  12. HitTestingResponse,
  13. IndexingEstimateParams,
  14. IndexingEstimateResponse,
  15. IndexingStatusBatchResponse,
  16. IndexingStatusResponse,
  17. ProcessRuleResponse,
  18. RelatedAppResponse,
  19. SegmentDetailModel,
  20. SegmentUpdator,
  21. SegmentsQuery,
  22. SegmentsResponse,
  23. createDocumentResponse,
  24. } from '@/models/datasets'
  25. import type { CommonResponse, DataSourceNotionWorkspace } from '@/models/common'
  26. import type {
  27. ApikeysListResponse,
  28. CreateApiKeyResponse,
  29. } from '@/models/app'
  30. import type { RetrievalConfig } from '@/types/app'
  31. // apis for documents in a dataset
  32. type CommonDocReq = {
  33. datasetId: string
  34. documentId: string
  35. }
  36. type BatchReq = {
  37. datasetId: string
  38. batchId: string
  39. }
  40. export type SortType = 'created_at' | 'hit_count' | '-created_at' | '-hit_count'
  41. export type MetadataType = 'all' | 'only' | 'without'
  42. export const fetchDatasetDetail: Fetcher<DataSet, string> = (datasetId: string) => {
  43. return get<DataSet>(`/datasets/${datasetId}`)
  44. }
  45. export const updateDatasetSetting: Fetcher<DataSet, { datasetId: string; body: Partial<Pick<DataSet, 'name' | 'description' | 'permission' | 'indexing_technique' | 'retrieval_model'>> }> = ({ datasetId, body }) => {
  46. return patch<DataSet>(`/datasets/${datasetId}`, { body })
  47. }
  48. export const fetchDatasetRelatedApps: Fetcher<RelatedAppResponse, string> = (datasetId: string) => {
  49. return get<RelatedAppResponse>(`/datasets/${datasetId}/related-apps`)
  50. }
  51. export const fetchDatasets: Fetcher<DataSetListResponse, { url: string; params: { page: number; ids?: string[]; limit?: number } }> = ({ url, params }) => {
  52. const urlParams = qs.stringify(params, { indices: false })
  53. return get<DataSetListResponse>(`${url}?${urlParams}`)
  54. }
  55. export const createEmptyDataset: Fetcher<DataSet, { name: string }> = ({ name }) => {
  56. return post<DataSet>('/datasets', { body: { name } })
  57. }
  58. export const deleteDataset: Fetcher<DataSet, string> = (datasetID) => {
  59. return del<DataSet>(`/datasets/${datasetID}`)
  60. }
  61. export const fetchDefaultProcessRule: Fetcher<ProcessRuleResponse, { url: string }> = ({ url }) => {
  62. return get<ProcessRuleResponse>(url)
  63. }
  64. export const fetchProcessRule: Fetcher<ProcessRuleResponse, { params: { documentId: string } }> = ({ params: { documentId } }) => {
  65. return get<ProcessRuleResponse>('/datasets/process-rule', { params: { document_id: documentId } })
  66. }
  67. export const fetchDocuments: Fetcher<DocumentListResponse, { datasetId: string; params: { keyword: string; page: number; limit: number; sort?: SortType } }> = ({ datasetId, params }) => {
  68. return get<DocumentListResponse>(`/datasets/${datasetId}/documents`, { params })
  69. }
  70. export const createFirstDocument: Fetcher<createDocumentResponse, { body: CreateDocumentReq }> = ({ body }) => {
  71. return post<createDocumentResponse>('/datasets/init', { body })
  72. }
  73. export const createDocument: Fetcher<createDocumentResponse, { datasetId: string; body: CreateDocumentReq }> = ({ datasetId, body }) => {
  74. return post<createDocumentResponse>(`/datasets/${datasetId}/documents`, { body })
  75. }
  76. export const fetchIndexingEstimate: Fetcher<IndexingEstimateResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  77. return get<IndexingEstimateResponse>(`/datasets/${datasetId}/documents/${documentId}/indexing-estimate`, {})
  78. }
  79. export const fetchIndexingEstimateBatch: Fetcher<IndexingEstimateResponse, BatchReq> = ({ datasetId, batchId }) => {
  80. return get<IndexingEstimateResponse>(`/datasets/${datasetId}/batch/${batchId}/indexing-estimate`, {})
  81. }
  82. export const fetchIndexingStatus: Fetcher<IndexingStatusResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  83. return get<IndexingStatusResponse>(`/datasets/${datasetId}/documents/${documentId}/indexing-status`, {})
  84. }
  85. export const fetchIndexingStatusBatch: Fetcher<IndexingStatusBatchResponse, BatchReq> = ({ datasetId, batchId }) => {
  86. return get<IndexingStatusBatchResponse>(`/datasets/${datasetId}/batch/${batchId}/indexing-status`, {})
  87. }
  88. export const fetchDocumentDetail: Fetcher<DocumentDetailResponse, CommonDocReq & { params: { metadata?: MetadataType } }> = ({ datasetId, documentId, params }) => {
  89. return get<DocumentDetailResponse>(`/datasets/${datasetId}/documents/${documentId}`, { params })
  90. }
  91. export const pauseDocIndexing: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  92. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/processing/pause`)
  93. }
  94. export const resumeDocIndexing: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  95. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/processing/resume`)
  96. }
  97. export const deleteDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  98. return del<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}`)
  99. }
  100. export const archiveDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  101. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/status/archive`)
  102. }
  103. export const unArchiveDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  104. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/status/un_archive`)
  105. }
  106. export const enableDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  107. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/status/enable`)
  108. }
  109. export const disableDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  110. return patch<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/status/disable`)
  111. }
  112. export const syncDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  113. return get<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/notion/sync`)
  114. }
  115. export const preImportNotionPages: Fetcher<{ notion_info: DataSourceNotionWorkspace[] }, { url: string; datasetId?: string }> = ({ url, datasetId }) => {
  116. return get<{ notion_info: DataSourceNotionWorkspace[] }>(url, { params: { dataset_id: datasetId } })
  117. }
  118. export const modifyDocMetadata: Fetcher<CommonResponse, CommonDocReq & { body: { doc_type: string; doc_metadata: Record<string, any> } }> = ({ datasetId, documentId, body }) => {
  119. return put<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/metadata`, { body })
  120. }
  121. // apis for segments in a document
  122. export const fetchSegments: Fetcher<SegmentsResponse, CommonDocReq & { params: SegmentsQuery }> = ({ datasetId, documentId, params }) => {
  123. return get<SegmentsResponse>(`/datasets/${datasetId}/documents/${documentId}/segments`, { params })
  124. }
  125. export const enableSegment: Fetcher<CommonResponse, { datasetId: string; segmentId: string }> = ({ datasetId, segmentId }) => {
  126. return patch<CommonResponse>(`/datasets/${datasetId}/segments/${segmentId}/enable`)
  127. }
  128. export const disableSegment: Fetcher<CommonResponse, { datasetId: string; segmentId: string }> = ({ datasetId, segmentId }) => {
  129. return patch<CommonResponse>(`/datasets/${datasetId}/segments/${segmentId}/disable`)
  130. }
  131. export const updateSegment: Fetcher<{ data: SegmentDetailModel; doc_form: string }, { datasetId: string; documentId: string; segmentId: string; body: SegmentUpdator }> = ({ datasetId, documentId, segmentId, body }) => {
  132. return patch<{ data: SegmentDetailModel; doc_form: string }>(`/datasets/${datasetId}/documents/${documentId}/segments/${segmentId}`, { body })
  133. }
  134. export const addSegment: Fetcher<{ data: SegmentDetailModel; doc_form: string }, { datasetId: string; documentId: string; body: SegmentUpdator }> = ({ datasetId, documentId, body }) => {
  135. return post<{ data: SegmentDetailModel; doc_form: string }>(`/datasets/${datasetId}/documents/${documentId}/segment`, { body })
  136. }
  137. export const deleteSegment: Fetcher<CommonResponse, { datasetId: string; documentId: string; segmentId: string }> = ({ datasetId, documentId, segmentId }) => {
  138. return del<CommonResponse>(`/datasets/${datasetId}/documents/${documentId}/segments/${segmentId}`)
  139. }
  140. export const segmentBatchImport: Fetcher<{ job_id: string; job_status: string }, { url: string; body: FormData }> = ({ url, body }) => {
  141. return post<{ job_id: string; job_status: string }>(url, { body }, { bodyStringify: false, deleteContentType: true })
  142. }
  143. export const checkSegmentBatchImportProgress: Fetcher<{ job_id: string; job_status: string }, { jobID: string }> = ({ jobID }) => {
  144. return get<{ job_id: string; job_status: string }>(`/datasets/batch_import_status/${jobID}`)
  145. }
  146. // hit testing
  147. export const hitTesting: Fetcher<HitTestingResponse, { datasetId: string; queryText: string; retrieval_model: RetrievalConfig }> = ({ datasetId, queryText, retrieval_model }) => {
  148. return post<HitTestingResponse>(`/datasets/${datasetId}/hit-testing`, { body: { query: queryText, retrieval_model } })
  149. }
  150. export const fetchTestingRecords: Fetcher<HitTestingRecordsResponse, { datasetId: string; params: { page: number; limit: number } }> = ({ datasetId, params }) => {
  151. return get<HitTestingRecordsResponse>(`/datasets/${datasetId}/queries`, { params })
  152. }
  153. export const fetchFileIndexingEstimate: Fetcher<FileIndexingEstimateResponse, IndexingEstimateParams> = (body: IndexingEstimateParams) => {
  154. return post<FileIndexingEstimateResponse>('/datasets/indexing-estimate', { body })
  155. }
  156. export const fetchNotionPagePreview: Fetcher<{ content: string }, { workspaceID: string; pageID: string; pageType: string }> = ({ workspaceID, pageID, pageType }) => {
  157. return get<{ content: string }>(`notion/workspaces/${workspaceID}/pages/${pageID}/${pageType}/preview`)
  158. }
  159. export const fetchApiKeysList: Fetcher<ApikeysListResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  160. return get<ApikeysListResponse>(url, params)
  161. }
  162. export const delApikey: Fetcher<CommonResponse, { url: string; params: Record<string, any> }> = ({ url, params }) => {
  163. return del<CommonResponse>(url, params)
  164. }
  165. export const createApikey: Fetcher<CreateApiKeyResponse, { url: string; body: Record<string, any> }> = ({ url, body }) => {
  166. return post<CreateApiKeyResponse>(url, body)
  167. }
  168. export const fetchDatasetApiBaseUrl: Fetcher<{ api_base_url: string }, string> = (url) => {
  169. return get<{ api_base_url: string }>(url)
  170. }
  171. type FileTypesRes = {
  172. allowed_extensions: string[]
  173. }
  174. export const fetchSupportFileTypes: Fetcher<FileTypesRes, { url: string }> = ({ url }) => {
  175. return get<FileTypesRes>(url)
  176. }