mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 05:12:39 +00:00
fix: global variable persist during api calls (#2544)
This commit is contained in:
@@ -5,6 +5,7 @@ import { ChatItemValueTypeEnum, ChatRoleEnum } from '@fastgpt/global/core/chat/c
|
|||||||
import { delFileByFileIdList, getGFSCollection } from '../../common/file/gridfs/controller';
|
import { delFileByFileIdList, getGFSCollection } from '../../common/file/gridfs/controller';
|
||||||
import { BucketNameEnum } from '@fastgpt/global/common/file/constants';
|
import { BucketNameEnum } from '@fastgpt/global/common/file/constants';
|
||||||
import { MongoChat } from './chatSchema';
|
import { MongoChat } from './chatSchema';
|
||||||
|
import { ChatSchema as ChatType } from '@fastgpt/global/core/chat/type.d';
|
||||||
|
|
||||||
export async function getChatItems({
|
export async function getChatItems({
|
||||||
appId,
|
appId,
|
||||||
@@ -35,7 +36,26 @@ export async function getChatItems({
|
|||||||
|
|
||||||
return { histories };
|
return { histories };
|
||||||
}
|
}
|
||||||
/* 临时适配旧的对话记录 */
|
|
||||||
|
export async function getChat({
|
||||||
|
appId,
|
||||||
|
chatId,
|
||||||
|
field
|
||||||
|
}: {
|
||||||
|
appId: string;
|
||||||
|
chatId?: string;
|
||||||
|
field: string;
|
||||||
|
}): Promise<{ chat: ChatType | null }> {
|
||||||
|
if (!chatId) {
|
||||||
|
return { chat: null };
|
||||||
|
}
|
||||||
|
|
||||||
|
const chat = await MongoChat.findOne({ appId, chatId }, field).lean();
|
||||||
|
|
||||||
|
return { chat };
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Temporary adaptation for old conversation records */
|
||||||
export const adaptStringValue = (value: any): ChatItemValueItemType[] => {
|
export const adaptStringValue = (value: any): ChatItemValueItemType[] => {
|
||||||
if (typeof value === 'string') {
|
if (typeof value === 'string') {
|
||||||
return [
|
return [
|
||||||
|
@@ -20,7 +20,7 @@ import {
|
|||||||
textAdaptGptResponse
|
textAdaptGptResponse
|
||||||
} from '@fastgpt/global/core/workflow/runtime/utils';
|
} from '@fastgpt/global/core/workflow/runtime/utils';
|
||||||
import { GPTMessages2Chats, chatValue2RuntimePrompt } from '@fastgpt/global/core/chat/adapt';
|
import { GPTMessages2Chats, chatValue2RuntimePrompt } from '@fastgpt/global/core/chat/adapt';
|
||||||
import { getChatItems } from '@fastgpt/service/core/chat/controller';
|
import { getChat, getChatItems } from '@fastgpt/service/core/chat/controller';
|
||||||
import { saveChat } from '@fastgpt/service/core/chat/saveChat';
|
import { saveChat } from '@fastgpt/service/core/chat/saveChat';
|
||||||
import { responseWrite } from '@fastgpt/service/common/response';
|
import { responseWrite } from '@fastgpt/service/common/response';
|
||||||
import { pushChatUsage } from '@/service/support/wallet/usage/push';
|
import { pushChatUsage } from '@/service/support/wallet/usage/push';
|
||||||
@@ -220,17 +220,31 @@ async function handler(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
|
|
||||||
// Get and concat history;
|
// Get and concat history;
|
||||||
const limit = getMaxHistoryLimitFromNodes(app.modules);
|
const limit = getMaxHistoryLimitFromNodes(app.modules);
|
||||||
const [{ histories }, { nodes, edges, chatConfig }] = await Promise.all([
|
const [{ histories }, { nodes, edges, chatConfig }, { chat }] = await Promise.all([
|
||||||
getChatItems({
|
getChatItems({
|
||||||
appId: app._id,
|
appId: app._id,
|
||||||
chatId,
|
chatId,
|
||||||
limit,
|
limit,
|
||||||
field: `dataId obj value nodeOutputs`
|
field: `dataId obj value nodeOutputs`
|
||||||
}),
|
}),
|
||||||
getAppLatestVersion(app._id, app)
|
getAppLatestVersion(app._id, app),
|
||||||
|
getChat({
|
||||||
|
appId: app._id,
|
||||||
|
chatId,
|
||||||
|
field: 'source variableList variables'
|
||||||
|
})
|
||||||
]);
|
]);
|
||||||
|
// get chat histories
|
||||||
const newHistories = concatHistories(histories, chatMessages);
|
const newHistories = concatHistories(histories, chatMessages);
|
||||||
|
|
||||||
|
// get global variables
|
||||||
|
if (chat && chat.variables) {
|
||||||
|
variables = {
|
||||||
|
...chat.variables,
|
||||||
|
...variables
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
// Get runtimeNodes
|
// Get runtimeNodes
|
||||||
let runtimeNodes = storeNodes2RuntimeNodes(nodes, getWorkflowEntryNodeIds(nodes, newHistories));
|
let runtimeNodes = storeNodes2RuntimeNodes(nodes, getWorkflowEntryNodeIds(nodes, newHistories));
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user