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

✅ Certified by MCP Review

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.8.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.8-py3-none-any.whl (4.4 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: laravel_docs_mcp-0.2.8.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.8.tar.gz
Algorithm Hash digest
SHA256 54dbc9b63688c7d01f7889b452aec6403711216253821f21c490fac1f6fdaf4a
MD5 298a77b4d87dcf5a44117e41cf7dfe1c
BLAKE2b-256 36f1c5dbf1062fe9bf2a7d481308658d2a089f74b0bd6ea2662e570927bf1cd7

See more details on using hashes here.

Provenance

The following attestation bundles were made for laravel_docs_mcp-0.2.8.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.8-py3-none-any.whl.

File metadata

File hashes

Hashes for laravel_docs_mcp-0.2.8-py3-none-any.whl
Algorithm Hash digest
SHA256 f435df1d84f40e8a4fdee0ca7ee905ed64a0db1e8e64314f0250c1a60f0ca719
MD5 76f501307f3e8d54101815c8b0e6ffe5
BLAKE2b-256 3bffd9768c04979f55df3263a24cabc0f170bc000298566672edca3935714388

See more details on using hashes here.

Provenance

The following attestation bundles were made for laravel_docs_mcp-0.2.8-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