Django admin MCP integration - expose Django admin models to MCP clients
Project description
django-admin-mcp
Expose Django admin models to MCP (Model Context Protocol) clients via HTTP. Add a mixin to your ModelAdmin classes and get instant access to CRUD operations, admin actions, model history, and more.
Features
- 📦 Zero dependencies beyond Django and Pydantic
- 🎫 Token authentication - secure Bearer token auth with configurable expiry
- 🛡️ Django admin permissions - respects existing view/add/change/delete permissions
- ✏️ Full CRUD - list, get, create, update, delete operations
- ⚡ Admin actions - execute registered Django admin actions
- 📦 Bulk operations - update or delete multiple records at once
- 🔍 Model introspection - describe model fields and relationships
- 🔗 Related objects - traverse foreign keys and reverse relations
- 📜 Change history - access Django admin's history log
- 🔎 Autocomplete - search suggestions for foreign key fields
Installation
pip install django-admin-mcp
Add to your Django project:
# settings.py
INSTALLED_APPS = [
'django_admin_mcp',
# ...
]
# urls.py
from django.urls import path, include
urlpatterns = [
path('mcp/', include('django_admin_mcp.urls')),
# ...
]
Run migrations to create the token model:
python manage.py migrate django_admin_mcp
Quick Start
1. Expose your models
Add the mixin to any ModelAdmin. Set mcp_expose = True to expose direct tools:
from django.contrib import admin
from django_admin_mcp import MCPAdminMixin
from .models import Article, Author
@admin.register(Article)
class ArticleAdmin(MCPAdminMixin, admin.ModelAdmin):
mcp_expose = True # Exposes list_article, get_article, etc.
list_display = ['title', 'author', 'published']
@admin.register(Author)
class AuthorAdmin(MCPAdminMixin, admin.ModelAdmin):
pass # Discoverable via find_models, no direct tools
2. Create an API token
Go to Django admin at /admin/django_admin_mcp/mcptoken/ and create a token. Tokens can optionally be tied to users, groups, or have direct permissions assigned.
3. Configure Claude Code
Add to your Claude Code MCP settings (~/.claude/claude_desktop_config.json or project .mcp.json):
{
"mcpServers": {
"django-admin": {
"url": "http://localhost:8000/mcp/",
"headers": {
"Authorization": "Bearer YOUR_TOKEN"
}
}
}
}
4. Use with Claude
Once configured, Claude can use the tools directly:
User: What models are available in Django admin?
Claude: [calls find_models tool]
User: Show me the latest 10 articles
Claude: [calls list_article with limit=10]
User: Get article #42 and update its title to "New Title"
Claude: [calls get_article with id=42, then update_article]
Available Tools
For each exposed model (e.g., Article), the following tools are generated:
CRUD Operations
| Tool | Description |
|---|---|
list_article |
List all articles with pagination (limit, offset) and filtering |
get_article |
Get a single article by id |
create_article |
Create a new article with field values |
update_article |
Update an existing article by id |
delete_article |
Delete an article by id |
Model Introspection
| Tool | Description |
|---|---|
find_models |
Discover all exposed models and their available tools |
describe_article |
Get field definitions, types, and constraints |
Admin Actions
| Tool | Description |
|---|---|
actions_article |
List available admin actions for the model |
action_article |
Execute an admin action on selected records |
bulk_article |
Bulk update or delete multiple records |
Relationships
| Tool | Description |
|---|---|
related_article |
Get related objects via foreign keys |
history_article |
View Django admin change history |
autocomplete_article |
Search suggestions for autocomplete fields |
HTTP Protocol Reference
For custom integrations, the MCP endpoint accepts POST requests:
# List available tools
curl -X POST http://localhost:8000/mcp/ \
-H "Authorization: Bearer TOKEN" \
-H "Content-Type: application/json" \
-d '{"method": "tools/list"}'
# Call a tool
curl -X POST http://localhost:8000/mcp/ \
-H "Authorization: Bearer TOKEN" \
-H "Content-Type: application/json" \
-d '{"method": "tools/call", "name": "list_article", "arguments": {"limit": 10}}'
Example Conversations
CRUD Operations
User: Create a new article titled "Getting Started with Django"
Claude: I'll create that article for you.
[calls create_article with title="Getting Started with Django"]
Created article #15: "Getting Started with Django"
User: Update article 15 to add content
Claude: [calls update_article with id=15, content="..."]
Updated article #15 successfully.
User: Delete article 15
Claude: [calls delete_article with id=15]
Deleted article #15.
Admin Actions
User: Mark articles 1, 2, and 3 as published
Claude: [calls action_article with action="mark_as_published", ids=[1,2,3]]
Marked 3 articles as published.
Bulk Operations
User: Set status to "archived" for articles 10-15
Claude: [calls bulk_article with operation="update", ids=[10,11,12,13,14,15], data={"status": "archived"}]
Updated 6 articles.
User: Delete all draft articles from last month
Claude: [calls list_article to find drafts, then bulk_article with operation="delete"]
Deleted 12 draft articles.
Exploring Relationships
User: Show me all comments on article 42
Claude: [calls related_article with id=42, relation="comments"]
Found 8 comments on article #42...
User: What changes were made to article 42?
Claude: [calls history_article with id=42]
Change history for article #42:
- 2024-01-15: Changed title (admin)
- 2024-01-10: Created (admin)
Model Discovery
User: What can I manage through MCP?
Claude: [calls find_models]
Available models:
- article (5 tools: list, get, create, update, delete)
- author (5 tools: list, get, create, update, delete)
- category (5 tools: list, get, create, update, delete)
User: What fields does article have?
Claude: [calls describe_article]
Article fields:
- id (AutoField, read-only)
- title (CharField, max_length=200, required)
- content (TextField, optional)
- author (ForeignKey to Author, required)
- published (BooleanField, default=False)
- created_at (DateTimeField, auto)
Security
Two-Level Exposure
Models with MCPAdminMixin are automatically discoverable via the find_models tool, allowing Claude to see what's available. To expose full CRUD tools directly, set mcp_expose = True:
# Discoverable via find_models only
class AuthorAdmin(MCPAdminMixin, admin.ModelAdmin):
pass
# Full tools exposed (list_article, get_article, etc.)
class ArticleAdmin(MCPAdminMixin, admin.ModelAdmin):
mcp_expose = True
Token Authentication
- Tokens are created in Django admin
- Tokens can be associated with a user, groups, or have direct permissions
- Tokens without any permissions have no access (principle of least privilege)
- Token expiry is configurable (default: 90 days)
- Revoke tokens by deleting them in admin
Permission Checking
All operations respect Django admin permissions:
list_*andget_*require view permissioncreate_*requires add permissionupdate_*requires change permissiondelete_*requires delete permission
If a user lacks permission, the operation returns an error.
Requirements
- Python >= 3.10
- Django >= 3.2
- Pydantic >= 2.0
Supported Django Versions
- Django 3.2
- Django 4.0
- Django 4.1
- Django 4.2
- Django 5.0
License
GPL-3.0-or-later
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file django_admin_mcp-0.1.0.tar.gz.
File metadata
- Download URL: django_admin_mcp-0.1.0.tar.gz
- Upload date:
- Size: 69.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d3f7abc12117e725ce830bc9d20e6f8ff634c7255ec1659bf0136689c80aae6b
|
|
| MD5 |
576f2ae57996ad03fefc7506a1121455
|
|
| BLAKE2b-256 |
1473534dcdf2f3a12fd98941cb6aaf0030a17a2b24099d7d75cb3d779bcaf204
|
Provenance
The following attestation bundles were made for django_admin_mcp-0.1.0.tar.gz:
Publisher:
publish.yml on 7tg/django-admin-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
django_admin_mcp-0.1.0.tar.gz -
Subject digest:
d3f7abc12117e725ce830bc9d20e6f8ff634c7255ec1659bf0136689c80aae6b - Sigstore transparency entry: 849933937
- Sigstore integration time:
-
Permalink:
7tg/django-admin-mcp@1852ee7181ef7e8cd9a63afc8ec5a133b11134c3 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/7tg
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1852ee7181ef7e8cd9a63afc8ec5a133b11134c3 -
Trigger Event:
release
-
Statement type:
File details
Details for the file django_admin_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: django_admin_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 49.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
595c3a211dc9b7b2ef78b520dbc3b87b9b50ae0aecb1a57db422549eb63ebc0b
|
|
| MD5 |
4de6013e725d3aadf31497fd43c2139d
|
|
| BLAKE2b-256 |
8047afdcbdd9c56a3e194eea1a6e2c2f2ce3404e8f950efa7810801cc6a685a4
|
Provenance
The following attestation bundles were made for django_admin_mcp-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on 7tg/django-admin-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
django_admin_mcp-0.1.0-py3-none-any.whl -
Subject digest:
595c3a211dc9b7b2ef78b520dbc3b87b9b50ae0aecb1a57db422549eb63ebc0b - Sigstore transparency entry: 849933942
- Sigstore integration time:
-
Permalink:
7tg/django-admin-mcp@1852ee7181ef7e8cd9a63afc8ec5a133b11134c3 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/7tg
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@1852ee7181ef7e8cd9a63afc8ec5a133b11134c3 -
Trigger Event:
release
-
Statement type: