datasets.ts 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. import type { Fetcher } from 'swr'
  2. import qs from 'qs'
  3. import { del, get, patch, post, put } from './base'
  4. import type { CreateDocumentReq, DataSet, DataSetListResponse, DocumentDetailResponse, DocumentListResponse, FileIndexingEstimateResponse, HitTestingRecordsResponse, HitTestingResponse, IndexingEstimateResponse, IndexingStatusBatchResponse, IndexingStatusResponse, ProcessRuleResponse, RelatedAppResponse, SegmentsQuery, SegmentsResponse, createDocumentResponse } from '@/models/datasets'
  5. import type { CommonResponse, DataSourceNotionWorkspace } from '@/models/common'
  6. // apis for documents in a dataset
  7. type CommonDocReq = {
  8. datasetId: string
  9. documentId: string
  10. }
  11. type BatchReq = {
  12. datasetId: string
  13. batchId: string
  14. }
  15. export type SortType = 'created_at' | 'hit_count' | '-created_at' | '-hit_count'
  16. export type MetadataType = 'all' | 'only' | 'without'
  17. export const fetchDataDetail: Fetcher<DataSet, string> = (datasetId: string) => {
  18. return get(`/datasets/${datasetId}`) as Promise<DataSet>
  19. }
  20. export const updateDatasetSetting: Fetcher<DataSet, { datasetId: string; body: Partial<Pick<DataSet, 'name' | 'description' | 'permission' | 'indexing_technique'>> }> = ({ datasetId, body }) => {
  21. return patch(`/datasets/${datasetId}`, { body }) as Promise<DataSet>
  22. }
  23. export const fetchDatasetRelatedApps: Fetcher<RelatedAppResponse, string> = (datasetId: string) => {
  24. return get(`/datasets/${datasetId}/related-apps`) as Promise<RelatedAppResponse>
  25. }
  26. export const fetchDatasets: Fetcher<DataSetListResponse, { url: string; params: { page: number; ids?: string[]; limit?: number } }> = ({ url, params }) => {
  27. const urlParams = qs.stringify(params, { indices: false })
  28. return get(`${url}?${urlParams}`) as Promise<DataSetListResponse>
  29. }
  30. export const createEmptyDataset: Fetcher<DataSet, { name: string }> = ({ name }) => {
  31. return post('/datasets', { body: { name } }) as Promise<DataSet>
  32. }
  33. export const deleteDataset: Fetcher<DataSet, string> = (datasetID) => {
  34. return del(`/datasets/${datasetID}`) as Promise<DataSet>
  35. }
  36. export const fetchDefaultProcessRule: Fetcher<ProcessRuleResponse, { url: string }> = ({ url }) => {
  37. return get(url) as Promise<ProcessRuleResponse>
  38. }
  39. export const fetchProcessRule: Fetcher<ProcessRuleResponse, { params: { documentId: string } }> = ({ params: { documentId } }) => {
  40. return get('/datasets/process-rule', { params: { document_id: documentId } }) as Promise<ProcessRuleResponse>
  41. }
  42. export const fetchDocuments: Fetcher<DocumentListResponse, { datasetId: string; params: { keyword: string; page: number; limit: number; sort?: SortType } }> = ({ datasetId, params }) => {
  43. return get(`/datasets/${datasetId}/documents`, { params }) as Promise<DocumentListResponse>
  44. }
  45. export const createFirstDocument: Fetcher<createDocumentResponse, { body: CreateDocumentReq }> = ({ body }) => {
  46. return post('/datasets/init', { body }) as Promise<createDocumentResponse>
  47. }
  48. export const createDocument: Fetcher<createDocumentResponse, { datasetId: string; body: CreateDocumentReq }> = ({ datasetId, body }) => {
  49. return post(`/datasets/${datasetId}/documents`, { body }) as Promise<createDocumentResponse>
  50. }
  51. export const fetchIndexingEstimate: Fetcher<IndexingEstimateResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  52. return get(`/datasets/${datasetId}/documents/${documentId}/indexing-estimate`, {}) as Promise<IndexingEstimateResponse>
  53. }
  54. export const fetchIndexingEstimateBatch: Fetcher<IndexingEstimateResponse, BatchReq> = ({ datasetId, batchId }) => {
  55. return get(`/datasets/${datasetId}/batch/${batchId}/indexing-estimate`, {}) as Promise<IndexingEstimateResponse>
  56. }
  57. export const fetchIndexingStatus: Fetcher<IndexingStatusResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  58. return get(`/datasets/${datasetId}/documents/${documentId}/indexing-status`, {}) as Promise<IndexingStatusResponse>
  59. }
  60. export const fetchIndexingStatusBatch: Fetcher<IndexingStatusBatchResponse, BatchReq> = ({ datasetId, batchId }) => {
  61. return get(`/datasets/${datasetId}/batch/${batchId}/indexing-status`, {}) as Promise<IndexingStatusBatchResponse>
  62. }
  63. export const fetchDocumentDetail: Fetcher<DocumentDetailResponse, CommonDocReq & { params: { metadata?: MetadataType } }> = ({ datasetId, documentId, params }) => {
  64. return get(`/datasets/${datasetId}/documents/${documentId}`, { params }) as Promise<DocumentDetailResponse>
  65. }
  66. export const pauseDocIndexing: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  67. return patch(`/datasets/${datasetId}/documents/${documentId}/processing/pause`) as Promise<CommonResponse>
  68. }
  69. export const resumeDocIndexing: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  70. return patch(`/datasets/${datasetId}/documents/${documentId}/processing/resume`) as Promise<CommonResponse>
  71. }
  72. export const deleteDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  73. return del(`/datasets/${datasetId}/documents/${documentId}`) as Promise<CommonResponse>
  74. }
  75. export const archiveDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  76. return patch(`/datasets/${datasetId}/documents/${documentId}/status/archive`) as Promise<CommonResponse>
  77. }
  78. export const enableDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  79. return patch(`/datasets/${datasetId}/documents/${documentId}/status/enable`) as Promise<CommonResponse>
  80. }
  81. export const disableDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  82. return patch(`/datasets/${datasetId}/documents/${documentId}/status/disable`) as Promise<CommonResponse>
  83. }
  84. export const syncDocument: Fetcher<CommonResponse, CommonDocReq> = ({ datasetId, documentId }) => {
  85. return get(`/datasets/${datasetId}/documents/${documentId}/notion/sync`) as Promise<CommonResponse>
  86. }
  87. export const preImportNotionPages: Fetcher<{ notion_info: DataSourceNotionWorkspace[] }, { url: string; datasetId?: string }> = ({ url, datasetId }) => {
  88. return get(url, { params: { dataset_id: datasetId } }) as Promise<{ notion_info: DataSourceNotionWorkspace[] }>
  89. }
  90. export const modifyDocMetadata: Fetcher<CommonResponse, CommonDocReq & { body: { doc_type: string; doc_metadata: Record<string, any> } }> = ({ datasetId, documentId, body }) => {
  91. return put(`/datasets/${datasetId}/documents/${documentId}/metadata`, { body }) as Promise<CommonResponse>
  92. }
  93. export const getDatasetIndexingStatus: Fetcher<{ data: IndexingStatusResponse[] }, string> = (datasetId) => {
  94. return get(`/datasets/${datasetId}/indexing-status`) as Promise<{ data: IndexingStatusResponse[] }>
  95. }
  96. // apis for segments in a document
  97. export const fetchSegments: Fetcher<SegmentsResponse, CommonDocReq & { params: SegmentsQuery }> = ({ datasetId, documentId, params }) => {
  98. return get(`/datasets/${datasetId}/documents/${documentId}/segments`, { params }) as Promise<SegmentsResponse>
  99. }
  100. export const enableSegment: Fetcher<CommonResponse, { datasetId: string; segmentId: string }> = ({ datasetId, segmentId }) => {
  101. return patch(`/datasets/${datasetId}/segments/${segmentId}/enable`) as Promise<CommonResponse>
  102. }
  103. export const disableSegment: Fetcher<CommonResponse, { datasetId: string; segmentId: string }> = ({ datasetId, segmentId }) => {
  104. return patch(`/datasets/${datasetId}/segments/${segmentId}/disable`) as Promise<CommonResponse>
  105. }
  106. // hit testing
  107. export const hitTesting: Fetcher<HitTestingResponse, { datasetId: string; queryText: string }> = ({ datasetId, queryText }) => {
  108. return post(`/datasets/${datasetId}/hit-testing`, { body: { query: queryText } }) as Promise<HitTestingResponse>
  109. }
  110. export const fetchTestingRecords: Fetcher<HitTestingRecordsResponse, { datasetId: string; params: { page: number; limit: number } }> = ({ datasetId, params }) => {
  111. return get(`/datasets/${datasetId}/queries`, { params }) as Promise<HitTestingRecordsResponse>
  112. }
  113. export const fetchFileIndexingEstimate: Fetcher<FileIndexingEstimateResponse, any> = (body: any) => {
  114. return post('/datasets/indexing-estimate', { body }) as Promise<FileIndexingEstimateResponse>
  115. }
  116. export const fetchNotionPagePreview: Fetcher<{ content: string }, { workspaceID: string; pageID: string; pageType: string }> = ({ workspaceID, pageID, pageType }) => {
  117. return get(`notion/workspaces/${workspaceID}/pages/${pageID}/${pageType}/preview`) as Promise<{ content: string }>
  118. }