|
|
|
|
@ -4,7 +4,9 @@ from typing import Any, Optional
|
|
|
|
|
from core.plugin.manager.tool import PluginToolManager
|
|
|
|
|
from core.tools.__base.tool import Tool
|
|
|
|
|
from core.tools.__base.tool_runtime import ToolRuntime
|
|
|
|
|
from core.tools.entities.file_entities import PluginFileEntity
|
|
|
|
|
from core.tools.entities.tool_entities import ToolEntity, ToolInvokeMessage, ToolParameter, ToolProviderType
|
|
|
|
|
from models.model import File
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class PluginTool(Tool):
|
|
|
|
|
@ -29,6 +31,23 @@ class PluginTool(Tool):
|
|
|
|
|
message_id: Optional[str] = None,
|
|
|
|
|
) -> Generator[ToolInvokeMessage, None, None]:
|
|
|
|
|
manager = PluginToolManager()
|
|
|
|
|
|
|
|
|
|
# convert tool parameters with File type to PluginFileEntity
|
|
|
|
|
for parameter_name, parameter in tool_parameters.items():
|
|
|
|
|
if isinstance(parameter, File):
|
|
|
|
|
url = parameter.generate_url()
|
|
|
|
|
if url is None:
|
|
|
|
|
raise ValueError(f"File {parameter.id} does not have a valid URL")
|
|
|
|
|
tool_parameters[parameter_name] = PluginFileEntity(url=url).model_dump()
|
|
|
|
|
elif isinstance(parameter, list) and all(isinstance(p, File) for p in parameter):
|
|
|
|
|
tool_parameters[parameter_name] = []
|
|
|
|
|
for p in parameter:
|
|
|
|
|
assert isinstance(p, File)
|
|
|
|
|
url = p.generate_url()
|
|
|
|
|
if url is None:
|
|
|
|
|
raise ValueError(f"File {p.id} does not have a valid URL")
|
|
|
|
|
tool_parameters[parameter_name].append(PluginFileEntity(url=url)).model_dump()
|
|
|
|
|
|
|
|
|
|
return manager.invoke(
|
|
|
|
|
tenant_id=self.tenant_id,
|
|
|
|
|
user_id=user_id,
|
|
|
|
|
@ -36,6 +55,9 @@ class PluginTool(Tool):
|
|
|
|
|
tool_name=self.entity.identity.name,
|
|
|
|
|
credentials=self.runtime.credentials,
|
|
|
|
|
tool_parameters=tool_parameters,
|
|
|
|
|
conversation_id=conversation_id,
|
|
|
|
|
app_id=app_id,
|
|
|
|
|
message_id=message_id,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
def fork_tool_runtime(self, runtime: ToolRuntime) -> "PluginTool":
|
|
|
|
|
|