A Django app for generating boilerplate code
Project description
Django Model Suite File Generator
This project provides a custom Django management command that automatically generates boilerplate files for a specified model within a Django application. It creates admin configurations (list view, change view, permissions, context, displays), API files (serializers, views, URLs, filters, pagination), domain files (selectors, services, validators), and field definitions—all tailored for the given model.
Table of Contents
Features
- Automated file generation: With a single command, generate all necessary boilerplate files for a model.
- Extensible: Easily add or modify generators to customize the files you want to create.
- Organized output: Automatically places generated files in logical paths under your app (e.g.,
admin/<model>/,api/<model>/,domain/selectors/, etc.).
Installation
- install the package
pip install django-model-suite
-
Add to
INSTALLED_APPS: Make sure the app containing this management command (and thedjango_model_suiteif it’s a separate app) is listed in yourINSTALLED_APPSinsettings.py:INSTALLED_APPS = [ # ... "unfold.contrib.filters", # optional, if special filters are needed "unfold.contrib.forms", # optional, if special form elements are needed "unfold.contrib.inlines", # optional, if special inlines are needed "unfold.contrib.import_export", # optional, if django-import-export package is used "unfold.contrib.guardian", # optional, if django-guardian package is used "unfold.contrib.simple_history", # optional, if django-simple-history package is used "django.contrib.admin", # required 'django_model_suite', # ... ]
Usage
-
Run the command to generate files for a specific model
python manage.py generate_files <app_name> <model_name> --components admin domain api
example:
python manage.py generate_files users customer
How It Works
The command uses several generator classes (e.g., FieldsGenerator, ListViewGenerator, SerializerGenerator, etc.)
each responsible for creating a specific part of the Django scaffolding. Once you call:
python manage.py generate_files <app_name> <model_name>
The command:
- Resolves the app path based on the
app_nameprovided. - Retrieves the list of fields for the specified
model_name. - Iterates over a predefined list of components (e.g.,
fields,admin,api,selectors,services,validators). - Generates boilerplate files in each of these sections by calling the respective generators with the model name, app name, and field definitions.
File Structure
After running the command, you’ll typically see the following structure in your app (depending on which components the script generates):
your_app/
│
├─ fields/
│ └─ fields_<model_name>.py (Generated fields definitions)
│
├─ admin/
│ └─ <model_name>/
│ ├─ list_view_<model_name>.py (List view for model in Django admin)
│ ├─ change_view_<model_name>.py (Change view for model in Django admin)
│ ├─ permissions_<model_name>.py (Permissions handling in admin)
│ ├─ context_<model_name>.py (Context data for admin templates)
│ ├─ display_<model_name>.py (Display logic for admin list/change)
│ └─ admin_<model_name>.py (Main Admin registration)
│
├─ api/
│ └─ <model_name>/
│ ├─ serializer_<model_name>.py (Django Rest Framework serializer)
│ ├─ view_<model_name>.py (ViewSets or API views)
│ ├─ url_<model_name>.py (API URL configurations)
│ ├─ filter_<model_name>.py (Filter classes for the model API)
│ └─ pagination_<model_name>.py (Pagination settings for the model API)
│
└─ domain/
├─ selectors/
│ └─ selector_<model_name>.py (Query logic)
├─ services/
│ └─ service_<model_name>.py (Business logic services)
└─ validators/
└─ validator_<model_name>.py (Validation logic)
You can then import and integrate these files as needed in your Django project.
Project details
Release history Release notifications | RSS feed
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_model_suite-0.1.11.tar.gz.
File metadata
- Download URL: django_model_suite-0.1.11.tar.gz
- Upload date:
- Size: 14.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8afac448e3f10275f281d2f42a0aba7511f5878c5696faed738a0ba93a19f3db
|
|
| MD5 |
736753f15f1ac1f6aad78e25acee5e02
|
|
| BLAKE2b-256 |
c09ee1c11e68e38ae8fa8d4cb608d947ce9795ff1438310806344561c423c207
|
File details
Details for the file django_model_suite-0.1.11-py3-none-any.whl.
File metadata
- Download URL: django_model_suite-0.1.11-py3-none-any.whl
- Upload date:
- Size: 21.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8ed81feb75a64e44b6497a8f30b0dafb2d561d5c4d0c0b4d5cb492f3c8c10eb5
|
|
| MD5 |
424886c1a97d28413dda3b882b7eb34f
|
|
| BLAKE2b-256 |
c5b02658a139ac7ef3d16ad74067ea9566fce499c73c3d599d9ea94e273f2028
|