DDGS Metasearch via local MCP
v1.0.1Use a local DDGS MCP server (SSE) via mcporter to access fast web search tools (text/news/images/videos/books) without API keys. Use when user requests gener...
Like a lobster shell, security has layers — review code before you run it.
License
Runtime requirements
Install
brew install steipete/tap/mcporterSKILL.md
DDGS web search
Setup: install ddgs, run MCP server (SSE), optionally keep it as a daemon
It is recommended to enable built-in mcporter skill.
Install the Python package
python3 -m pip install -U ddgs
Run the DDGS MCP server (SSE)
Foreground (good for debugging):
ddgs api --host 127.0.0.1 --port 8000
Detached/background mode (convenient on a dev machine):
ddgs api -d --host 127.0.0.1 --port 8000
Stop the detached server:
ddgs api -s
Optional: systemd user service (always available)
Create ~/.config/systemd/user/ddgs.service:
[Unit]
Description=DDGS MCP SSE server
After=network-online.target
[Service]
Type=simple
ExecStart=%h/.local/bin/ddgs api --host 127.0.0.1 --port 8000
Restart=on-failure
RestartSec=2
[Install]
WantedBy=default.target
Then:
systemctl --user daemon-reload
systemctl --user enable --now ddgs
systemctl --user status ddgs --no-pager
Add the MCP server to mcporter
Add a named server pointing at the DDGS SSE endpoint:
mcporter config add ddgs http://127.0.0.1:8000/sse --allow-http
Verify it shows up:
mcporter config list ddgs
Then you can call tools as ddgs.<tool> (examples below).
Key idea:
- DDGS runs an MCP SSE endpoint at
http://127.0.0.1:8000/sse - mcporter connects to that endpoint and exposes tools like
ddgs.search_text_search_text_post
Defaults (use unless user says otherwise)
backend="duckduckgo"(most reliable)max_results=10(“SERP page 1”)region="us-en",safesearch="moderate"
Workflow
0) Preconditions / sanity
- Confirm DDGS server is up:
curl -s http://127.0.0.1:8000/health
- Confirm mcporter can see the server:
mcporter config list ddgs
If the server is down, either:
- start/restore it (if you have permission), or
- use fallback (
web_search).
1) Execution examples
Use mcporter to call DDGS tools and parse JSON.
Text search:
mcporter call ddgs.search_text_search_text_post \
query="<query>" max_results=10 backend="duckduckgo" region="us-en" safesearch="moderate" --json
News search:
mcporter call ddgs.search_news_search_news_post \
query="<query>" max_results=10 backend="bing" timelimit="w" --json
Images:
mcporter call ddgs.search_images_search_images_post \
query="<query>" max_results=10 backend="duckduckgo" region="us-en" safesearch="moderate" --json
Videos:
mcporter call ddgs.search_videos_search_videos_post \
query="<query>" max_results=10 backend="duckduckgo" region="us-en" safesearch="moderate" --json
Books:
mcporter call ddgs.search_books_search_books_post \
query="<query>" max_results=10 backend="annasarchive" --json
Available tools (via mcporter)
ddgs.search_text_search_text_postddgs.search_images_search_images_postddgs.search_news_search_news_postddgs.search_videos_search_videos_postddgs.search_books_search_books_post
Tool parameters
Common parameters (most endpoints):
query— the search string.max_results— cap results; default 10 (fast, “page 1”).backend— engine selector. Preferduckduckgofor reliability;bingas second choice; avoidgoogleon servers (403/captcha risk)region— locale for results (e.g.us-en,uk-uk).safesearch— content filtering (off|moderate|strict); defaultmoderate.
News-specific:
timelimit— recency filter (commonlyd,w,m,y).
Books-specific:
- recommended
backendisannasarchive.
Tip: when you need reproducibility, explicitly pass backend, region, safesearch, max_results even if they match defaults.
Troubleshooting
-
mcportersays server not found → you’re using a different config file; if you use a non-default config, pass--configpath from your system (default is~/.openclaw/workspace/config/mcporter.json). -
backend="google"often returns HTTP 403 in server environments → use another backend, e.g.duckduckgo/bing. -
Full API docs available locally at
http://localhost:8000/docs.
Files
1 totalComments
Loading comments…
