Skip to main content

MCP Server for fixing and enriching BibTeX bibliography metadata

Project description

bib-enrich-mcp

PyPI version License: MIT

Writing a paper and your .bib file is a mess? This tool lets AI automatically complete your citations — fill in missing metadata, find publication venues, add DOIs, and even discover if a preprint has been formally published.

Features

  • Automatic metadata scraping from multiple sources:
    • arXiv API
    • DBLP API
    • CrossRef API
  • BibTeX parsing and writing with full field support
  • Batch processing of entire .bib files
  • MCP integration for use with AI assistants

Installation

# Or install with uv (Recommended)
uv tool install bib-enrich-mcp

# Install from PyPI
pip install bib-enrich-mcp

# Or clone and install locally
git clone https://github.com/haoxiangsnr/bib-enrich-mcp.git
cd bib-enrich-mcp
uv sync

Quick Start

Step 1: Configure MCP Client

Add the server to your MCP client (e.g., Cherry Studio, Claude Desktop, Cursor):

{
  "mcpServers": {
    "bib-enrich": {
      "command": "bib-enrich-mcp"
    }
  }
}

Step 2: Enable the MCP Server

In your MCP client, enable the bib-enrich server. Look for a tools icon (usually a wrench) in the chat interface.

Step 3: Start Using

Now you can ask the AI to help with your bibliography. Example prompts:

Help me find the complete citation for: Attention Is All You Need
Enrich this BibTeX entry with arXiv ID 2401.12345
Process my references.bib file and fill in missing metadata

The AI will automatically call the appropriate tools to fetch metadata from arXiv, DBLP, and CrossRef.

Usage

As an MCP Server

Add to your MCP client configuration:

{
  "mcpServers": {
    "bib-enrich": {
      "command": "bib-enrich-mcp"
    }
  }
}

Running the Server

bib-enrich-mcp

API Documentation

MCP Tools

mcp_enrich_bib_entry

Enrich a single bibliography entry by scraping metadata from academic sources.

Parameters:

  • cite_key (required): The citation key for the entry
  • title (optional): Paper title to search for
  • arxiv_id (optional): arXiv ID (e.g., "2401.12345")
  • doi (optional): DOI of the paper

Returns: BibTeX string with enriched metadata

Example:

result = await mcp_enrich_bib_entry(
    cite_key="vaswani2017attention",
    title="Attention Is All You Need"
)

mcp_enrich_bib_file

Enrich all entries in a BibTeX file.

Parameters:

  • file_path (required): Path to the .bib file

Returns: Summary of enriched entries

Example:

result = await mcp_enrich_bib_file("/path/to/references.bib")
# Returns: "Enriched 5/10 entries in /path/to/references.bib"

Python API

You can also use the library directly in Python:

from bib_enrich_mcp.bib_parser import parse_bib_file, write_bib_file
from bib_enrich_mcp.scrapers import scrape_metadata

# Parse a bib file
entries = parse_bib_file("references.bib")

# Scrape metadata for a paper
results = await scrape_metadata(
    title="Attention Is All You Need",
    arxiv_id="1706.03762"
)

Supported Metadata Sources

Source Search by Title Search by ID Notes
arXiv ✅ (arXiv ID) Best for preprints
DBLP Best for CS conferences
CrossRef ✅ (DOI) Best for journals

Development

Running Tests

uv run pytest tests/ -v

Project Structure

bib-enrich-mcp/
├── src/bib_enrich_mcp/
│   ├── __init__.py
│   ├── bib_parser.py    # BibTeX parsing/writing
│   ├── scrapers.py      # Metadata scrapers
│   └── server.py        # MCP server
├── tests/
│   ├── test_bib_parser.py
│   ├── test_scrapers.py
│   └── test_server.py
├── pyproject.toml
└── README.md

License

MIT

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

bib_enrich_mcp-0.1.1.tar.gz (82.5 kB view details)

Uploaded Source

Built Distribution

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

bib_enrich_mcp-0.1.1-py3-none-any.whl (8.7 kB view details)

Uploaded Python 3

File details

Details for the file bib_enrich_mcp-0.1.1.tar.gz.

File metadata

  • Download URL: bib_enrich_mcp-0.1.1.tar.gz
  • Upload date:
  • Size: 82.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.8

File hashes

Hashes for bib_enrich_mcp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 b00047490087c0e8b52a1776e5d797a91875ac137e523b69e53f96ae84332f56
MD5 5f91f5eb503b85a521a8f170b4b3739c
BLAKE2b-256 43b31655caf414a2b1ae7098025c730bd44c438e241a6b8b2161344249abe7a3

See more details on using hashes here.

File details

Details for the file bib_enrich_mcp-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for bib_enrich_mcp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e547195b4be0a9e735ccb45ea070d409ed7fb0e06ea51b84f831e58642682ab4
MD5 0759f90bbe7ac25876ea9d4c9e54322e
BLAKE2b-256 f28b18792f464aad770199acdf442e3d06328775d9b64fdf0c48c7ca34d165fa

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