Skip to content
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 11 additions & 5 deletions document/content/docs/upgrading/4-13/4132.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,17 @@ description: 'FastGPT V4.13.1 更新说明'
## 🐛 修复

1. LLM 模型默认支持图片,导致请求错误。
2. Mongo 多副本切换时候,watch 未重新触发。

## 🔨 插件更新

1. Perplexity search 工具。
2. Base64转文件工具。
3. MiniMax TTS 文件生成工具。
4. Openrouter nano banana 绘图工具。
5. 系统工具支持配置是否需要在 Worker 中运行。
1. 新增:Perplexity search 工具。
2. 新增:Base64转文件工具。
3. 新增:MiniMax TTS 文件生成工具。
4. 新增:Openrouter nano banana 绘图工具。
5. 新增:Redis 缓存操作工具。
6. 新增:Tavily search 工具。
7. 新增:硅基流动 qwen-image 和 qwen-image-edit 工具。
8. 新增:飞书多维表格操作套件。
9. 新增:Youtube 字幕提取。
10. 系统工具支持配置是否需要在 Worker 中运行。
2 changes: 1 addition & 1 deletion document/data/doc-last-modified.json
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@
"document/content/docs/upgrading/4-12/4124.mdx": "2025-09-17T22:29:56+08:00",
"document/content/docs/upgrading/4-13/4130.mdx": "2025-09-30T16:00:10+08:00",
"document/content/docs/upgrading/4-13/4131.mdx": "2025-09-30T15:47:06+08:00",
"document/content/docs/upgrading/4-13/4132.mdx": "2025-10-12T00:04:51+08:00",
"document/content/docs/upgrading/4-13/4132.mdx": "2025-10-13T16:16:59+08:00",
"document/content/docs/upgrading/4-8/40.mdx": "2025-08-02T19:38:37+08:00",
"document/content/docs/upgrading/4-8/41.mdx": "2025-08-02T19:38:37+08:00",
"document/content/docs/upgrading/4-8/42.mdx": "2025-08-02T19:38:37+08:00",
Expand Down
20 changes: 14 additions & 6 deletions packages/service/common/mongo/init.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,13 @@ const maxConnecting = Math.max(30, Number(process.env.DB_MAX_LINK || 20));
/**
* connect MongoDB and init data
*/
export async function connectMongo(db: Mongoose, url: string): Promise<Mongoose> {
export async function connectMongo(props: {
db: Mongoose;
url: string;
connectedCb?: () => void;
}): Promise<Mongoose> {
const { db, url, connectedCb } = props;

/* Connecting, connected will return */
if (db.connection.readyState !== 0) {
return db;
Expand All @@ -31,7 +37,7 @@ export async function connectMongo(db: Mongoose, url: string): Promise<Mongoose>
RemoveListeners();
await db.disconnect();
await delay(1000);
await connectMongo(db, url);
await connectMongo(props);
}
} catch (error) {}
});
Expand All @@ -42,7 +48,7 @@ export async function connectMongo(db: Mongoose, url: string): Promise<Mongoose>
RemoveListeners();
await db.disconnect();
await delay(1000);
await connectMongo(db, url);
await connectMongo(props);
}
} catch (error) {}
});
Expand All @@ -60,16 +66,18 @@ export async function connectMongo(db: Mongoose, url: string): Promise<Mongoose>
retryReads: true
};

db.connect(url, options);

await db.connect(url, options);
console.log('mongo connected');

connectedCb?.();

return db;
} catch (error) {
addLog.error('Mongo connect error', error);

await db.disconnect();

await delay(1000);
return connectMongo(db, url);
return connectMongo(props);
}
}
2 changes: 1 addition & 1 deletion packages/service/core/ai/config/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -236,7 +236,7 @@ export const getSystemModelConfig = async (model: string): Promise<SystemModelIt
export const watchSystemModelUpdate = () => {
const changeStream = MongoSystemModel.watch();

changeStream.on(
return changeStream.on(
'change',
debounce(async () => {
try {
Expand Down
15 changes: 7 additions & 8 deletions packages/service/core/workflow/dispatch/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -633,14 +633,13 @@ export const runWorkflow = async (data: RunWorkflowProps): Promise<DispatchFlowR
this.chatNodeUsages = this.chatNodeUsages.concat(nodeDispatchUsages);
}

if (toolResponses !== undefined && toolResponses !== null) {
if (Array.isArray(toolResponses) && toolResponses.length === 0) return;
if (
!Array.isArray(toolResponses) &&
if (
(toolResponses !== undefined && toolResponses !== null) ||
(Array.isArray(toolResponses) && toolResponses.length > 0) ||
(!Array.isArray(toolResponses) &&
typeof toolResponses === 'object' &&
Object.keys(toolResponses).length === 0
)
return;
Object.keys(toolResponses).length > 0)
) {
this.toolRunResponse = toolResponses;
}

Expand Down Expand Up @@ -973,7 +972,7 @@ export const runWorkflow = async (data: RunWorkflowProps): Promise<DispatchFlowR
externalProvider.externalWorkflowVariables,
data.chatConfig?.variables
);

console.log(workflowQueue.chatAssistantResponse, 11);
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Bug: Unintended Debug Statement in Production

A debug console.log(workflowQueue.chatAssistantResponse, 11); statement was accidentally committed, cluttering console output in production.

Fix in Cursor Fix in Web

return {
flowResponses: workflowQueue.chatResponses,
flowUsages: workflowQueue.chatNodeUsages,
Expand Down
12 changes: 9 additions & 3 deletions projects/app/src/instrumentation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -47,8 +47,15 @@ export async function register() {
initGlobalVariables();

// Connect to MongoDB
await connectMongo(connectionMongo, MONGO_URL);
connectMongo(connectionLogMongo, MONGO_LOG_URL);
await connectMongo({
db: connectionMongo,
url: MONGO_URL,
connectedCb: () => startMongoWatch()
});
connectMongo({
db: connectionLogMongo,
url: MONGO_LOG_URL
});

//init system config;init vector database;init root user
await Promise.all([getInitConfig(), initVectorStore(), initRootUser(), loadSystemModels()]);
Expand All @@ -60,7 +67,6 @@ export async function register() {
initAppTemplateTypes()
]);

startMongoWatch();
startCron();
startTrainingQueue(true);
trackTimerProcess();
Expand Down
8 changes: 8 additions & 0 deletions projects/app/src/pages/api/core/app/version/publish.ts
Original file line number Diff line number Diff line change
Expand Up @@ -116,3 +116,11 @@ async function handler(req: ApiRequestProps<PostPublishAppProps>, res: NextApiRe
}

export default NextAPI(handler);

export const config = {
api: {
bodyParser: {
sizeLimit: '5mb'
}
}
};
22 changes: 16 additions & 6 deletions projects/app/src/service/common/system/volumnMongoWatch.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,17 +7,21 @@ import { getAppTemplatesAndLoadThem } from '@fastgpt/service/core/app/templates/
import { watchSystemModelUpdate } from '@fastgpt/service/core/ai/config/utils';
import { SystemConfigsTypeEnum } from '@fastgpt/global/common/system/config/constants';

const changeStreams: any[] = [];

export const startMongoWatch = async () => {
reloadConfigWatch();
createDatasetTrainingMongoWatch();
refetchAppTemplates();
watchSystemModelUpdate();
cleanupMongoWatch();
console.log('Watch mongo db start');
changeStreams.push(reloadConfigWatch());
changeStreams.push(createDatasetTrainingMongoWatch());
changeStreams.push(refetchAppTemplates());
changeStreams.push(watchSystemModelUpdate());
};

const reloadConfigWatch = () => {
const changeStream = MongoSystemConfigs.watch();

changeStream.on('change', async (change) => {
return changeStream.on('change', async (change) => {
try {
if (
change.operationType === 'update' ||
Expand All @@ -36,7 +40,7 @@ const reloadConfigWatch = () => {
const refetchAppTemplates = () => {
const changeStream = MongoAppTemplate.watch();

changeStream.on(
return changeStream.on(
'change',
debounce(async (change) => {
setTimeout(() => {
Expand All @@ -47,3 +51,9 @@ const refetchAppTemplates = () => {
}, 500)
);
};

const cleanupMongoWatch = () => {
changeStreams.forEach((changeStream) => {
changeStream?.close();
});
};
2 changes: 1 addition & 1 deletion projects/app/src/service/core/dataset/training/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import { datasetParseQueue } from '../queues/datasetParse';
export const createDatasetTrainingMongoWatch = () => {
const changeStream = MongoDatasetTraining.watch();

changeStream.on('change', async (change) => {
return changeStream.on('change', async (change) => {
try {
if (change.operationType === 'insert') {
const fullDocument = change.fullDocument as DatasetTrainingSchemaType;
Expand Down
Loading