feat: enhance execute method to support mcp_tool_id and mcp_source parameters

--bug=1060726 --user=刘瑞斌 【工具】应用中引用的MCP没删除后,在应用对话界面依然可以调用MCP的工具 https://www.tapd.cn/62980211/s/1759963
This commit is contained in:
CaptainB 2025-08-22 14:32:59 +08:00
parent c3001ffd2d
commit c8e8afa8b9
2 changed files with 22 additions and 14 deletions

View File

@ -9,16 +9,12 @@ from application.flow.i_step_node import INode, NodeResult
class McpNodeSerializer(serializers.Serializer):
mcp_servers = serializers.JSONField(required=True,
label=_("Mcp servers"))
mcp_server = serializers.CharField(required=True,
label=_("Mcp server"))
mcp_servers = serializers.JSONField(required=True, label=_("Mcp servers"))
mcp_server = serializers.CharField(required=True, label=_("Mcp server"))
mcp_tool = serializers.CharField(required=True, label=_("Mcp tool"))
tool_params = serializers.DictField(required=True,
label=_("Tool parameters"))
mcp_tool_id = serializers.UUIDField(required=False, label=_("Mcp tool"), allow_null=True)
mcp_source = serializers.CharField(required=False, label=_("Mcp source"), allow_blank=True, allow_null=True)
tool_params = serializers.DictField(required=True, label=_("Tool parameters"))
class IMcpNode(INode):
@ -30,5 +26,5 @@ class IMcpNode(INode):
def _run(self):
return self.execute(**self.node_params_serializer.data, **self.flow_params_serializer.data)
def execute(self, mcp_servers, mcp_server, mcp_tool, tool_params, **kwargs) -> NodeResult:
def execute(self, mcp_servers, mcp_server, mcp_tool, mcp_tool_id, mcp_source, tool_params, **kwargs) -> NodeResult:
pass

View File

@ -3,10 +3,12 @@ import asyncio
import json
from typing import List
from django.db.models import QuerySet
from langchain_mcp_adapters.client import MultiServerMCPClient
from application.flow.i_step_node import NodeResult
from application.flow.step_node.mcp_node.i_mcp_node import IMcpNode
from tools.models import Tool
class BaseMcpNode(IMcpNode):
@ -15,10 +17,20 @@ class BaseMcpNode(IMcpNode):
self.context['tool_params'] = details.get('tool_params')
self.context['mcp_tool'] = details.get('mcp_tool')
def execute(self, mcp_servers, mcp_server, mcp_tool, tool_params, **kwargs) -> NodeResult:
servers = json.loads(mcp_servers)
params = json.loads(json.dumps(tool_params))
params = self.handle_variables(params)
def execute(self, mcp_servers, mcp_server, mcp_tool, mcp_tool_id, mcp_source, tool_params,**kwargs) -> NodeResult:
if mcp_source == 'referencing':
if not mcp_tool_id:
raise ValueError("MCP tool ID is required when mcp_source is 'referencing'.")
tool = QuerySet(Tool).filter(id=mcp_tool_id).first()
if not tool:
raise ValueError(f"Tool with ID {mcp_tool_id} not found.")
servers = json.loads(tool.code)
params = json.loads(json.dumps(tool_params))
params = self.handle_variables(params)
else:
servers = json.loads(mcp_servers)
params = json.loads(json.dumps(tool_params))
params = self.handle_variables(params)
async def call_tool(t, a):
client = MultiServerMCPClient(servers)