Install
openclaw skills install websearch-ddgs-mcpUse 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 general web search, especially in automated/cron runs, images search, news search, videos search, books search.
openclaw skills install websearch-ddgs-mcpddgs, run MCP server (SSE), optionally keep it as a daemonIt is recommended to enable built-in mcporter skill.
python3 -m pip install -U ddgs
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
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 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:
http://127.0.0.1:8000/sseddgs.search_text_search_text_postbackend="duckduckgo" (most reliable)max_results=10 (“SERP page 1”)region="us-en", safesearch="moderate"curl -s http://127.0.0.1:8000/healthmcporter config list ddgsIf the server is down, either:
web_search).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
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_postCommon parameters (most endpoints):
query — the search string.max_results — cap results; default 10 (fast, “page 1”).backend — engine selector. Prefer duckduckgo for reliability; bing as second choice; avoid google on servers (403/captcha risk)region — locale for results (e.g. us-en, uk-uk).safesearch — content filtering (off|moderate|strict); default moderate.News-specific:
timelimit — recency filter (commonly d, w, m, y).Books-specific:
backend is annasarchive.Tip: when you need reproducibility, explicitly pass backend, region, safesearch, max_results even if they match defaults.
mcporter says server not found → you’re using a different config file; if you use a non-default config, pass --config path 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.