Paper Distill MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Paper Distill MCP ServerFind recent papers on LLM reasoning and sync the top results to Zotero"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
๐ Paper Distill MCP Server
Academic paper search, intelligent curation, and multi-platform delivery โ built on the Model Context Protocol.
Compatible with all MCP clients: Claude Desktop, Claude Code, Cursor, Trae, Codex CLI, Gemini CLI, OpenClaw, VS Code, Zed, and more.
โ ๏ธ Early development stage. Many features are still being validated and may contain bugs or instabilities. Feedback and bug reports are warmly welcome!
โจ Features
๐ 11-source parallel search โ OpenAlex, Semantic Scholar, PubMed, arXiv, Papers with Code, CrossRef, Europe PMC, bioRxiv, DBLP, CORE, Unpaywall
๐ค Adaptive AI delivery โ the agent tracks your evolving research interests and automatically refines search keywords and recommendations over time
๐ 4-dimensional weighted ranking โ relevance ร recency ร impact ร novelty, fully customizable weights
๐ฅ Dual-AI blind review โ two AI reviewers independently shortlist papers; a chief reviewer synthesizes a final push/overflow/discard decision (optional)
๐งน Scraper delegation โ offload abstract extraction to a low-cost agent or API to cut token spend significantly
๐ Personal paper library site โ Astro + Vercel auto-deploy; site updates within 30 seconds of each push
๐ฌ Multi-platform delivery โ Telegram / Discord / Feishu / WeCom
๐ฆ Zotero integration โ save papers to Zotero with one command
๐ Obsidian integration โ auto-generate paper note cards with Zotero backlinks; supports summary and template modes
๐ Quick Install
uvx paper-distill-mcpThat's it. Your AI client will discover all tools automatically. No API keys required for basic paper search.
No
uv? โcurl -LsSf https://astral.sh/uv/install.sh | shorbrew install uv
pip:
pip install paper-distill-mcpHomebrew:
brew tap Eclipse-Cj/tap
brew install paper-distill-mcpDocker:
docker run -i --rm ghcr.io/eclipse-cj/paper-distill-mcpFrom source (developers):
git clone https://github.com/Eclipse-Cj/paper-distill-mcp.git
cd paper-distill-mcp
python3 -m venv .venv && .venv/bin/pip install --upgrade pip && .venv/bin/pip install -e .๐ Connecting to AI Clients
Claude Desktop
Add to claude_desktop_config.json (Settings โ Developer โ Edit Config):
{
"mcpServers": {
"paper-distill": {
"command": "uvx",
"args": ["paper-distill-mcp"]
}
}
}Claude Code
claude mcp add paper-distill -- uvx paper-distill-mcpOr add to .mcp.json:
{
"mcpServers": {
"paper-distill": {
"command": "uvx",
"args": ["paper-distill-mcp"]
}
}
}Codex CLI (OpenAI)
Add to ~/.codex/config.toml:
[mcp_servers.paper-distill]
command = "uvx"
args = ["paper-distill-mcp"]Gemini CLI (Google)
Add to ~/.gemini/settings.json:
{
"mcpServers": {
"paper-distill": {
"command": "uvx",
"args": ["paper-distill-mcp"]
}
}
}OpenClaw
mcporter config add paper-distill --command uvx --scope home -- paper-distill-mcp
mcporter list # verifyTo remove:
mcporter config remove paper-distill
git clone https://github.com/Eclipse-Cj/paper-distill-mcp.git ~/.openclaw/tools/paper-distill-mcp
cd ~/.openclaw/tools/paper-distill-mcp
uv venv .venv && uv pip install .
mcporter config add paper-distill \
--command ~/.openclaw/tools/paper-distill-mcp/.venv/bin/python3 \
--scope home \
-- -m mcp_server.server
mcporter listTo remove:
rm -rf ~/.openclaw/tools/paper-distill-mcp && mcporter config remove paper-distill
Other clients (Cursor, VS Code, Windsurf, Zed, Trae)
Same JSON config, different config file paths:
Client | Config path |
Claude Desktop |
|
Trae | Settings โ MCP โ Add |
Cursor |
|
VS Code |
|
Windsurf |
|
Zed |
|
HTTP transport (remote / hosted)
paper-distill-mcp --transport http --port 8765๐ฏ Getting Started
After connecting your client, tell the agent "initialize paper-distill". It will call setup() and walk you through:
Research topics โ describe your interests in plain language; the AI extracts keywords
Delivery platform โ set up Telegram / Discord / Feishu / WeCom (optional)
Paper library site โ build a personal paper library that updates automatically (optional)
Scraper delegate โ point to a low-cost agent or API for abstract extraction (recommended)
Preferences โ paper count, ranking weights, review mode, etc.
First search โ
pool_refresh()populates the paper pool
All settings can be updated at any time through conversation:
"Push 8 papers next time"
"Add a new topic: RAG retrieval"
"Enable dual-AI blind review"
"Increase recency weight"
โ๏ธ Configuration Reference
All parameters are set via configure() or add_topic() โ no manual file editing needed.
Research Topics (add_topic / manage_topics)
Parameter | Description | Default |
| Topic identifier (e.g. | โ |
| Display name (e.g. | โ |
| Search keywords, 3โ5 recommended | โ |
| Topic priority 0.0โ1.0 (higher = more papers) |
|
| Temporarily disable without deleting |
|
Paper Count & Review (configure)
Parameter | Options | Default | Description |
| any integer |
| Papers per push |
|
|
| Count mode |
| any integer |
| Shortlist size per reviewer |
|
|
| Single AI or dual blind review |
| free text |
| Custom selection criteria |
๐ก Dual blind review: two independent AI reviewers each shortlist papers; a chief reviewer makes the final push/overflow/discard call. Papers that don't make the cut are held for the next cycle rather than discarded. Enable with
configure(review_mode="dual").
Ranking Weights (configure)
Controls paper scoring. The four weights should sum to approximately 1.0.
Parameter | Measures | Default |
| Keyword and topic match |
|
| How recently the paper was published |
|
| Citation count (log-normalized) |
|
| Whether this is the first appearance |
|
Example: "Prioritize recent papers" โ
configure(w_recency=0.35, w_relevance=0.40)
Scraper / Abstract Extraction Delegate (configure)
Abstract extraction is the most token-intensive step. It runs on the main agent by default, but can be delegated to a cheaper model to cut costs significantly.
Parameter | Value | Description |
|
| Main agent handles extraction (most expensive) |
agent name (e.g. | Delegate to a low-cost sub-agent | |
API URL | Call an external LLM API (DeepSeek, Ollama, etc.) |
๐ง Strongly recommended: for 30+ papers, frontier model costs add up fast. A $0.14/M-token model handles extraction just as well. Set this with
configure(summarizer="scraper").
Paper Pool & Scan Batches (configure)
Parameter | Description | Default |
| Split the paper pool into N batches, reviewed over N+1 days |
|
pool_refresh() searches all 11 APIs and fills the pool. The pool is then split into batches for daily AI review โ avoiding a single 60+ paper dump.
scan_batches=2(default): review first half on day 1, second half on day 2, finalize on day 3scan_batches=3: review one-third per day, finalize on day 4
When all batches are reviewed, the pool is exhausted and the next run triggers a fresh API search automatically.
Delivery Platforms (Environment Variables)
Platform | Environment variables |
|
Telegram |
|
|
Discord |
|
|
Feishu |
|
|
WeCom |
|
|
โ ๏ธ Important: set environment variables in the MCP client config
envfield, not as system environment variables. Otherwisesend_push()cannot access the webhook URL and the AI may generate scripts that call webhooks directly, causing encoding issues.
Config example (WeCom + Claude Desktop):
{
"mcpServers": {
"paper-distill": {
"command": "uvx",
"args": ["paper-distill-mcp"],
"env": {
"WECOM_WEBHOOK_URL": "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=YOUR_KEY"
}
}
}
}Restart the MCP client after editing the config.
Push message format (fixed):
1. Paper Title (Year)
Journal Name
- One-sentence summary
- Why it was selected
https://doi.org/...Paper Library Site (configure)
Personal paper library website, auto-updated on every push. Built on Astro + Vercel (free tier).
Parameter | Description |
| Vercel deploy hook URL (triggers site rebuild) |
| Local path to the paper-library repository |
Setup steps (the AI agent will guide you):
Create a repo from the paper-library-template
Connect to Vercel and deploy
Create a deploy hook in Vercel (Settings > Git > Deploy Hooks)
Tell the agent the hook URL โ saved via
configure(site_deploy_hook=...)
After setup, every finalize_review() call pushes the digest JSON to the site repo and triggers a Vercel rebuild. The site updates in ~30 seconds.
Zotero Integration
Save papers to Zotero with one command. Requires a Zotero account and API key.
Getting credentials:
API Key: go to zotero.org/settings/keys/new โ check "Allow library access" + "Allow write access" โ Save Key
Library ID: go to zotero.org/settings/keys โ your userID is shown at the top
Add to MCP client config:
{
"mcpServers": {
"paper-distill": {
"command": "uvx",
"args": ["paper-distill-mcp"],
"env": {
"ZOTERO_LIBRARY_ID": "your userID",
"ZOTERO_API_KEY": "your API key"
}
}
}
}After setup, reply collect 1 3 after a push to save papers 1 and 3 to Zotero, automatically sorted into per-topic folders.
All Environment Variables
Variable | Description | Required |
| Increases OpenAlex API rate limit; also used for Unpaywall | optional |
| CORE API key (free registration) | optional |
| Enhanced search via DeepSeek | optional |
| Save papers to Zotero | optional |
| Paper library website URL | optional |
| Data directory | default: |
๐ ๏ธ Tools (19 total)
Setup & Configuration
Tool | Description |
| First call โ detects fresh install and returns guided initialization instructions |
| Add a research topic with search keywords |
| Update any setting: paper count, ranking weights, review mode, etc. |
Search & Curation
Tool | Description |
| Parallel search across 11 sources |
| 4-dimensional weighted scoring |
| Deduplicate against previously pushed papers |
Daily Pipeline (paper pool mode)
Tool | Description |
| Search all 11 APIs and build the paper pool |
| Generate AI abstract extraction prompt |
| Generate review prompt โ AI makes push/overflow/discard decisions |
| Process AI decisions, update pool, output push message |
| Pool status: count, scan day, exhausted or not |
| Save papers to Zotero + generate Obsidian notes |
Session & Output
Tool | Description |
| Detect delivery platform and load research context |
| Load historical research context |
| Generate output files (JSONL, site, Obsidian) |
| Deliver to Telegram / Discord / Feishu / WeCom |
| Save to Zotero via DOI |
| List / disable / enable / reweight topics |
| Inherit research context across sessions |
๐๏ธ Architecture
AI client (Claude Code / Codex CLI / Gemini CLI / Cursor / ...)
โ MCP (stdio or HTTP)
paper-distill-mcp
โโโ search/ โ 11-source academic search (with OA full-text enrichment)
โโโ curate/ โ scoring + deduplication
โโโ generate/ โ output (JSONL, Obsidian, site)
โโโ bot/ โ push formatting (4 platforms)
โโโ integrations/ โ Zotero APIThe server does not call any LLM internally. Search, ranking, and deduplication are pure data operations. Intelligence comes from your AI client.
๐ Paywalled Papers & Open Access
The system searches all papers by default (including subscription journals) and maximizes free full-text access through:
CORE โ world's largest OA aggregator (200M+ papers), covering author self-archived versions from institutional repositories
Unpaywall โ after merging results, automatically looks up legal free PDFs via DOI (preprints, green OA, author versions)
For papers with no free version, the system returns a DOI link. If you have institutional VPN access, clicking the DOI link while connected is usually enough โ publishers identify your institution by IP.
open_access_urlpriority: arXiv > CORE > Unpaywall > OpenAlex > Semantic Scholar > Papers with Code
โ FAQ
Review stage hangs / no response for 30+ minutes
Symptom: the review prompt generated by prepare_review() causes the AI client to hang or time out.
Cause: too many candidate papers in the pool (e.g. 80โ100), making the prompt exceed the client's context window or output token limit. VS Code Copilot and some IDE plugins have limited context capacity.
Solutions (pick one):
Increase
scan_batches(recommended) โ split the pool into more batches:configure(scan_batches=5)Reduce topics or keywords โ fewer topics โ fewer search results โ smaller pool.
Switch to a higher-context client โ Claude Code (200k), Claude Desktop (200k), or Cursor handle long prompts better.
Install error: Requires-Python >=3.10
Python 3.10+ is required. macOS ships with Python 3.9 by default โ install a newer version with brew install python@3.13 or use uv.
Docker image fails to pull (mainland China)
ghcr.io is blocked in mainland China. Use pip with a Chinese mirror:
pip install paper-distill-mcp -i https://pypi.tuna.tsinghua.edu.cn/simple๐งโ๐ป Development
git clone https://github.com/Eclipse-Cj/paper-distill-mcp.git
cd paper-distill-mcp
python3 -m venv .venv && .venv/bin/pip install --upgrade pip && .venv/bin/pip install -e .
python tests/test_mcp_smoke.py # 9 tests, no network required๐ License
This project is licensed under AGPL-3.0. See LICENSE for details.
Unauthorized commercial use is prohibited. For commercial licensing inquiries, contact the author.
๐ฌ Contact
Email: vertex.cj@gmail.com
GitHub Issues: Eclipse-Cj/paper-distill-mcp/issues
Bug reports and feature requests are welcome. The project is in active early development โ thank you for your patience and support ๐
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/Eclipse-Cj/paper-distill-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server