Skip to main content

The control room for your Django app

Project description

Tests codecov PyPI version Python versions License: MIT Downloads Awesome Django

Django Control Room

Django Control Room

A centralized dashboard for managing Django admin panels

Official SiteFeaturesInstallationQuick StartOfficial PanelsDocumentation


Features

  • Centralized Dashboard - All your admin panels in one place
  • Plugin System - Discover and install panels via PyPI
  • Beautiful UI - Modern, responsive design with dark mode support
  • Secure - Package verification prevents panel hijacking
  • Easy Integration - Works seamlessly with Django admin
  • Official Panels - Pre-built panels for common tasks

Django Control Room Dashboard

Installation

Basic Installation

pip install dj-control-room

Install with Official Panels

# Install with specific panels
pip install dj-control-room[redis,cache,urls]

# Or install with all official panels
pip install dj-control-room[all]

Available panel extras:

  • redis - Redis connection manager and inspector
  • cache - Django cache backend inspector
  • urls - URL pattern browser and tester
  • celery - Celery task monitor
  • signals - Django signals inspector (coming soon)
  • all - All official panels

Quick Start

1. Add to INSTALLED_APPS

# settings.py
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    
    # Add any panels you installed
    'dj_redis_panel',
    'dj_cache_panel',
    'dj_urls_panel',
    
    # Then add Django Control Room
    'dj_control_room',
    # Your apps
    # ...
]

2. Configure URLs

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

urlpatterns = [
    # Panel URLs (include each panel you installed)
    path('admin/dj-redis-panel/', include('dj_redis_panel.urls')),
    path('admin/dj-cache-panel/', include('dj_cache_panel.urls')),
    path('admin/dj-urls-panel/', include('dj_urls_panel.urls')),
    
    # Control Room dashboard
    path('admin/dj-control-room/', include('dj_control_room.urls')),
    
    # Django admin
    path('admin/', admin.site.urls),
]

3. Access the Control Room

  1. Run migrations: python manage.py migrate
  2. Start your server: python manage.py runserver
  3. Navigate to http://localhost:8000/admin/dj-control-room/

Admin Sidebar Integration

All installed panels appear in the Django admin sidebar under "Django Control Room":

Admin Sidebar

Control Sidebar Behavior (Optional)

# settings.py
DJ_CONTROL_ROOM_SETTINGS = {
    # Global: Show panels in both Control Room and their own sections
    'REGISTER_PANELS_IN_ADMIN': False,  # Default: False

    # Per-panel: Override for specific panels
    'PANEL_ADMIN_REGISTRATION': {
        'dj_redis_panel': True,   # Redis in both places
        'dj_cache_panel': False,  # Cache only in Control Room
    },

    # CSS: load built-in styles and/or inject your own
    'LOAD_DEFAULT_CSS': True,
    # Static paths are relative to app's static/ dir (e.g. 'myapp/css/overrides.css'
    # for a file at myapp/static/myapp/css/overrides.css). Full URLs also accepted.
    'EXTRA_CSS': [],
}

Official Panels

Official Panels

Available Now

Panel Description Install
Redis Panel Monitor connections, inspect keys, view memory usage pip install dj-redis-panel
Cache Panel Inspect cache entries, view hit/miss ratios pip install dj-cache-panel
URLs Panel Browse URL patterns, test resolvers pip install dj-urls-panel
Celery Panel Monitor workers, track task queues pip install dj-celery-panel

Coming Soon

Panel Description Status
Signals Panel Inspect Django signals, debug connections In Development
Error Panel Monitor errors, exceptions, and tracebacks In Development

Creating Custom Panels

The fastest way to create a new panel is using our official cookiecutter template:

pip install cookiecutter
cookiecutter https://github.com/yassi/cookiecutter-dj-control-room-plugin

This generates a complete panel structure with Django admin integration, tests, documentation, and Docker setup.

Manual Panel Creation

You can also create panels manually by implementing a simple interface:

# my_panel/panel.py
class MyPanel:
    name = "My Panel"
    description = "My awesome panel"
    icon = "chart"
# pyproject.toml
[project.entry-points."dj_control_room.panels"]
my_panel = "my_panel.panel:MyPanel"

See our Creating Panels Doc for full documentation or use our Build your own panel guide which uses our cookiecutter template to get started quickly.

Security

Django Control Room includes built-in security features:

  • Package Verification - Featured panels are verified by package origin
  • Staff-Only Access - Requires Django staff/superuser permissions
  • No Malicious Hijacking - Prevents panels from impersonating official packages

Documentation

Visit the official site at djangocontrolroom.com for guides, tutorials, and examples.

Full documentation: https://yassi.github.io/dj-control-room/

Requirements

  • Python 3.9+
  • Django 4.2+

Contributing

We welcome contributions! Please see our Contributing Guide for details.

License

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

Credits

Created by Yasser Toruno


Official SiteStar us on GitHubReport BugRequest Feature

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

dj_control_room-1.1.2.tar.gz (1.4 MB view details)

Uploaded Source

Built Distribution

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

dj_control_room-1.1.2-py3-none-any.whl (1.4 MB view details)

Uploaded Python 3

File details

Details for the file dj_control_room-1.1.2.tar.gz.

File metadata

  • Download URL: dj_control_room-1.1.2.tar.gz
  • Upload date:
  • Size: 1.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for dj_control_room-1.1.2.tar.gz
Algorithm Hash digest
SHA256 f614527a552c0c46eadaf50b829ace9dea0fe8e790123681fdd443212020d23a
MD5 c31531ce14a79b14d7d8b30fe8f4a9ef
BLAKE2b-256 84091fb9954260162b7f17111625338eef8c095a0c2afb0af3c469dc7142ca78

See more details on using hashes here.

Provenance

The following attestation bundles were made for dj_control_room-1.1.2.tar.gz:

Publisher: python-publish.yml on yassi/dj-control-room

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

File details

Details for the file dj_control_room-1.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for dj_control_room-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 e7246718e35e3a1c9160354b3724080dd57807d8acf5f90038989e9a92b3e602
MD5 0361b15a1d244dd8f1c3c3a5c0384f7b
BLAKE2b-256 73882f9bca1346b3dd1b85d1087f7da55fe0d21932f592db38624ce855f30050

See more details on using hashes here.

Provenance

The following attestation bundles were made for dj_control_room-1.1.2-py3-none-any.whl:

Publisher: python-publish.yml on yassi/dj-control-room

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