Stratosphere MCP Zotero
Enables natural language interaction with Zotero libraries, allowing users to search, retrieve, and update papers and metadata via AI assistants like Claude and Gemini.
README
Stratosphere MCP Zotero
Connect your Zotero library to an AI assistant. Ask questions, find papers, save sources, fix metadata — in plain language.
Works with Claude, Gemini CLI, OpenAI Codex, and any other MCP client.
What you can ask
You ask in plain language. The assistant picks the right tool. You stay in your normal chat.
Find a paper
"Find papers about deception in the Deception Research group." "Do I have anything by Kahneman in my ML collection?" "Do I already have this DOI?" "Find the paper with BibTeX key smith2023."
The assistant searches your library and returns a short list with title, authors, year, and DOI.
Search several libraries at once
"Do I have anything about bananas in Exotic Research or my personal library?"
You get one answer with results from both.
Browse by tag or collection
"Show me everything tagged 'to-read'." "What's in my Reading Queue collection?" "List all papers tagged 'important' in the Deception Research group."
The assistant lists the items. Tags must match exactly.
Look up one item
"Show me the full details for item ABCD1234." "Where is the PDF for this paper on my disk?"
You get normalised metadata, or a local PDF path you can open in your editor.
Count your library
"How many papers do I have in my personal Zotero?" "How big is the Deception Research group library?"
You get a number. By default it counts top-level items only, not PDFs and notes.
Save and update
"Save this paper to my Reading Queue collection." "Fix the DOI on item ABCD1234 and add the tag 'to-read'."
The assistant adds or updates the item and shows you what changed. Only the fields you mention are touched — nothing else is overwritten.
A few things to know
- Group libraries: All tools accept a
libraryargument —"personal", a group name like"Deception Research", or a numeric group ID. Group names are fuzzy-matched. - Collections by name: Pass a collection name and the tool resolves it. If two collections have similar names, the tool asks you to pick.
- Save/update format: Separate authors with
;and tags with,.creators="Ada Lovelace; Grace Hopper" creators="author: Turing, Alan; editor: Knuth, Donald" tags="reading-queue, llm, bibliography" - Pagination: Tools that list items (
find_library_sources,find_by_tag) cap at 100 results per call. Use theoffsetargument to page through larger sets —total_resultsin the response tells you when to stop. - BibTeX keys: Looking up a paper by its citation key requires the Better BibTeX Zotero plugin, which writes the key into the item's
extrafield.
Prerequisites
Zotero API key:
- Go to your Zotero account settings → API Keys
- Create a key with the library permissions you need (personal and/or group access)
- Copy it into your
.envfile
The server automatically resolves your user ID and all accessible group libraries from the API key — no manual library IDs required.
Quick start (Docker)
# Build
docker compose build
# Configure
cp .env.example .env
# Fill in ZOTERO_API_KEY, then lock down the file:
chmod 600 .env
Register with your AI assistant:
<details> <summary><strong>Claude</strong></summary>
Claude Desktop — edit ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"zotero": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"--env-file", "/absolute/path/to/.env",
"zotero-mcp:latest",
"serve"
]
}
}
}
Use the full path to your .env file. Claude Desktop launches Docker from an unknown working directory, so relative paths won't work.
Claude Code:
claude mcp add --transport stdio zotero -- \
docker run --rm -i \
--env-file /absolute/path/to/.env \
zotero-mcp:latest serve
</details>
<details> <summary><strong>Gemini CLI</strong></summary>
Edit ~/.gemini/settings.json (or .gemini/settings.json in your project root):
{
"mcpServers": {
"zotero": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"--env-file", "/absolute/path/to/.env",
"zotero-mcp:latest",
"serve"
]
}
}
}
</details>
<details> <summary><strong>OpenAI Codex</strong></summary>
Edit ~/.codex/config.toml (or .codex/config.toml in your project root):
[[mcp_servers]]
name = "zotero"
command = "docker"
args = [
"run", "--rm", "-i",
"--env-file", "/absolute/path/to/.env",
"zotero-mcp:latest",
"serve"
]
</details>
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.