Skip to main content

Create new Django applications with pizazz. ๐Ÿš€

Project description

django-new โœจ

Create new Django applications with pizazz. ๐Ÿš€

Features ๐Ÿš€

  • Interactive mode for creating new applications.
  • Predefined structure for typical use cases:
    • API
    • data
    • website
    • worker
  • Create new Django applications based on a starter template.
  • Create "minimal" projects (aka DEP-15) for a streamlined codebase.
  • When creating new apps, automatically add them to INSTALLED_APPS.
  • Create other files that are typically used in a Django project with sensible defaults:
    • .env - Environment variables
    • .gitignore - git ignore patterns
    • pyproject.toml - Python project configuration (PEP 621 compliant)
    • README.md - Project documentation

Goals ๐ŸŽฏ

  • Strike a balance between django-admin startproject / django-admin startapp and more full-fledged starter projects.
  • Have some opinions about the structure for different use cases, but try to avoid prescribing specific libraries.
  • Reduce the confusion between a "project" and "app".
  • Be backwards-compatible with existing Django projects.
  • Create folders and files automatically with sensible defaults for modern Python workflows that the majority of developers will need.

NOTE: this is a work in progress and is not yet ready for production use. If you are an expert Django developer, you might disagree with at least some of the opinions here. That's ok. There is a ton (too much?) of bike shedding around project creation. I am open to different opinions and feedback, but I am also focused on handling the 80/20 for new Django projects and provide some patterns based on my personal experience.

Guiding principles ๐Ÿ•ฏ๏ธ

  • There are three main use cases for Django: website, API, and worker; they serve different use cases, and each has a unique (but defined) file structure.
  • The distinction between "project" and "app" can be confusing for new developers, and creating a "project" without an "app" is an outlier.
  • Knowing when to use either django-admin or manage.py is a common source of confusion.
  • The DJANGO_SETTINGS_MODULE environment variable is flexible, but annoying to deal with; there should be simpler patterns for managing different environments.
  • Having a slightly non-ideal standard that mostly works for a majority of developers is better than no standard at all.

Hot takes ๐Ÿ”ฅ

  • Project-specific files, e.g. settings.py, should be in a config directory.
  • When creating a new app in a project, it should automatically be added to INSTALLED_APPS.
  • Tests should be written with pytest and should be located in a tests directory under the project root.
  • Settings should be split into multiple files per environment (e.g. config/settings/base.py, config/settings/production.py, etc.)

Usage ๐Ÿ“–

django-new is designed to be used with uvx or pipx.

uvx django-new [--api | --data | --web | --worker] [name] [folder]

django-new creates a standard folder structure for different use cases (based on the --api, --web, or --worker flag) along with a config folder to store "project-level" files like settings.py. django-new also creates a few typically used files (if they do not already exist) when creating a new application:

  • .env - Local Environment variables
  • .gitignore - git configuration
  • pyproject.toml - Configuration and dependencies
  • README.md - Documentation

Interactive mode

When no arguments are provided, django-new will prompt you for the application name and folder location.

uvx django-new

Create a new API

uvx django-new --api [name] [folder]
.
โ”œโ”€โ”€ api
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ views.py
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new data-only application

uvx django-new --data [name] [folder]
.
โ”œโ”€โ”€ data
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ views.py
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new website

uvx django-new --web [name] [folder]
.
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ static
โ”‚   โ”œโ”€โ”€ css
โ”‚   โ”œโ”€โ”€ img
โ”‚   โ””โ”€โ”€ js
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ web
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ templates
โ”‚   โ”œโ”€โ”€ templatetags
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ views.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new worker

uvx django-new --worker [name] [folder]
.
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ worker
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ””โ”€โ”€ tasks.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new default application

uvx django-new [name] [folder]
.
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ {name}
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ views.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new "minimal" application

Based on the minimal project in DEP-15, this will create a new Django project and app within a single directory.

uvx django-new --api --minimal [name] [folder]
uvx django-new --data --minimal [name] [folder]
uvx django-new --web --minimal [name] [folder]
uvx django-new --worker --minimal [name] [folder]
uvx django-new --minimal [name] [folder]
.
โ”œโ”€โ”€ {name}
โ”‚   โ”œโ”€โ”€ migrations
โ”‚   โ”‚   โ””โ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ admin.py
โ”‚   โ”œโ”€โ”€ apps.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ models.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ”œโ”€โ”€ views.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a new application based on a starter

Use the provided path to create a custom application.

uvx django-new --starter={path} [name] [folder]

Starters use the built-in Django startproject --template functionality under the hood.

The path passed into the starter option can be a directory, local archive file, or a remote URL. Remote URLs must point to an archive file using a http, https, or ftp protocol.

Supported archive file extensions: .zip, .tar, .tar.gz, .tar.bz2, .tar.xz, .tar.lzma, .tgz, .tbz2, .txz, .tlz

uvx django-new --starter=https://github.com/githubuser/django-app-template/archive/main.zip new_project

Starters from untrusted sources should be carefully inspected before use to prevent potential security issues.

Variable replacement

Starters can use variables that will be replaced in the included .py files using Django template syntax, like {{ project_name }}.

The context used for variable replacement:

{
    "project_name": "the project name provided to django-new, e.g. 'myproject'",
    "project_directory": "/full/path/to/the/myproject",
    "secret_key": "a randomly generated secret key",
    "docs_version": "version of the documentation",
    "django_version": "version of Django"
}

Add new app to an existing Django project

If a project already exists in the specified folder, django-new will add a new app to it. Use the same flags as above to create a specific type of app.

uvx django-new --api [name] [folder]
uvx django-new --data [name] [folder]
uvx django-new --web [name] [folder]
uvx django-new --worker [name] [folder]
uvx django-new [name] [folder]

Create a bare project

When a non-project folder is specified and an app should not be created, use the --project flag.

uvx django-new --project [name] [folder]
.
โ”œโ”€โ”€ config
โ”‚   โ”œโ”€โ”€ __init__.py
โ”‚   โ”œโ”€โ”€ asgi.py
โ”‚   โ”œโ”€โ”€ settings.py
โ”‚   โ”œโ”€โ”€ urls.py
โ”‚   โ””โ”€โ”€ wsgi.py
โ”œโ”€โ”€ tests
โ”‚   โ””โ”€โ”€ __init__.py
โ”œโ”€โ”€ .env
โ”œโ”€โ”€ .gitignore
โ”œโ”€โ”€ manage.py
โ”œโ”€โ”€ pyproject.toml
โ””โ”€โ”€ README.md

Create a bare app

When a non-project folder is specified and a project should not be created, use the --app flag.

uvx django-new --app [name] [folder]
.
โ””โ”€โ”€ {name}
    โ”œโ”€โ”€ migrations
    โ”‚   โ””โ”€โ”€ __init__.py
    โ”œโ”€โ”€ __init__.py
    โ”œโ”€โ”€ admin.py
    โ”œโ”€โ”€ apps.py
    โ”œโ”€โ”€ models.py
    โ”œโ”€โ”€ urls.py
    โ””โ”€โ”€ views.py

Inspiration โค๏ธ

Heavily inspired by DEP-15, although it approaches the solution from a different angle.

Tests

just test

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_new-0.6.0.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

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

django_new-0.6.0-py3-none-any.whl (30.3 kB view details)

Uploaded Python 3

File details

Details for the file django_new-0.6.0.tar.gz.

File metadata

  • Download URL: django_new-0.6.0.tar.gz
  • Upload date:
  • Size: 22.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_new-0.6.0.tar.gz
Algorithm Hash digest
SHA256 5e27a6374b5fa9e7bc017d0af01e373ebf4f4576d6bf4fe9e11c85467b0a96e6
MD5 a48704ff57846e4bc8e54aa953e4e689
BLAKE2b-256 09fcac962cba66c0d4a6d1ac68b1b255136da21a95fc268d66231dabfdd2ffe5

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_new-0.6.0.tar.gz:

Publisher: publish.yml on adamghill/django-new

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_new-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: django_new-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 30.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for django_new-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 756c927093525627394c48247dd5fbd9d97ad66f2ffade41a95afe7e13931718
MD5 914caffc561a6321bf93dac456413aa0
BLAKE2b-256 de24c72dbe91ef01a874d4c65c73e6f8850c7a4fe554a5232fd8b0ae4cb4210d

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_new-0.6.0-py3-none-any.whl:

Publisher: publish.yml on adamghill/django-new

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