Archer 38efa3e050
feat: default model (#3662)
* move model config

* feat: default model
2025-01-24 18:44:43 +08:00

63 lines
1.5 KiB
TypeScript

import { addLog } from '../../../common/system/log';
import { POST } from '../../../common/api/serverRequest';
import { getDefaultRerankModel } from '../model';
import { getAxiosConfig } from '../config';
type PostReRankResponse = {
id: string;
results: {
index: number;
relevance_score: number;
}[];
};
type ReRankCallResult = { id: string; score?: number }[];
export function reRankRecall({
query,
documents
}: {
query: string;
documents: { id: string; text: string }[];
}): Promise<ReRankCallResult> {
const model = getDefaultRerankModel();
if (!model || !model?.requestUrl) {
return Promise.reject('no rerank model');
}
const { baseUrl, authorization } = getAxiosConfig({});
let start = Date.now();
return POST<PostReRankResponse>(
model.requestUrl ? model.requestUrl : `${baseUrl}/v1/rerank`,
{
model: model.model,
query,
documents: documents.map((doc) => doc.text)
},
{
headers: {
Authorization: model.requestAuth ? model.requestAuth : authorization
},
timeout: 30000
}
)
.then((data) => {
addLog.info('ReRank finish:', { time: Date.now() - start });
if (!data?.results || data?.results?.length === 0) {
addLog.error('ReRank error, empty result', data);
}
return data?.results?.map((item) => ({
id: documents[item.index].id,
score: item.relevance_score
}));
})
.catch((err) => {
addLog.error('rerank error', err);
return [];
});
}