mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 21:13:50 +00:00

* feat: stop toolCall and rename some field. (#46) * perf: node delete tip;pay tip * fix: toolCall cannot save child answer * feat: stop tool * fix: team modal * fix feckbackMoal auth bug (#47) * 简单的支持提示词运行tool。优化workflow模板 (#49) * remove templates * fix: request body undefined * feat: prompt tool run * feat: workflow tamplates modal * perf: plugin start * 4.7 (#50) * fix docker-compose download url (#994) original code is a bad url with '404 NOT FOUND' return. fix docker-compose download url, add 'v' before docker-compose version * Update ai_settings.md (#1000) * Update configuration.md * Update configuration.md * Fix history in classifyQuestion and extract modules (#1012) * Fix history in classifyQuestion and extract modules * Add chatValue2RuntimePrompt import and update text formatting * flow controller to packages * fix: rerank select * modal ui * perf: modal code path * point not sufficient * feat: http url support variable * fix http key * perf: prompt * perf: ai setting modal * simple edit ui --------- Co-authored-by: entorick <entorick11@qq.com> Co-authored-by: liujianglc <liujianglc@163.com> Co-authored-by: Fengrui Liu <liufengrui.work@bytedance.com> * fix team share redirect to login (#51) * feat: support openapi import plugins (#48) * feat: support openapi import plugins * feat: import from url * fix: add body params parse * fix build * fix * fix * fix * tool box ui (#52) * fix: training queue * feat: simple edit tool select * perf: simple edit dataset prompt * fix: chatbox tool ux * feat: quote prompt module * perf: plugin tools sign * perf: model avatar * tool selector ui * feat: max histories * perf: http plugin import (#53) * perf: plugin http import * chatBox ui * perf: name * fix: Node template card (#54) * fix: ts * setting modal * package * package * feat: add plugins search (#57) * feat: add plugins search * perf: change http plugin header input * Yjl (#56) * perf: prompt tool call * perf: chat box ux * doc * doc * price tip * perf: tool selector * ui' * fix: vector queue * fix: empty tool and empty response * fix: empty msg * perf: pg index * perf: ui tip * doc * tool tip --------- Co-authored-by: yst <77910600+yu-and-liu@users.noreply.github.com> Co-authored-by: entorick <entorick11@qq.com> Co-authored-by: liujianglc <liujianglc@163.com> Co-authored-by: Fengrui Liu <liufengrui.work@bytedance.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
91 lines
2.7 KiB
TypeScript
91 lines
2.7 KiB
TypeScript
import { MongoPlugin } from './schema';
|
|
import { FlowNodeTemplateType } from '@fastgpt/global/core/module/type';
|
|
import { FlowNodeTypeEnum } from '@fastgpt/global/core/module/node/constant';
|
|
import { plugin2ModuleIO } from '@fastgpt/global/core/module/utils';
|
|
import { PluginSourceEnum } from '@fastgpt/global/core/plugin/constants';
|
|
import type { PluginRuntimeType, PluginTemplateType } from '@fastgpt/global/core/plugin/type.d';
|
|
import { FlowNodeTemplateTypeEnum } from '@fastgpt/global/core/module/constants';
|
|
import type { PluginItemSchema } from '@fastgpt/global/core/plugin/type.d';
|
|
|
|
/*
|
|
plugin id rule:
|
|
personal: id
|
|
community: community-id
|
|
commercial: commercial-id
|
|
*/
|
|
|
|
export async function splitCombinePluginId(id: string) {
|
|
const splitRes = id.split('-');
|
|
if (splitRes.length === 1) {
|
|
return {
|
|
source: PluginSourceEnum.personal,
|
|
pluginId: id
|
|
};
|
|
}
|
|
|
|
const [source, pluginId] = id.split('-') as [`${PluginSourceEnum}`, string];
|
|
if (!source || !pluginId) return Promise.reject('pluginId not found');
|
|
|
|
return { source, pluginId: id };
|
|
}
|
|
|
|
const getPluginTemplateById = async (id: string): Promise<PluginTemplateType> => {
|
|
const { source, pluginId } = await splitCombinePluginId(id);
|
|
if (source === PluginSourceEnum.community) {
|
|
const item = global.communityPlugins?.find((plugin) => plugin.id === pluginId);
|
|
if (!item) return Promise.reject('plugin not found');
|
|
|
|
return item;
|
|
}
|
|
if (source === PluginSourceEnum.personal) {
|
|
const item = await MongoPlugin.findById(id).lean();
|
|
if (!item) return Promise.reject('plugin not found');
|
|
return {
|
|
id: String(item._id),
|
|
teamId: String(item.teamId),
|
|
name: item.name,
|
|
avatar: item.avatar,
|
|
intro: item.intro,
|
|
showStatus: true,
|
|
source: PluginSourceEnum.personal,
|
|
modules: item.modules,
|
|
templateType: FlowNodeTemplateTypeEnum.personalPlugin
|
|
};
|
|
}
|
|
return Promise.reject('plugin not found');
|
|
};
|
|
|
|
/* format plugin modules to plugin preview module */
|
|
export async function getPluginPreviewModule({
|
|
id
|
|
}: {
|
|
id: string;
|
|
}): Promise<FlowNodeTemplateType> {
|
|
const plugin = await getPluginTemplateById(id);
|
|
|
|
return {
|
|
id: plugin.id,
|
|
templateType: plugin.templateType,
|
|
flowType: FlowNodeTypeEnum.pluginModule,
|
|
avatar: plugin.avatar,
|
|
name: plugin.name,
|
|
intro: plugin.intro,
|
|
showStatus: plugin.showStatus,
|
|
isTool: plugin.isTool,
|
|
...plugin2ModuleIO(plugin.id, plugin.modules)
|
|
};
|
|
}
|
|
|
|
/* run plugin time */
|
|
export async function getPluginRuntimeById(id: string): Promise<PluginRuntimeType> {
|
|
const plugin = await getPluginTemplateById(id);
|
|
|
|
return {
|
|
teamId: plugin.teamId,
|
|
name: plugin.name,
|
|
avatar: plugin.avatar,
|
|
showStatus: plugin.showStatus,
|
|
modules: plugin.modules
|
|
};
|
|
}
|