Skip to main content

Zero-auth multi-source research MCP server — web, GitHub, Hacker News, Stack Overflow, arXiv, Semantic Scholar, YouTube transcripts, and more.

Project description

openresearch-mcp

PyPI version Python versions License CI

Zero-auth multi-source research MCP server. Works with Claude Desktop, Cursor, OpenCode, Open WebUI, or any MCP-compatible agent — no API keys required.

Tools

Tool Source Notes
web_search DuckDuckGo Optional site= param to scope to a domain (e.g. arxiv.org)
read_url Any webpage Strips nav/scripts, returns clean text
read_pdf Any PDF or arXiv Accepts /abs/, /pdf/, /html/ arXiv URLs interchangeably
search_openalex OpenAlex 250M+ works, zero rate limiting; set OPENALEX_EMAIL for polite pool
search_hacker_news HN via Algolia Story search with points + comment counts
search_stackoverflow Stack Overflow API Set STACKEXCHANGE_KEY for higher quota
read_repo GitHub public repos README + file tree + key docs; set GITHUB_TOKEN for 5k req/hr
get_youtube_transcript YouTube captions Accepts full URLs, youtu.be/ links, shorts, or bare video IDs

Install

# Recommended — zero install, always isolated
uvx openresearch-mcp

# Or install globally with pip
pip install openresearch-mcp
openresearch-mcp

By default the server starts on http://0.0.0.0:8000/mcp (Streamable HTTP, MCP 1.1+).

Update

uvx --refresh openresearch-mcp

With pip:

pip install --upgrade openresearch-mcp

Connect to an MCP client

Claude Desktop

Edit ~/Library/Application Support/Claude/claude_desktop_config.json
(Windows: %APPDATA%\Claude\claude_desktop_config.json)

{
  "mcpServers": {
    "openresearch": {
      "command": "uvx",
      "args": ["openresearch-mcp"],
      "env": { "MCP_TRANSPORT": "stdio" }
    }
  }
}

Restart Claude Desktop after saving. The server runs in stdio mode — no port needed.

Cursor

Create or edit ~/.cursor/mcp.json (global) or .cursor/mcp.json (per-project):

{
  "mcpServers": {
    "openresearch": {
      "command": "uvx",
      "args": ["openresearch-mcp"],
      "env": { "MCP_TRANSPORT": "stdio" }
    }
  }
}

HTTP agents (OpenCode, Open WebUI, custom)

Start the server:

uvx openresearch-mcp
# or: openresearch-mcp

Point your agent at:

http://localhost:8000/mcp

Optional env vars

All tools work without any keys. Set these to increase rate limits:

Variable Effect
GITHUB_TOKEN GitHub: 60 → 5,000 req/hr
OPENALEX_EMAIL OpenAlex polite pool (higher limits)
STACKEXCHANGE_KEY Stack Overflow: higher daily quota

Example with keys:

GITHUB_TOKEN=ghp_... OPENALEX_EMAIL=you@example.com uvx openresearch-mcp

Or in Claude Desktop config:

{
  "mcpServers": {
    "openresearch": {
      "command": "uvx",
      "args": ["openresearch-mcp"],
      "env": {
        "MCP_TRANSPORT": "stdio",
        "GITHUB_TOKEN": "ghp_...",
        "OPENALEX_EMAIL": "you@example.com"
      }
    }
  }
}

Health check

When running in HTTP mode, check which sources are reachable:

curl http://localhost:8000/health
{
  "status": "ok",
  "sources": {
    "duckduckgo":    { "status": "ok", "latency_ms": 173 },
    "github":        { "status": "ok", "latency_ms": 101 },
    "hacker_news":   { "status": "ok", "latency_ms": 308 },
    "stackoverflow": { "status": "ok", "latency_ms": 247 },
    "openalex":      { "status": "ok", "latency_ms": 412 },
    "youtube":       { "status": "ok", "latency_ms": 320 }
  }
}

status is "ok", "degraded" (some sources down), or "down" (all unreachable). HTTP 200 / 503.

Known limitations

  • Reddit / Zenodo: block unauthenticated scraping — not included
  • YouTube: rate-limited at scale; works well for personal/low-volume use

Roadmap

  • Reddit OAuth (browser-based, no user key management)
  • GitHub Device Flow login
  • PubMed / NCBI (optional key)
  • NewsAPI support (optional key)

License

Apache 2.0

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

openresearch_mcp-0.1.3.tar.gz (113.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

openresearch_mcp-0.1.3-py3-none-any.whl (16.4 kB view details)

Uploaded Python 3

File details

Details for the file openresearch_mcp-0.1.3.tar.gz.

File metadata

  • Download URL: openresearch_mcp-0.1.3.tar.gz
  • Upload date:
  • Size: 113.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for openresearch_mcp-0.1.3.tar.gz
Algorithm Hash digest
SHA256 842b98ab38d8c3b8fc6fa0a4c48e2a62e96c262898d93111d4d6672991717c46
MD5 ab59adad17f651f96d1e04d024d74387
BLAKE2b-256 2ebb1762268c90486672e175b5a17fc1eb337400b666bbdc9cc3d2f267087a98

See more details on using hashes here.

Provenance

The following attestation bundles were made for openresearch_mcp-0.1.3.tar.gz:

Publisher: release.yml on olanokhin/openresearch-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file openresearch_mcp-0.1.3-py3-none-any.whl.

File metadata

File hashes

Hashes for openresearch_mcp-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 59b1121ce631f3f5d8cd4beeafbc086cf05660b4cc5ab75e3b076d3032cdfb02
MD5 e0d1a6c1bbc4f2bcedb09d3d895eab10
BLAKE2b-256 7a1b5c52ed68da4f7f6b06091d2b65fb0c62b1b9c598a72a90fda3d234aa16a1

See more details on using hashes here.

Provenance

The following attestation bundles were made for openresearch_mcp-0.1.3-py3-none-any.whl:

Publisher: release.yml on olanokhin/openresearch-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page