ToolServer is the server provide XAgent with powerful and safe tools to solve tasks. It is a docker container that provides a safe environment for XAgent to run.
ToolServer is composed of three parts:
- ToolServerManager is responsible for creating and managing ToolServerNode instances.
- ToolServerMonitor is responsible for monitoring the status of ToolServerNode instances. Automatic detect instances status and removing the instances that are not working properly.
- ToolServerNode is responsible for providing tools to solve tasks. It is a docker container that provides a safe environment for XAgent to run.
Currently, ToolServer provides the following tools:
- 📝 File Editor provide a text editing tool that can write, read, and modify files.
- 📘 Python Notebook provide a interactive python notebook that can run python code to validate ideas, draw figures, etc.
- 🌏 Web Browser provide a web browser that can search and visit webpages.
- 🖥️ Shell provide a bash shell tool that can execute any shell commands, even install programs and host services.
- 🧩 Rapid API provide a tool to retrieve apis from Rapid API and calling them, which provides a wide range of apis for XAgent to use. See ToolBench to get more information about the Rapid API collections. You can also easily add new tools to ToolServer to enhance agent's abilities.
Configurations for ToolServer are stored in ToolServer/config/
. You can change them and rebuild images to apply the changes.
Notes:
- Change
node.privileged
tofalse
inmanager.yml
if you don't want to used docker in ToolServerNode. This will disable the ability to run docker commands in ToolServerNode. - Change
idling_close_minutes
inmonitor.yml
to change the time that ToolServerMonitor will wait before closing idle ToolServerNode instances. - Add your api keys in
node.yml
to enable bing search (or use backup search duckduckgo) and rapid api. - Change api timeout for Toolserver in
docker-compose.yml
by altering values after-t
inservices.ToolServerManager.command
if you encounter timeout error of ToolServer.
All docker image build files are stored in ToolServer/dockerfiles
.
You can build them manually with following command:
cd ToolServer
docker-compose build
This will build all the docker images for ToolServerManager, ToolServerMonitor and ToolServerNode.
After building the docker images, you can start the docker container with following command:
cd ToolServer
docker-compose up
Note that you should install docker
and docker-compose
first.
This path will return a cookie that contains the node_id of the ToolServerNode instance. All the following requests should use this cookie to identify the ToolServerNode instance.
This path will return all registered tools in ToolServerNode, together with their parameters.
{
"available_envs":[
{
"name":"env1",
"description":"description1",
"tools":["tool1","tool2"] //at most 50 tools, the rest will not be returned
},
],
"available_tools":[
"tool1",
"tool2", //hidden tools will not be returned
],
"tools_json":[
{
"name":"tool1",
"description":"description1",
"parameters":{
"type":"object",
"properties":{
"param1":{
"type":"string",
"description":"description1"
},
"param2":{
"type":"integer",
"description":"description2"
}
},
"required":["param1","param2"]
}
},
]
}
Giving a question, return related tools. Rapid API will also be returned. Arguments:
{
"question":"question",
"top_k":10
}
Return:
{
"retrieved_tools":[
"tool1",
"tool2"
],
"tools_json":[
{
//tool1 json
},
{
//tool2 json
}
]
}
Return the json schema for the given tools. Arguments:
{
"tools":["tool1","tool2"]
}
Return:
{
"tools_json":[
{
//tool1 json
},
{
//tool2 json
}
],
"missing_tools":[
]
}
Return the json schema for the given envs. Arguments:
{
"envs":["env1","env2"]
}
Return:
{
"envs_json":[
{
"name":"env1",
"description":"description1",
"tools":["tool1","tool2"]
}
],
"missing_envs":[
]
}
Execute the given tool with the given parameters. Arguments:
{
"tool":"tool1",
"parameters":{
"param1":"value1",
"param2":"value2"
}
}
Return is dependent on the tool. The return http code 450 standfor need further calling to finish tool execution. When return http code 450, the return value will be like:
{
"detail":{
"type":"retry",
"next_calling":"ShellEnv_read_stdout",
"arguments":{}
}
}
Close the ToolServerNode instance.
Close and delete ToolServerNode instance.