Skip to main content

Automatic admin registration for Django projects.

Project description

Django Admin Magic

Tests Coverage Test Matrix PyPI version Python versions Django versions

A simple Django app to automatically register your models with the admin site.

What?

It auto-generates all your admin pages programatically! It's awesome!

Why?

Sometimes you're working on a django app and you just wanna see the models, and you don't want to define a brand new admin instance every time, and you just want things to work and look at your data in the admin view. If so, this package is for you!

Tested Dependencies

This package is thoroughly tested against the following dependency combinations:

Django Version Python 3.8 Python 3.9 Python 3.10 Python 3.11 Python 3.12
3.2
4.0
4.1
4.2
5.0

Note: Django 5.0 requires Python 3.10+ and is not compatible with Python 3.8 or 3.9.

Continuous Integration

The test matrix includes:

  • 5 Django versions (3.2, 4.0, 4.1, 4.2, 5.0)
  • 5 Python versions (3.8, 3.9, 3.10, 3.11, 3.12)
  • Code coverage reporting
  • Linting with ruff
  • Security scanning with bandit

Installation

Install the package from PyPI:

pip install django-admin-magic

Then, add it to your INSTALLED_APPS in settings.py:

INSTALLED_APPS = [
    # ...
    "django_admin_magic",
    # ...
]

Demo

A full-featured demo app is included in this repository to showcase all features of Django Admin Magic, including:

  • Automatic admin registration for a variety of model types
  • Sample data for all models
  • Auto-generated superuser for instant login
  • Landing page listing all registered models

Quickstart:

python demo_app/setup_demo.py
python demo_app/manage.py runserver

See demo_app/README.md for full demo instructions, troubleshooting, and customization tips.

Configuration

Django Auto Admin supports multiple ways to specify which apps to register models for:

Method 1: Single App Label (Traditional)

Specify a single app_label in your settings.py:

AUTO_ADMIN_APP_LABEL = "my_app"

Method 2: Multiple App Labels

Specify multiple app labels as a list:

# Option A: Using APP_LABELS setting
AUTO_ADMIN_APP_LABELS = ["my_app", "another_app", "third_app"]

# Option B: Using APP_LABEL as a list
AUTO_ADMIN_APP_LABEL = ["my_app", "another_app", "third_app"]

Method 3: Auto-Discover All Apps

Automatically discover and register all installed apps that have models:

AUTO_ADMIN_AUTO_DISCOVER_ALL_APPS = True

Method 4: Manual Registration in admin.py

If no configuration is provided in settings, you can manually create registrars in your admin.py files:

# In your app's admin.py file
from django_admin_magic.utils import create_auto_admin_registrar

# Auto-determine app label from current package
registrar = create_auto_admin_registrar()

# Or specify a specific app label
registrar = create_auto_admin_registrar("my_app")

# Or register multiple apps
from django_admin_magic.utils import create_auto_admin_registrar_for_apps
registrar = create_auto_admin_registrar_for_apps(["my_app", "another_app"])

# Or register all discovered apps
from django_admin_magic.utils import create_auto_admin_registrar_for_all_apps
registrar = create_auto_admin_registrar_for_all_apps()

Configuration Priority

The library follows this priority order for determining which apps to register:

  1. Explicitly provided parameters in admin.py files
  2. Settings configuration (AUTO_ADMIN_APP_LABEL, AUTO_ADMIN_APP_LABELS, AUTO_ADMIN_AUTO_DISCOVER_ALL_APPS)
  3. Auto-discovery if enabled
  4. No registration if nothing is configured

Advanced Configuration

You can override the default settings by adding them to your settings.py with the AUTO_ADMIN_ prefix.

  • DEFAULT_EXCLUDED_TERMS: A list of strings to exclude from the list_display when it's auto-generated.
  • DEFAULT_DO_NOT_REGISTER_FILTER_STRING_LIST: A list of strings. Any model whose name contains one of these strings will not be registered.
  • ADMIN_TUPLE_ATTRIBUTES_TO_LIST: A list of admin attributes that are typically tuples but need to be lists for modification (e.g., list_display, list_filter).
  • REORDER_LINKIFY_FIELDS: Boolean flag (default: True) that controls whether linkify fields should be reordered to avoid being the first column in admin changelist views. This prevents issues with clicking on the first column, which is often used for row selection checkboxes.

Linkify Field Reordering

By default, Django Auto Admin automatically reorders list_display fields to ensure that linkify functions (foreign key links) are not the first column in admin changelist views. This is because the first column in Django admin is often used for row selection checkboxes, and having a clickable link there can interfere with the selection functionality.

Example:

# Without reordering (problematic):
list_display = [linkify('parent'), 'name', 'created_at']

# With reordering (fixed):
list_display = ['name', linkify('parent'), 'created_at']

You can disable this behavior by setting:

AUTO_ADMIN_REORDER_LINKIFY_FIELDS = False

Usage

Once installed and configured, the library will automatically register all the models in the specified app(s) with the admin site.

Customizing the Admin

You can still customize the admin classes after they've been registered. The AdminModelRegistrar instance provides several methods for this purpose. You can get the registrar instance from the apps registry.

from django.apps import apps

# Get the registrar instance
registrar = apps.get_app_config("django_admin_magic").registrar

# Get the admin class for a model
MyModelAdmin = registrar.return_admin_class_for_model(MyModel)

# Customize the admin class
MyModelAdmin.list_display.append("my_custom_field")

Available Methods

  • append_list_display(model, list_display)
  • prepend_list_display(model, list_display)
  • remove_list_display(model, list_display_to_remove)
  • append_filter_display(model, list_filter)
  • add_search_fields(model, search_fields)
  • update_list_select_related(model, list_select_related)
  • add_admin_method(model, method_name, method_func, short_description=None, is_action=False)
  • append_inline(model, inline_class)

Polymorphic Models

This library automatically detects if django-polymorphic is installed and will use the appropriate admin classes for polymorphic models. There is no extra configuration required.

Development

CI/CD Pipeline

This project uses GitHub Actions for continuous integration and deployment:

  • Tests: Runs across Django 3.2-5.0 and Python 3.8-3.12
  • Linting: Code quality checks with ruff
  • Security: Automated security scanning with bandit
  • Deployment: Automatic PyPI deployment on releases
  • Badges: Real-time status badges updated automatically

For setup instructions, see SETUP_CI_CD.md.

Local Development

# Install development dependencies
pip install -e ".[dev]"

# Run tests
pytest

# Run linting
ruff check .
ruff format .

# Test CI locally
python scripts/test-ci-locally.py

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

django_admin_magic-0.1.2.tar.gz (88.0 kB view details)

Uploaded Source

Built Distribution

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

django_admin_magic-0.1.2-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file django_admin_magic-0.1.2.tar.gz.

File metadata

  • Download URL: django_admin_magic-0.1.2.tar.gz
  • Upload date:
  • Size: 88.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for django_admin_magic-0.1.2.tar.gz
Algorithm Hash digest
SHA256 82f8a526dd79b618db2bef6322266ccb4daa2b809c563067c978b81eeea74309
MD5 33744fb59f3efd4c6482e532fa77330f
BLAKE2b-256 72dff5d88ae7a3fc5b4be185b6f5eeb8abb58fcea15813ad438738abf63c37cd

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_admin_magic-0.1.2.tar.gz:

Publisher: publish.yml on billthefighter/django-admin-magic

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

File details

Details for the file django_admin_magic-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for django_admin_magic-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 48d154ac9282214a4dc5dd7e098be1b8961519576749015f247343f47bdfd0eb
MD5 a59d0f6f898fcd0580fb4dca624cf008
BLAKE2b-256 5c3ee9d0f6a69e60abc462365d67632eb5e95c3739e5f625ea5731c4947898d2

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_admin_magic-0.1.2-py3-none-any.whl:

Publisher: publish.yml on billthefighter/django-admin-magic

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