OpenLibrary MCP

OpenLibrary MCP

Enables searching for books using the OpenLibrary API; provides a search_books tool for AI assistants to find books by title, author, or keywords.

Category
Visit Server

README

OpenLibrary MCP

A book search application that provides access to the OpenLibrary API through both FastAPI and MCP (Model Context Protocol) servers.

๐Ÿš€ Features

  • Book Search: Search for books using the OpenLibrary API
  • Dual Server Support: Available as both FastAPI web server and MCP server
  • Data Validation: Robust Pydantic models with proper validation
  • Error Handling: Graceful handling of incomplete API responses
  • Comprehensive Logging: Detailed logging for monitoring and debugging
  • Code Quality: Pre-commit hooks for maintaining code standards

๐Ÿ“ฆ Installation

Prerequisites

  • Python 3.11+
  • Poetry (recommended) or pip

Using Poetry (Recommended)

# Clone the repository
git clone <repository-url>
cd openlibrary_mcp

# Install dependencies
poetry install

# Install pre-commit hooks
poetry run pre-commit install

# Activate virtual environment
poetry shell

Using pip

# Clone the repository
git clone <repository-url>
cd openlibrary_mcp

# Create virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

๐Ÿ› ๏ธ Usage

FastAPI Server

Start the FastAPI web server:

python -m openlibrary_mcp.fastapi_server

The server will be available at http://localhost:8000

API Endpoints

  • GET /search?query=<search_term> - Search for books
  • GET /health - Health check endpoint
  • GET / - API information
  • GET /docs - Interactive API documentation

Example:

curl "http://localhost:8000/search?query=python+programming"

MCP Server

The MCP server provides tool-based access for AI assistants:

python -m openlibrary_mcp.mcp_server

Or use the installed command:

openlibrary-mcp

๐Ÿค– Using with Claude Desktop

This MCP server can be easily integrated with Claude Desktop to provide book search capabilities directly in your conversations with Claude.

example_usage

๐Ÿ“‹ Prerequisites

  • Claude Desktop application installed
  • This openlibrary_mcp project installed and working
  • Poetry or Python environment set up

โš™๏ธ Setup Instructions

1. Locate Claude Desktop Config

Find your Claude Desktop configuration file:

macOS:

~/Library/Application\ Support/Claude/claude_desktop_config.json

Windows:

%APPDATA%\Claude\claude_desktop_config.json

Linux:

~/.config/Claude/claude_desktop_config.json

2. Add Books MCP Server

Edit the claude_desktop_config.json file and add the openlibrary-mcp server:

{
  "mcpServers": {
    "books-search": {
      "command": "uvx",
      "args": [
        "--from",
        "git+https://github.com/uysalserkan/openlibrary-mcp",
        "openlibrary-mcp"
      ]
    },
    ...
  }
}

3. Restart Claude Desktop

Close and restart Claude Desktop for the changes to take effect.

๐ŸŽฏ Using the Book Search Tool

Once configured, you can use the book search functionality in Claude Desktop:

Example Conversations:

You: "Can you help me find books about Python programming?"

Claude: I'll search for Python programming books for you.

[Claude uses the search_books tool]

Claude: I found several Python programming books:

  1. "Learning Python" by Mark Lutz (2013)

    • 5 editions available
    • Language: English
  2. "Python Crash Course" by Eric Matthes (2019)

    • 3 editions available
    • Language: English

[...more results...]

Other Example Queries:

  • "Find books by J.R.R. Tolkien"
  • "Search for books about machine learning"
  • "Look up George Orwell's 1984"
  • "Find cookbooks published after 2020"

๐Ÿ”ง Tool Details

The MCP server provides one tool:

search_books(query: str)

  • Purpose: Search for books using OpenLibrary API
  • Input: Search query string
  • Output: Structured book data including titles, authors, publication years, and more
  • Examples:
    • "python programming"
    • "tolkien lord of the rings"
    • "george orwell 1984"

โœ… Verification

After setup, you should see:

  1. In Claude Desktop: The openlibrary-mcp server listed in available tools
  2. In Conversations: Ability to ask Claude to search for books
  3. In Logs: MCP server startup messages when Claude Desktop starts

The integration allows Claude to seamlessly search for books and provide detailed information about authors, publication years, editions, and more, making it a powerful research and discovery tool!

๐Ÿ”ง Development

Pre-commit Hooks

This project uses pre-commit hooks to ensure code quality and consistency. The following tools are configured:

๐Ÿ›ก๏ธ Code Quality Tools

  • Black: Code formatting (line length: 88)
  • isort: Import sorting with black compatibility
  • Ruff: Fast Python linter (replaces flake8)
  • mypy: Static type checking
  • Bandit: Security vulnerability scanner

๐Ÿ“ General Checks

  • Trailing whitespace: Automatically removes trailing spaces
  • End of file: Ensures files end with newline
  • YAML/TOML validation: Validates configuration files
  • Large files: Prevents committing large files
  • Merge conflicts: Detects merge conflict markers
  • Debug statements: Finds debug statements in code

๐Ÿš€ Running Pre-commit

# Install hooks (run once)
poetry run pre-commit install

# Run on all files
poetry run pre-commit run --all-files

# Run on specific files
poetry run pre-commit run --files openlibrary_mcp/models.py

# Skip hooks for a commit (not recommended)
git commit -m "message" --no-verify

โš™๏ธ Tool Configuration

All tools are configured in pyproject.toml:

[tool.black]
line-length = 88
target-version = ['py311']

[tool.isort]
profile = "black"
line_length = 88

[tool.ruff.lint]
select = ["E", "W", "F", "I", "B", "C4", "UP"]

[tool.mypy]
python_version = "3.11"
disallow_untyped_defs = true

๐Ÿ“Š API Response Format

{
  "num_found": 1234,
  "q": "python programming",
  "docs": [
    {
      "author_name": "John Doe",
      "edition_count": 5,
      "first_publish_year": 2020,
      "language": "en",
      "title": "Python Programming Guide"
    }
  ]
}

๐Ÿ—๏ธ Project Structure

openlibrary_mcp/
โ”œโ”€โ”€ openlibrary_mcp/           # Main package directory
โ”‚   โ”œโ”€โ”€ __init__.py      # Package initialization
โ”‚   โ”œโ”€โ”€ fastapi_server.py # FastAPI web server
โ”‚   โ”œโ”€โ”€ mcp_server.py    # MCP server implementation
โ”‚   โ”œโ”€โ”€ models.py        # Pydantic data models
โ”‚   โ””โ”€โ”€ providers.py     # OpenLibrary API provider
โ”œโ”€โ”€ .pre-commit-config.yaml # Pre-commit configuration
โ”œโ”€โ”€ claude_desktop_config.json # Sample Claude Desktop configuration
โ”œโ”€โ”€ pyproject.toml       # Project configuration
โ”œโ”€โ”€ poetry.lock          # Dependency lock file
โ”œโ”€โ”€ README.md           # This file
โ””โ”€โ”€ dist/               # Built packages

๐Ÿ”ง Dependencies

  • FastAPI: Web framework for building APIs
  • FastMCP: MCP server implementation
  • Pydantic: Data validation and settings management
  • Uvicorn: ASGI server for FastAPI
  • HTTPX: Async HTTP client for API calls
  • Requests: HTTP library for synchronous requests

Development Dependencies

  • pre-commit: Git hooks for code quality
  • black: Code formatter
  • isort: Import sorter
  • ruff: Fast Python linter
  • mypy: Static type checker
  • bandit: Security linter

๐Ÿ” Data Models

BookDetails

Represents individual book information with optional fields to handle incomplete API responses:

  • author_name: Author's name
  • edition_count: Number of available editions
  • first_publish_year: Year of first publication
  • language: Book language(s)
  • title: Book title

OpenLibrary

Represents the complete API response:

  • num_found: Total number of books found
  • q: Search query
  • docs: List of book details

๐Ÿ“‹ Logging

The application includes comprehensive logging to help with monitoring and debugging:

๐ŸŽฏ Key Logging Features:

  • API Calls: Track OpenLibrary API requests, responses, and timing
  • Data Validation: Monitor model validation, data cleaning, and incomplete records
  • Server Activity: Log server startup, endpoint access, and request processing
  • Error Handling: Detailed error logging with context

๐Ÿ“Š Log Levels:

  • INFO: General application flow and important events
  • DEBUG: Detailed validation steps and data processing
  • WARNING: Non-critical issues (empty queries, missing fields)
  • ERROR: Failures and exceptions with full context

๐Ÿ”ง Log Format:

2025-07-15 16:57:40,733 - openlibrary_mcp.providers - INFO - ๐Ÿ“š Starting book search for query: 'python'
2025-07-15 16:57:40,734 - openlibrary_mcp.models - INFO - โš ๏ธ  1/3 books have missing critical fields

๐Ÿ“ Example Log Messages:

๐Ÿ”ง OpenLibraryProvider initialized with base_url: https://openlibrary.org
๐Ÿ“š Starting book search for query: 'python programming'
๐Ÿ“ก API Response: 200 | Content-Length: 12345
โœ… Search completed: 1234 total books found, 20 returned in response
๐ŸŽฏ Successfully processed 20 book records
๐Ÿ” MCP tool called: search_books with query='python'
๐ŸŒ GET /search - Query: {'query': 'python'}
๐Ÿ“Š Response: 200 | Time: 0.523s

๐Ÿงช Testing

Run a quick test to verify the installation:

# Test FastAPI server
python -c "from openlibrary_mcp.providers import OpenLibraryProvider; print('โœ… OpenLibrary provider works!')"

# Test models
python -c "from openlibrary_mcp.models import BookDetails, OpenLibrary; print('โœ… Models imported successfully!')"

# Test pre-commit hooks
poetry run pre-commit run --all-files

๐Ÿค Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Make your changes
  4. Ensure pre-commit hooks pass: poetry run pre-commit run --all-files
  5. Add tests if applicable
  6. Submit a pull request

Code Quality Standards

  • Type hints: All functions must have proper type annotations
  • Documentation: Use docstrings for all public functions and classes
  • Error handling: Use proper exception chaining with raise ... from e
  • Security: Avoid binding to all interfaces (0.0.0.0) in production
  • Logging: Include meaningful log messages with appropriate levels

๐Ÿ“ License

This project is open source and available under the MIT License.

๐Ÿ”— Related Links

๐Ÿ› Issues

If you encounter any issues, please create an issue on the GitHub repository with:

  • Description of the problem
  • Steps to reproduce
  • Expected vs actual behavior
  • Your environment 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