Skip to main content

MCP server for reading and searching EPUB/PDF documents

Project description

mcp-ebook-read

A local MCP server for Codex to read and retrieve content from EPUB/PDF documents.

One-Command Docker Setup

Qdrant (required)

docker rm -f qdrant 2>/dev/null || true && docker run -d --name qdrant -p 6333:6333 -p 6334:6334 qdrant/qdrant:v1.16.3

GROBID (required by startup preflight and document_ingest_pdf_paper)

docker rm -f grobid 2>/dev/null || true && docker run -d --name grobid -p 8070:8070 lfoppiano/grobid:0.8.0

Verify Services

curl -sS http://localhost:6333/collections
curl -sS http://localhost:8070/api/isalive

Expected:

  • Qdrant returns JSON with "status":"ok"
  • GROBID returns true

Run MCP Server (PyPI via uvx)

QDRANT_URL=http://localhost:6333 GROBID_URL=http://localhost:8070 GROBID_TIMEOUT_SECONDS=120 uvx mcp-ebook-read

If startup preflight fails, the server exits with a structured error payload on stderr that includes missing env vars and setup hints.

First Run Recommendation

Before configuring this MCP inside an MCP client, run it once manually from a terminal:

QDRANT_URL=http://localhost:6333 GROBID_URL=http://localhost:8070 GROBID_TIMEOUT_SECONDS=120 uvx mcp-ebook-read

This pre-resolves and aligns runtime dependencies, which helps avoid long first-time activation latency after MCP client configuration.

When you want to upgrade to the latest published version, run:

QDRANT_URL=http://localhost:6333 GROBID_URL=http://localhost:8070 GROBID_TIMEOUT_SECONDS=120 uvx --upgrade mcp-ebook-read

Environment Variables

Required:

  • QDRANT_URL (for example http://127.0.0.1:6333)
  • GROBID_URL (for example http://127.0.0.1:8070)

Optional:

  • GROBID_TIMEOUT_SECONDS (default 20; recommended 120 for large papers)
  • QDRANT_COLLECTION (default mcp_ebook_read_chunks)
  • QDRANT_TIMEOUT_SECONDS (default 10)
  • FASTEMBED_MODEL (FastEmbed model override)
  • DOCLING_FORMULA_ENRICHMENT (true by default)
  • PDF_FORMULA_REQUIRE_ENGINE (true by default)
  • PDF_FORMULA_BATCH_SIZE (auto by default; or an explicit integer)

Persistence Model

  • Persistence is sidecar-based and auto-routed by document location.
  • For each document, MCP writes state to <document_dir>/.mcp-ebook-read/.
  • Sidecar contains:
    • catalog.db
    • docs/<doc_id>/reading/reading.md
    • docs/<doc_id>/assets/...
    • docs/<doc_id>/evidence/...

Notes

  • Use library_scan to discover .pdf/.epub files under a root and register updates/removals.
  • After a fresh server restart, call library_scan(root=...) or storage_list_sidecars(root=...) before using tools that only take doc_id.
  • Use search for global semantic retrieval and read for locator-based chunk windows.
  • Startup preflight is fail-fast and requires both Qdrant and GROBID to be configured and reachable.
  • Use document_ingest_pdf_book for PDF books.
  • Use document_ingest_epub_book for EPUB books.
  • Use document_ingest_pdf_paper for PDF papers. Docling remains the canonical page-aware outline; GROBID enriches paper metadata and title.
  • Use search_in_outline_node when you need chapter-scoped retrieval (recommended for reading workflows).
  • Use get_outline to fetch document outline nodes before chapter/formula/image scoped reading.
  • Use read_outline_node to read a chapter/outline node directly without locator stitching.
  • Use render_pdf_page for PDF evidence rendering.
  • PDF image extraction is on-demand: ingest does not pre-extract PDF images.
  • Use pdf_list_images to trigger/list extracted PDF figure/table images (optionally scoped to one outline node).
  • Use pdf_read_image to get one extracted PDF image path plus nearby text context.
  • Use pdf_book_list_formulas / pdf_book_read_formula for formula-centric reading on PDF books.
  • Use pdf_paper_list_formulas / pdf_paper_read_formula for formula-centric reading on PDF papers.
  • Use epub_list_images to list extracted EPUB images (optionally scoped to one outline node).
  • Use epub_read_image to get one EPUB image path plus nearby text context.
  • Use storage_list_sidecars to inspect sidecar persistence under a root.
  • Use storage_delete_document to remove one document's persisted state.
  • Use storage_cleanup_sidecars to prune missing docs/orphan artifacts and compact catalogs.
  • For large papers, increase GROBID_TIMEOUT_SECONDS (for example 120) to reduce timeout failures.
  • PDF ingest now uses a mixed formula pipeline:
    • Docling structure extraction with do_formula_enrichment.
    • Pix2Text as the primary formula recovery engine.
    • Fail-fast when formula markers exist but Pix2Text is unavailable.
  • Optional formula env controls:
    • DOCLING_FORMULA_ENRICHMENT (true by default)
    • PDF_FORMULA_REQUIRE_ENGINE (true by default)
    • PDF_FORMULA_BATCH_SIZE (auto by default; auto-detected from CPU and memory, or set an explicit integer)
  • Sidecar cleanup is explicit:
    • library_scan no longer triggers threshold-based auto compaction.
    • Use storage_cleanup_sidecars(..., compact_catalog=true) when you want compaction.

No-Label Formula Benchmark

Use your own non-scanned PDF corpus as a no-label regression baseline (without manual annotations).

uvx mcp-ebook-formula-benchmark \
  --samples-dir /ABSOLUTE/PATH/TO/pdf-formula-benchmark-corpus \
  --passes 2 \
  --max-unresolved-rate 0.15 \
  --min-latex-valid-rate 0.85 \
  --min-stability-rate 1.0

Output is JSON with per-document metrics and a threshold pass/fail flag. Exit code is 0 when thresholds pass, otherwise 2.

Claude Code MCP Configuration (JSON via uvx)

You can register this server in a Claude Code compatible mcpServers JSON config.

Published package

{
  "mcpServers": {
    "mcp-ebook-read": {
      "command": "uvx",
      "args": [
        "mcp-ebook-read"
      ],
      "env": {
        "QDRANT_URL": "http://127.0.0.1:6333",
        "QDRANT_COLLECTION": "mcp_ebook_read_chunks",
        "GROBID_URL": "http://127.0.0.1:8070",
        "GROBID_TIMEOUT_SECONDS": "120"
      }
    }
  }
}

Security note

  • Do not put real passwords, API keys, or tokens directly in committed JSON files.
  • Use environment variables or secret managers, and keep example values as placeholders only.

Codex MCP Configuration (TOML)

You can also configure MCP servers in Codex using TOML style (for example in a Codex MCP config file).

Example

[mcp_servers.mcp-ebook-read]
command = "uvx"
args = [ "mcp-ebook-read" ]
startup_timeout_sec = 60

[mcp_servers.mcp-ebook-read.env]
QDRANT_URL = "http://127.0.0.1:6333"
QDRANT_COLLECTION = "mcp_ebook_read_chunks"
GROBID_URL = "http://127.0.0.1:8070"
GROBID_TIMEOUT_SECONDS = "120"

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

mcp_ebook_read-0.1.3.tar.gz (69.9 kB view details)

Uploaded Source

Built Distribution

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

mcp_ebook_read-0.1.3-py3-none-any.whl (49.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mcp_ebook_read-0.1.3.tar.gz
  • Upload date:
  • Size: 69.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mcp_ebook_read-0.1.3.tar.gz
Algorithm Hash digest
SHA256 85a8ab2940de9b9d1aa408abc0f1b4b7bd0ac713badb9d247a757b50b7a6bf5e
MD5 31898e59af134846ec3543a88d596ecf
BLAKE2b-256 37992c253fa6b82419d84dbd9dc6a48e897be844c66b3cbbcaf7db11092f9c18

See more details on using hashes here.

File details

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

File metadata

  • Download URL: mcp_ebook_read-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 49.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.9 {"installer":{"name":"uv","version":"0.10.9","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for mcp_ebook_read-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 515ee0e01a8d6dafd5fa5bc7c38a38f297f616d6e41f805e57b221ba6daabacc
MD5 ce565e57696c6bb9fae115ef2069fdaf
BLAKE2b-256 60c85a8585c0ab37d27f604e3ad19093020ec752f87cd135971daf09fe549b4a

See more details on using hashes here.

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