Skip to main content

Model Context Protocol (MCP) server for accessing and searching Laravel 12 documentation. Enables AI assistants and tools to query Laravel docs through a standardized interface.

Project description

Laravel Docs MCP Server

GitHub release (latest by date) PyPI Python Version GitHub Workflow Status License Docker Image smithery badge GitHub Stars GitHub Forks

⚠️ BETA SOFTWARE - This project is in early development. Features may not work as expected and breaking changes may occur without notice.

Are you creating or modifying a Laravel app? Hook this MCP up to your AI assistant and immediately get access to:

  • The latest Laravel documentation, for all versions from 6.x
  • Intelligent Laravel package recommendations based on the context from your codebase, and what you're trying to accomplish.

This is like having a very book-smart and up-to-date Laravel dev sit next to you as you code your application.

Update Frequency

This application is written in a way to maximize the value out of GitHub Actions. Every day, it retrieves the latest Laravel documentation for all versions since 6.x (sometimes the old docs get updated too!). If it finds any updates, a new patch release will automatically be generated here and then distributed to both Pypi and GHCR for your consumption. Mmm, delicious.

Installation

Quick Install via Smithery

npx -y @smithery/cli install @brianirish/laravel-docs-mcp --client claude

Install from PyPI

pip install laravel-docs-mcp

Docker

# Pull and run the latest version
docker run -p 8000:8000 ghcr.io/brianirish/laravel-docs-mcp:latest

# Or run a specific version
docker run -p 8000:8000 ghcr.io/brianirish/laravel-docs-mcp:v0.1.4

Manual Installation from Source

Prerequisites

  • Python 3.12+
  • uv package manager (recommended)

Steps

  1. Clone the repository:

    git clone https://github.com/brianirish/laravel-docs-mcp.git
    cd laravel-docs-mcp
    
  2. Set up environment and install dependencies:

    # Create and activate virtual environment
    uv venv
    source .venv/bin/activate  # Linux/macOS
    # or
    .venv\Scripts\activate     # Windows
    
    # Install dependencies
    uv pip install .
    

Usage

Using with AI Clients

Once installed, the MCP server integrates directly with your AI client (Claude Desktop, Cursor, etc.). The server provides Laravel documentation and package recommendation tools that your AI assistant can use automatically.

Smithery (Recommended)

After installing via Smithery, the server is automatically configured with your AI client:

npx -y @smithery/cli install @brianirish/laravel-docs-mcp --client claude

The server runs automatically when your AI client needs it. No manual startup required.

Docker

The Docker container runs the server immediately:

# Basic usage with default settings
docker run ghcr.io/brianirish/laravel-docs-mcp:latest

# Custom configuration with environment variables
docker run -e LOG_LEVEL=DEBUG -e LARAVEL_VERSION=11.x ghcr.io/brianirish/laravel-docs-mcp:latest

# Network transport for remote access
docker run -p 8000:8000 ghcr.io/brianirish/laravel-docs-mcp:latest --transport websocket --host 0.0.0.0 --port 8000

PyPI / Manual Installation

After installing from PyPI or source, start the server manually:

# Basic server start
laravel-docs-server

# Or if installed from source
python laravel_docs_server.py

The server automatically fetches Laravel documentation on first run and can be stopped with Ctrl+C.

Advanced Configuration

For custom deployments, you can configure various options:

Option Description
--docs-path PATH Documentation directory path (default: ./docs)
--server-name NAME Server name (default: LaravelDocs)
--log-level LEVEL Log level: DEBUG, INFO, WARNING, ERROR, CRITICAL (default: INFO)
--transport TYPE Transport method: stdio, websocket, sse (default: stdio)
--host HOST Host to bind to (network transport)
--port PORT Port to listen on (network transport)
--version VERSION Laravel version branch (default: latest available)
--update-docs Update documentation before starting
--force-update Force documentation update

Example with custom options:

python laravel_docs_server.py --docs-path /path/to/docs --version 11.x --update-docs --transport websocket --host localhost --port 8000

Documentation Management

Update documentation independently of the server:

# Update documentation for latest version
python docs_updater.py --target-dir ./docs

# Update specific version
python docs_updater.py --target-dir ./docs --version 11.x

# Update all supported versions
python docs_updater.py --all-versions

# Check if update is needed
python docs_updater.py --check-only

# Force update
python docs_updater.py --force

API Reference

Documentation Tools

  • list_laravel_docs(version: Optional[str]) - List documentation files (all versions or specific version)
  • search_laravel_docs(query: str, version: Optional[str]) - Search documentation for specific terms
  • update_laravel_docs(version: Optional[str], force: bool) - Update documentation
  • laravel_docs_info(version: Optional[str]) - Get documentation version information

Package Recommendation Tools

  • get_laravel_package_recommendations(use_case: str) - Get package recommendations for a use case
  • get_laravel_package_info(package_name: str) - Get details about a specific package
  • get_laravel_package_categories(category: str) - List packages in a specific category
  • get_features_for_laravel_package(package: str) - Get available features for a package

Features and Roadmap

Current Features (v0.2.0)

  • Multi-Version Support: Access documentation for Laravel 6.x through latest version simultaneously
  • Future-Proof Version Detection: Automatically detects and supports new Laravel releases (13.x, 14.x, etc.)
  • Daily Documentation Updates: Automatically syncs with Laravel's GitHub repository every day
  • Dynamic Versioning: Automatic version management based on git tags
  • Automated Releases: Patch releases triggered by documentation updates
  • Multiple Deployment Options: PyPI package, Docker images, and Smithery marketplace
  • Package Recommendations: Intelligent suggestions based on specific use cases
  • Implementation Guidance: Detailed information for common Laravel packages
  • Flexible Configuration: Support for multiple Laravel versions and transport methods
  • Graceful Shutdown: Proper cleanup and signal handling

Upcoming Features

  • 🔧 v0.3.0: Comprehensive testing, performance optimization, enhanced error handling
  • 🔍 v0.4.0: Semantic search, code example extraction, cross-version comparison
  • 📦 v0.5.0: Extended Laravel ecosystem support, community package integration
  • 🎯 v0.6.0: Project analysis, personalized recommendations, migration assistance
  • 🚀 v1.0.0: The definitive Laravel documentation companion

For detailed roadmap information, see ROADMAP.md.

License

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

Contributing

Contributions are welcome! See CONTRIBUTING.md for guidelines.

Acknowledgements

  • Laravel for their excellent documentation
  • Laravel package authors for their contributions to the ecosystem

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

laravel_docs_mcp-0.2.5.tar.gz (3.9 MB view details)

Uploaded Source

Built Distribution

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

laravel_docs_mcp-0.2.5-py3-none-any.whl (4.4 MB view details)

Uploaded Python 3

File details

Details for the file laravel_docs_mcp-0.2.5.tar.gz.

File metadata

  • Download URL: laravel_docs_mcp-0.2.5.tar.gz
  • Upload date:
  • Size: 3.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for laravel_docs_mcp-0.2.5.tar.gz
Algorithm Hash digest
SHA256 4e7a3ac307f07bcf794f1594cd8c60baf8ef45e4e84936939983e05f0b237202
MD5 d60b9e938a28ad6d27a899eb5e03c33e
BLAKE2b-256 93836b34104f3725285a6bb51cacb366059ae727e45fb3425f18d230dde4adef

See more details on using hashes here.

Provenance

The following attestation bundles were made for laravel_docs_mcp-0.2.5.tar.gz:

Publisher: release.yaml on brianirish/laravel-docs-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file laravel_docs_mcp-0.2.5-py3-none-any.whl.

File metadata

File hashes

Hashes for laravel_docs_mcp-0.2.5-py3-none-any.whl
Algorithm Hash digest
SHA256 3475e896f1726981925f0d1149442ef9e0c2ba2043ef5bb581275e034afdc0df
MD5 cdfb99654e027f3eca603130b4f40b10
BLAKE2b-256 7f202601a03f051a80a4020308a2fcf836f27fb0011b22c31628e04cac0d8b5b

See more details on using hashes here.

Provenance

The following attestation bundles were made for laravel_docs_mcp-0.2.5-py3-none-any.whl:

Publisher: release.yaml on brianirish/laravel-docs-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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