src.tools.implementations.duck_tool.DuckDuckGoSearchTool
Bases: BaseRESTTool
A tool for searching the web using DuckDuckGo.
This tool sends search queries to DuckDuckGo's HTML interface and extracts search results, including titles, snippets, and URLs. It returns up to 5 search results formatted in Markdown.
Attributes:
Name | Type | Description |
---|---|---|
name |
str
|
The name of the tool, used for registry and invocation. |
description |
str
|
Human-readable description of the tool's purpose. |
parameters |
dict
|
JSON schema for the tool's parameters. |
Source code in src/tools/implementations/duck_tool.py
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 |
|
__init__(config=None)
Initialize the DuckDuckGo Search Tool.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
config
|
Optional[Dict]
|
Configuration options for the tool, which will override the default configuration. |
None
|
Returns:
Type | Description |
---|---|
None |
Source code in src/tools/implementations/duck_tool.py
29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
|
execute(context=None, **kwargs)
async
Execute a DuckDuckGo search.
This method takes a query parameter and searches DuckDuckGo for relevant results, then formats them for display.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
context
|
Optional[StreamContext]
|
Execution context for the tool. |
None
|
**kwargs
|
Keyword arguments containing the search parameters. Required: query (str): The search query to send to DuckDuckGo. |
{}
|
Returns:
Name | Type | Description |
---|---|---|
ToolResponse |
ToolResponse
|
A response object containing the search results formatted in Markdown. |
Raises:
Type | Description |
---|---|
ValueError
|
If the required 'query' parameter is missing. |
Source code in src/tools/implementations/duck_tool.py
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 |
|
parse_output(output)
Parse the raw output from DuckDuckGo.
This method processes the HTML response from DuckDuckGo to extract relevant information. In this implementation, it is not directly used as the parsing is done in the _search_duckduckgo method for better error handling and control.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
output
|
str
|
The raw HTML response from DuckDuckGo. |
required |
Returns:
Name | Type | Description |
---|---|---|
str |
str
|
Processed output as a string. |
Note
This method is required to implement the BaseRESTTool abstract class, but in this implementation, the actual parsing is done in _search_duckduckgo.
Source code in src/tools/implementations/duck_tool.py
93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 |
|