Skip to main content

A powerful Model Context Protocol (MCP) server for Chinese-to-English book translation and document processing

Project description

BookBridge-MCP

GitHub Python Poetry FastMCP uv

๐Ÿš€ Now with uvx support! Run directly from GitHub with zero installation:

uvx --from git+https://github.com/Polly2014/BookBridge-MCP-Server bookbridge-server

A powerful Model Context Protocol (MCP) server for Chinese-to-English book translation and document processing, built with FastMCP framework.

๐ŸŒ‰ Overview

BookBridge-MCP provides a comprehensive solution for translating Chinese books and documents to English while preserving formatting and structure. The server follows a client-side LLM architecture, where the MCP server handles document processing and provides translation resources, while LLM interactions are performed on the client side.

โœจ Key Features

  • Zero Installation Required: Run directly from GitHub using uvx
  • Document Processing: Convert between Word (.docx) and Markdown formats
  • Smart Resource Management: Organize and track translation projects
  • Professional Translation Prompts: Specialized prompts for different content types
  • Client-Side LLM Architecture: Clean separation between document processing and AI inference
  • Batch Processing: Handle multiple documents efficiently
  • Format Preservation: Maintain original document structure and formatting

๐Ÿ—๏ธ Architecture

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    MCP Protocol    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚                 โ”‚โ—„โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ–บโ”‚                 โ”‚
โ”‚   MCP Client    โ”‚                    โ”‚  BookBridge     โ”‚
โ”‚                 โ”‚                    โ”‚  MCP Server     โ”‚
โ”‚  + LLM Calls    โ”‚                    โ”‚                 โ”‚
โ”‚  + UI/Logic     โ”‚                    โ”‚  + Tools        โ”‚
โ”‚                 โ”‚                    โ”‚  + Resources    โ”‚
โ”‚                 โ”‚                    โ”‚  + Prompts      โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜                    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜
         โ”‚                                       โ”‚
         โ”‚                                       โ”‚
         v                                       v
โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”                    โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚   OpenAI API    โ”‚                    โ”‚   Document      โ”‚
โ”‚   (Client-side) โ”‚                    โ”‚   Processing    โ”‚
โ”‚                 โ”‚                    โ”‚   (Server-side) โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜                    โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

โšก Quick Start

Method 1: Using uvx (Recommended - Run Directly from GitHub)

No installation needed! Run directly from GitHub using uvx:

# Run directly from GitHub
uvx --from git+https://github.com/Polly2014/BookBridge-MCP-Server bookbridge-server

Update your MCP configuration (mcp.json):

{
  "servers": {
    "Book-Bridge-MCP": {
      "command": "uvx",
      "args": [
        "--from",
        "git+https://github.com/Polly2014/BookBridge-MCP-Server",
        "bookbridge-server"
      ],
      "type": "stdio"
    }
  }
}

Method 2: Local Development Installation

1. Install Dependencies

# Clone the repository
git clone https://github.com/Polly2014/BookBridge-MCP-Server.git
cd BookBridge-MCP-Server

# Automated setup (recommended)
python setup_poetry.py

# Or if Poetry is already installed
poetry install

2. Test Environment

# Verify installation
poetry run python test_environment.py

# Test MCP functionality
poetry run python test_simple.py

3. Start Server

# Start the MCP server
poetry run python start.py

4. Run Client Example

# Test with client example
poetry run python examples/client_example.py

5. Development Commands

# Run tests: poetry run pytest
# Format code: poetry run black .
# Type checking: poetry run mypy src/
# All checks: make check (or make.bat check on Windows)

Method 3: Using npx-like approach with uv

If you prefer an npx-like experience, you can also use:

# Run directly with uv (if published to PyPI)
uvx bookbridge-mcp

๐Ÿš€ Detailed Installation

1. Prerequisites

  • Python 3.10 or higher
  • Poetry (recommended) or pip

2. Installation

Option A: Using Poetry (Recommended)

git clone https://github.com/your-repo/BookBridge-MCP.git
cd BookBridge-MCP

# Automated setup (installs Poetry if needed)
python setup_poetry.py

# Or manual setup if Poetry is already installed
poetry install --with dev --with client

Option B: Using pip

git clone https://github.com/your-repo/BookBridge-MCP.git
cd BookBridge-MCP
pip install -r requirements.txt

3. Start the MCP Server

Using Poetry:

poetry run python start.py
# or
poetry run bookbridge-server
# or using make commands
make run              # Unix/Linux/Mac
make.bat run          # Windows

Using pip:

python start.py

The server will start and listen for MCP connections on the configured port.

3. Client-Side Integration

The MCP server provides tools, resources, and prompts. Your client application handles the LLM interactions:

from examples.client_example import BookBridgeClient

# Initialize client with your OpenAI API key
client = BookBridgeClient(api_key="your_openai_api_key")

# Translate a document
result = await client.translate_document(
    file_path="./my_chinese_book.docx",
    content_type="academic"  # or "general", "technical", "creative"
)

# Save the translation
output_path = await client.save_translation(
    result, 
    "./output/translated_book.md"
)

๐Ÿ› ๏ธ MCP Server Capabilities

Tools

  1. process_document - Convert documents between Word and Markdown formats
  2. list_documents - List and manage documents in the project
  3. get_document_info - Get detailed information about a specific document
  4. create_translation_project - Set up new translation projects
  5. get_translation_metrics - Calculate translation quality metrics

Resources

  • Document Registry - Track all processed documents
  • Project Files - Access source and output documents
  • Translation History - View previous translations

Prompts

  • General Translation - For everyday content
  • Academic Translation - For scholarly and research texts
  • Technical Translation - For documentation and manuals
  • Creative Translation - For literary and creative works

๐Ÿ“ Project Structure

BookBridge-MCP/
โ”œโ”€โ”€ server.py                 # Main MCP server
โ”œโ”€โ”€ start.py                  # Server startup script
โ”œโ”€โ”€ requirements.txt          # Dependencies
โ”œโ”€โ”€ config.env               # Configuration
โ”œโ”€โ”€ src/
โ”‚   โ”œโ”€โ”€ document_processor.py # Document conversion
โ”‚   โ”œโ”€โ”€ resource_manager.py   # File and project management
โ”‚   โ”œโ”€โ”€ prompts.py            # Translation prompts
โ”‚   โ””โ”€โ”€ translator.py         # Translation utilities
โ”œโ”€โ”€ examples/
โ”‚   โ””โ”€โ”€ client_example.py     # Client implementation example
โ”œโ”€โ”€ input_documents/          # Source documents
โ”œโ”€โ”€ output_documents/         # Translated documents
โ””โ”€โ”€ temp_documents/           # Temporary files

๐Ÿ”ง Configuration

MCP Client Configuration

You can configure your MCP client in three ways:

Option 1: Using uvx with GitHub (Recommended)

Edit your mcp.json file:

{
  "servers": {
    "Book-Bridge-MCP": {
      "command": "uvx",
      "args": [
        "--from",
        "git+https://github.com/Polly2014/BookBridge-MCP-Server",
        "bookbridge-server"
      ],
      "type": "stdio"
    }
  }
}

Advantages:

  • โœ… No local installation required
  • โœ… Always runs the latest version from GitHub
  • โœ… Automatic dependency management via uv
  • โœ… Clean and simple configuration

Option 2: Using Local Installation

{
  "servers": {
    "Book-Bridge-MCP": {
      "command": "python",
      "args": [
        "D:\\path\\to\\BookBridge-MCP\\server.py"
      ],
      "cwd": "D:\\path\\to\\BookBridge-MCP",
      "type": "stdio"
    }
  }
}

Option 3: Using npx-like syntax (if published to PyPI)

{
  "servers": {
    "Book-Bridge-MCP": {
      "command": "uvx",
      "args": ["bookbridge-mcp"],
      "type": "stdio"
    }
  }
}

Server Configuration

Edit config.env to customize settings:

# Document Processing Settings
INPUT_DIR=./input_documents
OUTPUT_DIR=./output_documents
TEMP_DIR=./temp_documents

# Translation Settings (for client reference)
SOURCE_LANGUAGE=chinese
TARGET_LANGUAGE=english

# MCP Server Settings
SERVER_NAME=BookBridge-MCP
SERVER_VERSION=1.0.0

๏ฟฝ๏ธ Development Workflow

Using Poetry (Recommended)

Poetry provides better dependency management and development workflow:

# Complete development setup
poetry install --with dev --with client
poetry run pre-commit install

# Development commands using Poetry
poetry run python start.py          # Start server
poetry run pytest                   # Run tests  
poetry run pytest --cov=src         # Tests with coverage
poetry run black .                  # Format code
poetry run isort .                  # Sort imports
poetry run flake8 src/              # Lint code
poetry run mypy src/                # Type checking

Using Make Commands

For convenience, use the provided Makefile (Unix/Linux/Mac) or make.bat (Windows):

# Unix/Linux/Mac
make dev-setup      # Complete development setup
make run            # Start server
make test           # Run tests
make format         # Format code
make lint           # Lint code
make type-check     # Type checking
make check          # Run all checks
make clean          # Clean temporary files

# Windows
make.bat dev-setup  # Complete development setup
make.bat run        # Start server
make.bat test       # Run tests
make.bat format     # Format code
make.bat lint       # Lint code
make.bat type-check # Type checking
make.bat check      # Run all checks
make.bat clean      # Clean temporary files

Package Management

# Add new dependency
poetry add package_name

# Add development dependency
poetry add --group dev package_name

# Add client dependency (optional for client usage)
poetry add --group client package_name

# Update dependencies
poetry update

# Show installed packages
poetry show

# Environment information
poetry env info

๏ฟฝ๐Ÿ’ก Usage Examples

Basic Document Translation

# Process and translate a Word document
result = await client.translate_document(
    file_path="./books/chinese_novel.docx",
    content_type="creative"
)

print(f"Translated {result['summary']['original_words']} words")
print(f"Used {result['summary']['token_usage']} tokens")

Batch Processing

# Process multiple documents
documents = ["doc1.docx", "doc2.md", "doc3.docx"]

for doc in documents:
    result = await client.translate_document(doc, "academic")
    await client.save_translation(result, f"./output/{doc}_translated.md")

Custom Content Types

You can request specific translation prompts from the server:

# Get specialized prompt for technical content
prompt = await client.get_translation_prompt("technical")

# Use prompt for custom translation
translation = await client.translate_content(
    content="ๆŠ€ๆœฏๆ–‡ๆกฃๅ†…ๅฎน...",
    content_type="technical"
)

๐ŸŽฏ Client-Side LLM Benefits

  1. Flexibility: Clients can use any LLM provider or model
  2. Security: API keys stay on the client side
  3. Scalability: Server focuses on document processing
  4. Customization: Clients can customize translation parameters
  5. Cost Control: Clients manage their own LLM usage

๐Ÿ“Š Translation Quality Features

  • Smart Chunking: Preserve document structure when splitting large texts
  • Format Preservation: Maintain headers, lists, and emphasis
  • Metrics Calculation: Analyze translation quality and completeness
  • Content-Type Optimization: Specialized prompts for different text types

๐Ÿงช Testing

Running Tests

Using Poetry:

# Run all tests
poetry run pytest

# Run tests with coverage
poetry run pytest --cov=src --cov-report=html --cov-report=term

# Run specific test file
poetry run pytest tests/test_document_processor.py

# Run tests in verbose mode
poetry run pytest -v

# Quick test (stop on first failure)
poetry run pytest -x

Using Make commands:

# Unix/Linux/Mac
make test
make test-coverage
make quick-test

# Windows  
make.bat test
make.bat test-coverage
make.bat quick-test

Running Examples

Test the client example:

# Using Poetry
poetry run python examples/client_example.py

# Using Make
make client-example        # Unix/Linux/Mac
make.bat client-example    # Windows

Development Testing

# Run architecture tests
poetry run python test_architecture.py

# Test individual components
poetry run python test_components.py

๐Ÿค Contributing

Development Setup

  1. Fork the repository
  2. Clone your fork:
    git clone https://github.com/your-username/BookBridge-MCP.git
    cd BookBridge-MCP
    
  3. Set up development environment:
    # Complete setup with Poetry
    make dev-setup           # Unix/Linux/Mac
    make.bat dev-setup       # Windows
    
    # Or manually
    poetry install --with dev --with client
    poetry run pre-commit install
    

Development Workflow

  1. Create a feature branch: git checkout -b feature/your-feature
  2. Make your changes
  3. Run quality checks:
    make check              # Unix/Linux/Mac
    make.bat check          # Windows
    
  4. Add tests for new functionality
  5. Commit your changes: git commit -m "Add your feature"
  6. Push to your fork: git push origin feature/your-feature
  7. Submit a pull request

Code Quality

This project uses:

  • Black for code formatting
  • isort for import sorting
  • flake8 for linting
  • mypy for type checking
  • pytest for testing
  • pre-commit for automated checks

All checks must pass before merging.

๐Ÿ“„ License

This project is licensed under the MIT License - see the LICENSE file for details.

๐Ÿ†˜ Support

For issues and questions:

  1. Check the examples directory for usage patterns
  2. Review the MCP server logs for debugging
  3. Open an issue on GitHub for bugs or feature requests

BookBridge-MCP: Bridging languages, preserving meaning. ๐ŸŒ‰๐Ÿ“š

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

bookbridge_mcp-1.0.0.tar.gz (30.3 kB view details)

Uploaded Source

Built Distribution

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

bookbridge_mcp-1.0.0-py3-none-any.whl (28.6 kB view details)

Uploaded Python 3

File details

Details for the file bookbridge_mcp-1.0.0.tar.gz.

File metadata

  • Download URL: bookbridge_mcp-1.0.0.tar.gz
  • Upload date:
  • Size: 30.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.11 Windows/10

File hashes

Hashes for bookbridge_mcp-1.0.0.tar.gz
Algorithm Hash digest
SHA256 3aa9aeb2f6d8000ee528fcc6c42ed250f117508e613ed903881eeb29e9d1e7a9
MD5 b95f67217d883070b41c3db955c0f9a4
BLAKE2b-256 de9054b520f47525183f8b4555c0243cf4eb2f30cf56e1cf576a7a4add905058

See more details on using hashes here.

File details

Details for the file bookbridge_mcp-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: bookbridge_mcp-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 28.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.3 CPython/3.10.11 Windows/10

File hashes

Hashes for bookbridge_mcp-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 57322d5a49a98b28f871e3fa16c7f66080d7b1f4f33ba1c57d9357276a346b19
MD5 e1f528a7ad8c9b111757b870d843e6d4
BLAKE2b-256 f19dd3c71036e0498daec24f01c9b52193a1b618f4c8ba9d167c899455bbb515

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