|
|
|
|
@ -8,12 +8,12 @@ from core.model_manager import ModelManager
|
|
|
|
|
from core.model_runtime.entities.model_entities import ModelType
|
|
|
|
|
from core.plugin.manager.exc import PluginDaemonClientSideError
|
|
|
|
|
from core.plugin.manager.plugin import PluginInstallationManager
|
|
|
|
|
from core.tools.entities.tool_entities import ToolProviderType
|
|
|
|
|
from core.tools.entities.tool_entities import ToolParameter, ToolProviderType
|
|
|
|
|
from core.tools.tool_manager import ToolManager
|
|
|
|
|
from core.workflow.entities.node_entities import NodeRunResult
|
|
|
|
|
from core.workflow.entities.variable_pool import VariablePool
|
|
|
|
|
from core.workflow.enums import SystemVariableKey
|
|
|
|
|
from core.workflow.nodes.agent.entities import AgentNodeData
|
|
|
|
|
from core.workflow.nodes.agent.entities import AgentNodeData, ParamsAutoGenerated
|
|
|
|
|
from core.workflow.nodes.base.entities import BaseNodeData
|
|
|
|
|
from core.workflow.nodes.enums import NodeType
|
|
|
|
|
from core.workflow.nodes.event.event import RunCompletedEvent
|
|
|
|
|
@ -162,11 +162,28 @@ class AgentNode(ToolNode):
|
|
|
|
|
tool_value = []
|
|
|
|
|
for tool in value:
|
|
|
|
|
provider_type = ToolProviderType(tool.get("type", ToolProviderType.BUILT_IN.value))
|
|
|
|
|
# handle the original settings
|
|
|
|
|
original_parameters = tool.get("parameters", {})
|
|
|
|
|
setting_params = tool.get("settings", {})
|
|
|
|
|
manual_input_params = []
|
|
|
|
|
# handle legacy data compatibility
|
|
|
|
|
if not all(isinstance(v, dict) for _, v in original_parameters.items()):
|
|
|
|
|
parameters = original_parameters
|
|
|
|
|
else:
|
|
|
|
|
params = {}
|
|
|
|
|
for key, param in original_parameters.items():
|
|
|
|
|
if param.get("auto", ParamsAutoGenerated.OPEN.value) == ParamsAutoGenerated.CLOSE.value:
|
|
|
|
|
params[key] = param.get("value", "")
|
|
|
|
|
manual_input_params.append(key)
|
|
|
|
|
else:
|
|
|
|
|
params[key] = None
|
|
|
|
|
settings = {k: v.get("value", None) for k, v in setting_params.items()}
|
|
|
|
|
parameters = {**params, **settings}
|
|
|
|
|
entity = AgentToolEntity(
|
|
|
|
|
provider_id=tool.get("provider_name", ""),
|
|
|
|
|
provider_type=provider_type,
|
|
|
|
|
tool_name=tool.get("tool_name", ""),
|
|
|
|
|
tool_parameters=tool.get("parameters", {}),
|
|
|
|
|
tool_parameters=parameters,
|
|
|
|
|
plugin_unique_identifier=tool.get("plugin_unique_identifier", None),
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
@ -179,14 +196,27 @@ class AgentNode(ToolNode):
|
|
|
|
|
tool_runtime.entity.description.llm = (
|
|
|
|
|
extra.get("descrption", "") or tool_runtime.entity.description.llm
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
tool_value.append(
|
|
|
|
|
{
|
|
|
|
|
**tool_runtime.entity.model_dump(mode="json"),
|
|
|
|
|
"runtime_parameters": tool_runtime.runtime.runtime_parameters,
|
|
|
|
|
"provider_type": provider_type.value,
|
|
|
|
|
for params in tool_runtime.entity.parameters:
|
|
|
|
|
params.form = (
|
|
|
|
|
ToolParameter.ToolParameterForm.FORM
|
|
|
|
|
if params.name in manual_input_params
|
|
|
|
|
else params.form
|
|
|
|
|
)
|
|
|
|
|
if tool_runtime.entity.parameters:
|
|
|
|
|
manual_input_value = {
|
|
|
|
|
key: value for key, value in parameters.items() if key in manual_input_params
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
runtime_parameters = {
|
|
|
|
|
**tool_runtime.runtime.runtime_parameters,
|
|
|
|
|
**manual_input_value,
|
|
|
|
|
}
|
|
|
|
|
tool_value.append(
|
|
|
|
|
{
|
|
|
|
|
**tool_runtime.entity.model_dump(mode="json"),
|
|
|
|
|
"runtime_parameters": runtime_parameters,
|
|
|
|
|
"provider_type": provider_type.value,
|
|
|
|
|
}
|
|
|
|
|
)
|
|
|
|
|
value = tool_value
|
|
|
|
|
if parameter.type == "model-selector":
|
|
|
|
|
value = cast(dict[str, Any], value)
|
|
|
|
|
|