mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 13:03: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>
136 lines
4.4 KiB
TypeScript
136 lines
4.4 KiB
TypeScript
import type { AppSimpleEditFormType } from '../app/type';
|
|
import { FlowNodeTypeEnum } from '../module/node/constant';
|
|
import {
|
|
ModuleOutputKeyEnum,
|
|
ModuleInputKeyEnum,
|
|
FlowNodeTemplateTypeEnum
|
|
} from '../module/constants';
|
|
import type { FlowNodeInputItemType } from '../module/node/type.d';
|
|
import { getGuideModule, splitGuideModule } from '../module/utils';
|
|
import { ModuleItemType } from '../module/type.d';
|
|
import { DatasetSearchModeEnum } from '../dataset/constants';
|
|
|
|
export const getDefaultAppForm = (): AppSimpleEditFormType => {
|
|
return {
|
|
aiSettings: {
|
|
model: 'gpt-3.5-turbo',
|
|
systemPrompt: '',
|
|
temperature: 0,
|
|
isResponseAnswerText: true,
|
|
maxHistories: 6,
|
|
maxToken: 4000
|
|
},
|
|
dataset: {
|
|
datasets: [],
|
|
similarity: 0.4,
|
|
limit: 1500,
|
|
searchMode: DatasetSearchModeEnum.embedding,
|
|
usingReRank: false,
|
|
datasetSearchUsingExtensionQuery: true,
|
|
datasetSearchExtensionBg: ''
|
|
},
|
|
selectedTools: [],
|
|
userGuide: {
|
|
welcomeText: '',
|
|
variables: [],
|
|
questionGuide: false,
|
|
tts: {
|
|
type: 'web'
|
|
}
|
|
}
|
|
};
|
|
};
|
|
|
|
/* format app modules to edit form */
|
|
export const appModules2Form = ({ modules }: { modules: ModuleItemType[] }) => {
|
|
const defaultAppForm = getDefaultAppForm();
|
|
|
|
const findInputValueByKey = (inputs: FlowNodeInputItemType[], key: string) => {
|
|
return inputs.find((item) => item.key === key)?.value;
|
|
};
|
|
|
|
modules.forEach((module) => {
|
|
if (
|
|
module.flowType === FlowNodeTypeEnum.chatNode ||
|
|
module.flowType === FlowNodeTypeEnum.tools
|
|
) {
|
|
defaultAppForm.aiSettings.model = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiModel
|
|
);
|
|
defaultAppForm.aiSettings.systemPrompt = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiSystemPrompt
|
|
);
|
|
defaultAppForm.aiSettings.temperature = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatTemperature
|
|
);
|
|
defaultAppForm.aiSettings.maxToken = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.aiChatMaxToken
|
|
);
|
|
defaultAppForm.aiSettings.maxHistories = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.history
|
|
);
|
|
} else if (module.flowType === FlowNodeTypeEnum.datasetSearchNode) {
|
|
defaultAppForm.dataset.datasets = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSelectList
|
|
);
|
|
defaultAppForm.dataset.similarity = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSimilarity
|
|
);
|
|
defaultAppForm.dataset.limit = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetMaxTokens
|
|
);
|
|
defaultAppForm.dataset.searchMode =
|
|
findInputValueByKey(module.inputs, ModuleInputKeyEnum.datasetSearchMode) ||
|
|
DatasetSearchModeEnum.embedding;
|
|
defaultAppForm.dataset.usingReRank = !!findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSearchUsingReRank
|
|
);
|
|
defaultAppForm.dataset.datasetSearchUsingExtensionQuery = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSearchUsingExtensionQuery
|
|
);
|
|
defaultAppForm.dataset.datasetSearchExtensionModel = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSearchExtensionModel
|
|
);
|
|
defaultAppForm.dataset.datasetSearchExtensionBg = findInputValueByKey(
|
|
module.inputs,
|
|
ModuleInputKeyEnum.datasetSearchExtensionBg
|
|
);
|
|
} else if (module.flowType === FlowNodeTypeEnum.userGuide) {
|
|
const { welcomeText, variableModules, questionGuide, ttsConfig } = splitGuideModule(
|
|
getGuideModule(modules)
|
|
);
|
|
defaultAppForm.userGuide = {
|
|
welcomeText: welcomeText,
|
|
variables: variableModules,
|
|
questionGuide: questionGuide,
|
|
tts: ttsConfig
|
|
};
|
|
} else if (module.flowType === FlowNodeTypeEnum.pluginModule) {
|
|
defaultAppForm.selectedTools.push({
|
|
id: module.inputs.find((input) => input.key === ModuleInputKeyEnum.pluginId)?.value || '',
|
|
name: module.name,
|
|
avatar: module.avatar,
|
|
intro: module.intro || '',
|
|
flowType: module.flowType,
|
|
showStatus: module.showStatus,
|
|
inputs: module.inputs,
|
|
outputs: module.outputs,
|
|
templateType: FlowNodeTemplateTypeEnum.other
|
|
});
|
|
}
|
|
});
|
|
|
|
return defaultAppForm;
|
|
};
|