Stratosphere MCP Zotero

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.

Category
Visit Server

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 library argument — "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 the offset argument to page through larger sets — total_results in 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 extra field.

Prerequisites

Zotero API key:

  1. Go to your Zotero account settings → API Keys
  2. Create a key with the library permissions you need (personal and/or group access)
  3. Copy it into your .env file

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

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured