PowerSearch MCP helps AI agents search and retrieve content from the public web with fewer broken fetches and clean, AI-friendly outputs ready to cite.
Project description
PowerSearch MCP
PowerSearch MCP helps AI agents search and retrieve content from the public web with fewer broken fetches and clean, AI-friendly outputs ready to cite.
TL;DR
Step 1: Clone the repository then run initialize the virtual environment:
git clone https://github.com/theobjectivedad/powersearch-mcp.git
Step 2: Initialize the virtual environment:
cd powersearch-mcp
make init
Step 3: Activate the virtual environment:
source .venv/bin/activate
Step 4: Create a .env file with your desired configuration, use example-configs/example.env as a starting point.
cp example-configs/example.env .env
Step 5: (Optional) run a local instance of SearXNG:
docker run -d \
--name searxng-local \
--pull=always \
--restart unless-stopped \
-p 127.0.0.1:9876:8080 \
--tmpfs /etc/searxng:rw,noexec,nosuid,size=16m \
--tmpfs /tmp:rw,noexec,nosuid,size=512m \
--cap-drop=ALL \
--security-opt=no-new-privileges:true \
--health-cmd='python3 -c "import urllib.request; urllib.request.urlopen(\"http://127.0.0.1:8080/\", timeout=3).read(1)"' \
--health-interval=10s \
--health-timeout=3s \
--health-retries=10 \
--health-start-period=15s \
--env SEARXNG_SETTINGS_PATH=/settings.yml \
--volume "$(pwd)/searxng.yaml:/settings.yml:ro" \
searxng/searxng
Step 6: Run PowerSearch via FastMCP:
fastmcp run \
src/powersearch_mcp/app.py \
--transport=streamable-http \
--skip-source \
--skip-env
Step 7: Point your AI agent at http://localhost:8099/mcp to start searching the web!
Feature Roadmap
- ✅ SearXNG-backed meta search with configurable engines, language, safe-search, and pagination
- ✅ Strong anti-bot fetching implementation via Scrapling and Camoufox
- ✅ Search response caching at the tool-level to memory, disk, and Redis storage backends
- ✅ Automatic retries with exponential backoff for both search and fetch operations
- ✅ AI Agent-friendly responses: HTML pages are converted to markdown automatically via Trafilatura
- ✅ Support for STDIO and streaming HTTP transports
- ✅ Health check endpoint for HTTP transport
- ✅ Extensive configuration suitable for many deployment scenarios
- ✅ Authentication support for both JWT and opaque tokens
- ✅ Authorization support for embedded Eunomia policies
- ✅ Auto summarization of search results via MCP sampling
- ✅ Optional server-side fallback for clients that don't support MCP sampling
- ✅ Public Docker image on Docker Hub
- 🗓️ (Future) Client selectable synchronous (current behavior) or asynchronous SEP-1686 execution for search / fetch tools
- 🗓️ (Future) Prometheus metrics exporter
- 🗓️ (Future) Helm chart
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file powersearch_mcp-0.4.0.tar.gz.
File metadata
- Download URL: powersearch_mcp-0.4.0.tar.gz
- Upload date:
- Size: 25.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ecd957aae2eb3668ec105ca3eb36b673aee954e15d8d3516042cf3604d965c1c
|
|
| MD5 |
3efa15c1df1bd3a67487387ec9bb09ec
|
|
| BLAKE2b-256 |
1b060f499d72e78295cebc504e3a7c9837d07161142843c12bab22c77c1396fa
|
File details
Details for the file powersearch_mcp-0.4.0-py3-none-any.whl.
File metadata
- Download URL: powersearch_mcp-0.4.0-py3-none-any.whl
- Upload date:
- Size: 27.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bfdb33f9247d3d46c8885dfc4d07e31efa50351e3ba6ed872db670e8b074a5f6
|
|
| MD5 |
2d624fbfe0ba0e2b57e6b3aa86015c78
|
|
| BLAKE2b-256 |
325a79b2974003fbff03ce1692a0ba0a38fa940512477ebc19e3882eb57a3f51
|