In the current agentUniverse's sample project, the following tools are integrated.
Tool Path
Detailed Configuration Information:
name: 'google_search_tool'
description: |
This tool can be used to perform Google searches. The tool's input is the content you want to search for.
Example inputs for the tool:
Example 1: If you want to search for the weather in Shanghai, the tool's input should be: "Shanghai weather today"
Example 2: If you want to search for the weather in Japan, the tool's input should be: "Japan weather"
tool_type: 'api'
input_keys: ['input']
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.google_search_tool'
class: 'GoogleSearchTool'
To use this API, you must apply for a BING_SUBSCRIPTION_KEY at https://serper.dev and configure it in your environment variables. Configuration method:
- Configure via Python code You must configure: SERPER_API_KEY
import os
os.environ['SERPER_API_KEY'] = 'xxxx'
- Configure via configuration file In the custom_key.toml file located in the config directory of the project, add the configuration:
SERPER_API_KEY="xxxx"
Currently, it integrates with the official Bing search.
Tool Path
Tool configuration:
name: 'bing_search_tool'
description: 'demo bing search tool'
tool_type: 'api'
input_keys: ['input']
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.bing_search_tool'
class: 'BingSearchTool'
To use this API, you must apply for BING_SUBSCRIPTION_KEY and configure it in environment variables. Configuration method:
- Configure through Python code Mandatory configuration: BING_SUBSCRIPTION_KEY
import os
os.environ['BING_SUBSCRIPTION_KEY'] = 'xxxx'
- Configure through configuration file In custom_key.toml under config directory of the project, add configuration:
BING_SUBSCRIPTION_KEY="xxxx"
Supports multiple search tools, such as:
- Baidu search
- Bing search
Other search engines also include: Google search, Amazon search, YouTube search, etc. For more information, please refer to: https://www.searchapi.io/ Tool configuration:
name: 'search_api_baidu_tool'
description: 'Baidu (Bing) search tool, input is a string of content to be searched, e.g.: input="What is the price of gold?"'
tool_type: 'api'
input_keys: ['input']
engine: 'baidu'
search_type: 'json'
search_params:
num: 10
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.search_api_tool'
class: 'SearchAPITool'
Parameter description:
search_type: Represents the format of the expected search results, where json represents the expectation for JSON format and common represents the expectation for string format. search_params: Represents additional parameters that need to be passed to the search engine, such as in Baidu search, num represents the number of returned search results, detailed parameters need to be referenced at [https://www.searchapi.io/]. engine: The search engine you expect to use, including baidu, google, bing, amazon, youtube, ... To use this API, you must apply for SEARCH_API_KEY from the official website ([https://www.searchapi.io/]) and configure it in environment variables. Configuration method: You must configure:SEARCHAPI_API_KEY
- Configure via Python code :
import os
os.environ['SEARCHAPI_API_KEY'] = 'xxxxxx'
- Configure through configuration file Add configuration in custom_key.toml under the config directory of the project:
SEARCHAPI_API_KEY="xxxxxx"
Tool Path
This tool can execute a piece of Python code, the configuration information of the tool:
name: 'python_runner'
description: 'The tool can execute Python code, which can be directly run in PyCharm. The input to the tool must be valid Python code. If you want to view the execution result of the tool, you must use print(...) to print the content you want to view in the Python code.
Example of tool input:
When you want to calculate what 1 + 3 equals, the input to the tool should be:
```py
print(1+3)
```
When you want to get information about the Baidu page, the input to the tool should be:
```py
import requests
resp=requests.get("https://www.baidu.com")
print(resp.content)
```'
tool_type: 'api'
input_keys: ['input']
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.python_repl'
class: 'PythonREPLTool'
This tool can be used directly without any key, but for system security, please do not use this tool in production environments.
Tool Path The tool can send a GET request, with its configuration information being:
name: 'requests_get'
description: 'A portal to the internet. Use this when you need to get specific
content from a website. Input should be a url (i.e. https://www.google.com).
The output will be the text response of the GET request.
```'
headers:
content-type: 'application/json'
method: 'GET'
json_parser: false
response_content_type: json
tool_type: 'api'
input_keys: ['input']
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.request_tool'
class: 'RequestTool'
Configuration to Refer to When Sending a POST Request:
name: 'requests_post'
# description copy from langchain RequestPOSTTool
description: 'Use this when you want to POST to a website.
Input should be a json string with two keys: "url" and "data".
The value of "url" should be a string, and the value of "data" should be a dictionary of
key-value pairs you want to POST to the url.
Be careful to always use double quotes for strings in the json string
The output will be the text response of the POST request.
```'
headers:
content-type: 'application/json'
method: 'POST'
json_parser: true
response_content_type: json
tool_type: 'api'
input_keys: ['input']
metadata:
type: 'TOOL'
module: 'sample_standard_app.intelligence.agentic.tool.request_tool'
class: 'RequestTool'
Parameter Description: method: the method of the request, such as GET, POST, PUT, etc. headers: the HTTP headers neccessary for sending the request. json_parse: indicates whether the input parameters should be serialized as JSON and sent in the request body (True for POST requests) or not (False for GET requests, where parameters are typically sent as a query string). response_content_type: the output format for the HTTP request result. If set to 'json', the result will be returned in JSON format; if set to 'text', it will be returned as plain text. This tool can be used directly without requiring any keys.