Skip to main content

Integrate Model Context Protocol with Django

Project description

✨ Django-MCP 🔮

Python 3.10+ Django 4.0+ License Status Style Types

Supercharge your Django apps with AI assistant capabilities

Django-MCP bridges the gap between Django applications and AI assistants by implementing the Model Context Protocol (MCP). With a few simple decorators, you can expose your app's data and functionality to AI assistants, creating richer, more capable AI interactions.

Want AI to help users explore your data, perform admin tasks, or create content? Django-MCP makes it magical! ✨💫🧙‍♀️

🌟 Features

  • 🔮 Seamless Integration - Add MCP to your Django project with minimal configuration
  • 🧩 Decorator-Based API - Intuitive decorators to expose functions, models, and views
  • 📊 Django ORM Integration - First-class support for Django models and querysets
  • 🛡️ Admin Integration - Expose admin actions and panels to AI assistants
  • 🌐 DRF Compatibility - Works with Django REST Framework viewsets and serializers
  • 🔍 Auto-Discovery - Automatically finds and registers MCP components in your apps
  • 🚀 ASGI Support - Built-in ASGI server for SSE-based MCP communication
  • ⚙️ Flexible Configuration - Configure through familiar Django settings
  • 🔒 Security-Focused - Safe by default with clear permission controls
  • 📝 Contextual Awareness - MCP server understands Django request context

🚀 Installation

# Install with pip
pip install django-mcp

# Or with UV
uv add django-mcp

⚡ Quick Start

1. Add to INSTALLED_APPS

# settings.py
INSTALLED_APPS = [
    # ... your other apps ...
    'django_mcp',
]

# MCP Configuration (optional)
DJANGO_MCP_SERVER_NAME = "My Awesome Django App"
DJANGO_MCP_INSTRUCTIONS = "This server provides access to my Django app."

2. Update your ASGI configuration

# asgi.py
from django_mcp.asgi import get_asgi_application

application = get_asgi_application()

3. Include MCP URLs

# urls.py
from django.urls import path, include

urlpatterns = [
    # ... your other URLs ...
    path('', include('django_mcp.urls')),
]

4. Create your first MCP tool

# myapp/mcp_tools.py - automatically discovered!
from django_mcp.decorators import mcp_tool
from django_mcp.context import Context
from myapp.models import Product

@mcp_tool()
def search_products(context: Context, query: str) -> list:
    """Search for products by name"""
    products = Product.objects.filter(name__icontains=query)[:10]
    return [
        {
            "id": p.id,
            "name": p.name,
            "price": str(p.price),
            "description": p.description,
        }
        for p in products
    ]

5. Expose a Django model

# myapp/models.py
from django.db import models
from django_mcp.decorators import mcp_model_tool, mcp_model_resource

class Product(models.Model):
    name = models.CharField(max_length=100)
    price = models.DecimalField(max_digits=10, decimal_places=2)
    description = models.TextField()

    def __str__(self):
        return self.name

# Expose CRUD operations for Product model
@mcp_model_tool(Product)
def product_tools():
    pass

# Expose Product instances as resources
@mcp_model_resource(Product)
def product_resource():
    pass

6. Connect your AI assistant

Point your MCP-compatible AI assistant (like Claude) to:

http://yourdomain.com/mcp/

Now your AI assistant can use your Django app's functionality!

🧙‍♀️ Using with AI Assistants

  1. Start your Django server with Django-MCP installed
  2. Connect your AI assistant using the MCP protocol URI
  3. The AI can now invoke your tools and access your resources!

Example conversation with an AI:

User: "How many products do we have in our database priced under $20?"

AI: *uses the search_products tool to find this information*
"I found 15 products under $20. The most popular ones are Product A ($15.99),
Product B ($19.50), and Product C ($12.75). Would you like to see more details
about any of these products?"

💫 Examples

Admin Integration

from django_mcp.admin_tools import register_admin_tools
from myapp.admin import ProductAdmin
from myapp.models import Product

# Register all admin actions for Product
register_admin_tools(ProductAdmin, Product)

DRF Integration

from django_mcp.drf_tools import register_drf_viewset
from myapp.api.viewsets import ProductViewSet

# Expose all viewset actions as tools
register_drf_viewset(ProductViewSet)

Creating Resources

from django_mcp.decorators import mcp_resource
from myapp.models import Category

@mcp_resource("category://{slug}")
def get_category(slug: str) -> str:
    """Get information about a product category"""
    category = Category.objects.get(slug=slug)
    products = category.product_set.all()

    return f"""# Category: {category.name}

{category.description}

## Products in this category

{', '.join(p.name for p in products[:10])}

Total products: {products.count()}
"""

🛠️ Advanced Configuration

Django-MCP offers advanced configuration options through Django settings:

# settings.py

# Core settings
DJANGO_MCP_SERVER_NAME = "My Django App"
DJANGO_MCP_URL_PREFIX = "mcp"  # URL prefix for MCP endpoints
DJANGO_MCP_INSTRUCTIONS = "This server provides access to my Django app."
DJANGO_MCP_DEPENDENCIES = []  # MCP dependencies

# Discovery settings
DJANGO_MCP_AUTO_DISCOVER = True  # Auto-discover MCP components
DJANGO_MCP_EXPOSE_MODELS = True  # Auto-expose Django models
DJANGO_MCP_EXPOSE_ADMIN = True  # Auto-expose Django admin
DJANGO_MCP_EXPOSE_DRF = True  # Auto-expose DRF ViewSets

# Security settings
DJANGO_MCP_ALLOWED_ORIGINS = []  # CORS allowed origins for SSE endpoint

📊 Dashboard

Django-MCP includes a built-in dashboard at /mcp/dashboard/ that shows all registered tools, resources, and prompts.

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes
  4. Run tests (pytest)
  5. Commit your changes (git commit -m 'Add some amazing feature')
  6. Push to the branch (git push origin feature/amazing-feature)
  7. Open a Pull Request

📝 License

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


Created by Stefanie Jane 🌠

If you find Django-MCP useful, buy me a Monster Ultra Violet ⚡️

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

iflow_mcp_hyperb1iss_django_mcp-0.1.0.tar.gz (175.3 kB view details)

Uploaded Source

Built Distribution

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

iflow_mcp_hyperb1iss_django_mcp-0.1.0-py3-none-any.whl (48.7 kB view details)

Uploaded Python 3

File details

Details for the file iflow_mcp_hyperb1iss_django_mcp-0.1.0.tar.gz.

File metadata

  • Download URL: iflow_mcp_hyperb1iss_django_mcp-0.1.0.tar.gz
  • Upload date:
  • Size: 175.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_hyperb1iss_django_mcp-0.1.0.tar.gz
Algorithm Hash digest
SHA256 75677e5c42601fb49b304a68ff2aba657bc7518df449febeeb6c71290d7a8a7c
MD5 9145d538bfe24243ddc6234637aaae9e
BLAKE2b-256 077a8384cecd2f305288dc2a1c02f1dfeefb676f729f946035173f38306d6135

See more details on using hashes here.

File details

Details for the file iflow_mcp_hyperb1iss_django_mcp-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_hyperb1iss_django_mcp-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 48.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.28 {"installer":{"name":"uv","version":"0.9.28","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_hyperb1iss_django_mcp-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c4681a04d4471a68cbd6ffc5a74515eeee2478729c1192b3db524e93baf511f7
MD5 23d6dd50d92bb07978d56a10e39ecc42
BLAKE2b-256 0d894032e2eb179dd67876fe07bf36fde297caa9927afeef84b662c9660bfcc0

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