Labsco
blazickjp logo

arXiv MCP Server

β˜… 2,900

from blazickjp

Search and analyze academic papers on arXiv.

πŸ”₯πŸ”₯πŸ”₯βœ“ VerifiedFreeQuick setup

ArXiv MCP Server

πŸ” Enable AI assistants to search and access arXiv papers through a simple MCP interface.

The ArXiv MCP Server provides a bridge between AI assistants and arXiv's research repository through the Model Context Protocol (MCP). It allows AI models to search for papers and access their content in a programmatic way.

🀝 Contribute β€’ πŸ“ Report Bug

✨ Core Features

  • πŸ”Ž Paper Search: Query arXiv papers with filters for date ranges and categories

  • πŸ“„ Paper Access: Download and read paper content

  • πŸ“‹ Paper Listing: View all downloaded papers

  • πŸ—ƒοΈ Local Storage: Papers are saved locally for faster access

  • πŸ“ Prompts: A set of research prompts for paper analysis

πŸ”’ Security

Prompt Injection Risk

Paper content retrieved from arXiv is untrusted external input.

When an AI assistant downloads or reads a paper through this server, the paper's text is passed directly into the model's context. A maliciously crafted paper could embed adversarial instructions designed to hijack the AI's behavior β€” for example, instructing it to exfiltrate data, invoke other tools with unintended arguments, or override system-level instructions. This is a known class of attack described by OWASP as LLM01: Prompt Injection and by the OWASP Agentic AI framework as AG01: Prompt Injection in LLM-Integrated Systems.

Recommended Mitigations

  • Use read-only MCP configurations β€” where possible, configure the MCP client so that the arxiv-mcp-server cannot trigger write operations or invoke other tools on your behalf.

  • Review paper content before acting on AI summaries β€” if an AI summary asks you to run commands or visit external URLs that were not part of your original request, treat that as a red flag.

  • Be cautious in multi-tool setups β€” agentic pipelines that combine this server with filesystem, shell, or browser tools are higher risk; a prompt injection in a paper could chain tool calls unexpectedly.

  • Treat AI-generated summaries as data, not instructions β€” always apply human judgment before executing any action the AI recommends after reading a paper.

References

πŸ”’ Security Note

arXiv papers are user-generated, untrusted content. Paper text returned by this server may contain prompt injection attempts β€” crafted text designed to manipulate an AI assistant's behavior. Treat all paper content as untrusted input.

In production environments, apply appropriate sandboxing and avoid feeding raw paper content into agentic pipelines that have access to sensitive tools or data without review. See SECURITY.md for the full security policy.

πŸ’‘ Available Tools

Core Workflow

The typical workflow for deep paper research is:

Copy & paste β€” that's it
search_papers β†’ download_paper β†’ read_paper

list_papers shows what you have locally. semantic_search searches across your local collection.

1. Paper Search

Search arXiv with optional category, date, and boolean filters. Enforces arXiv's 3-second rate limit automatically. If rate limited, wait 60 seconds before retrying.

Copy & paste β€” that's it
result = await call_tool("search_papers", {
 "query": "\"KAN\" OR \"Kolmogorov-Arnold Networks\"",
 "max_results": 10,
 "date_from": "2024-01-01",
 "categories": ["cs.LG", "cs.AI"],
 "sort_by": "date" # or "relevance" (default)
})

Supported categories include cs.AI, cs.LG, cs.CL, cs.CV, cs.NE, stat.ML, math.OC, quant-ph, eess.SP, and more. See tool description for the full list.

2. Paper Download

Download a paper by its arXiv ID. Tries HTML first, falls back to PDF. Stores the paper locally for read_paper and semantic_search. The response includes content_length, returned_chars, next_start, and is_truncated so clients can safely page through very large papers without mistaking client-side output caps for failed downloads.

Copy & paste β€” that's it
result = await call_tool("download_paper", {
 "paper_id": "2401.12345"
})

# For very large papers, request bounded chunks:
result = await call_tool("download_paper", {
 "paper_id": "2401.12345",
 "start": 0,
 "max_chars": 50000
})

For older papers that only have a PDF, install the [pdf] extra: uv tool install 'arxiv-mcp-server[pdf]'

3. List Papers

List all papers downloaded locally. Returns arXiv IDs only β€” use read_paper to access content.

Copy & paste β€” that's it
result = await call_tool("list_papers", {})

4. Read Paper

Read the full text of a locally downloaded paper in markdown. Requires download_paper to be called first. Use start and max_chars with the returned next_start value to page through large papers.

Copy & paste β€” that's it
result = await call_tool("read_paper", {
 "paper_id": "2401.12345"
})

result = await call_tool("read_paper", {
 "paper_id": "2401.12345",
 "start": 50000,
 "max_chars": 50000
})

πŸ“ Research Prompts

The server offers specialized prompts to help analyze academic papers:

Paper Analysis Prompt

A comprehensive workflow for analyzing academic papers that only requires a paper ID:

Copy & paste β€” that's it
result = await call_prompt("deep-paper-analysis", {
 "paper_id": "2401.12345"
})

This prompt includes:

  • Detailed instructions for using available tools (list_papers, download_paper, read_paper, search_papers)

  • A systematic workflow for paper analysis

  • Comprehensive analysis structure covering:

  • Executive summary

  • Research context

  • Methodology analysis

  • Results evaluation

  • Practical and theoretical implications

  • Future research directions

  • Broader impacts

Pro Prompt Pack

  • summarize_paper: concise structured summary for one paper.

  • compare_papers: side-by-side technical comparison across paper IDs.

  • literature_review: thematic synthesis across a topic and optional paper set.

πŸ§ͺ Testing

Run the test suite:

Copy & paste β€” that's it
python -m pytest

πŸ§ͺ Experimental Features

These features are not yet fully tested and may behave unexpectedly. Use with caution.

The following tools require additional dependencies and are under active development:

Copy & paste β€” that's it
uv pip install -e ".[pro]"

Semantic Search

Semantic similarity search over your locally downloaded papers only. Returns empty results if no papers have been downloaded yet. Requires [pro] dependencies.

Copy & paste β€” that's it
result = await call_tool("semantic_search", {
 "query": "test-time adaptation in multimodal transformers",
 "max_results": 5
})
# or find papers similar to a known paper:
result = await call_tool("semantic_search", {
 "paper_id": "2404.19756",
 "max_results": 5
})

Citation Graph

Fetch references and citing papers via Semantic Scholar. Works on any arXiv ID β€” no local download required.

Copy & paste β€” that's it
result = await call_tool("citation_graph", {
 "paper_id": "2401.12345"
})

Research Alerts

Save topic watches and poll for newly published papers since the last check. Uses the same query syntax as search_papers.

Copy & paste β€” that's it
# Register a watch (idempotent β€” calling again updates the existing watch)
await call_tool("watch_topic", {
 "topic": "\"multi-agent reinforcement learning\"",
 "categories": ["cs.AI", "cs.LG"],
 "max_results": 10
})

# Check all watches β€” returns only papers published since last check
result = await call_tool("check_alerts", {})

# Check a single watch
result = await call_tool("check_alerts", {"topic": "\"multi-agent reinforcement learning\""})

Advanced Prompts

summarize_paper, compare_papers, and literature_review for deeper research workflows. Requires [pro] dependencies.

πŸ“„ License

Released under the Apache License 2.0. See the LICENSE file for details.

Made with ❀️ by the Pearl Labs Team