This is a template/project structure for developing django-based applications - either strictly through the django-rest-framework or just django.
Go to file
saqibur 5e86cb98e6 Add common folder 2022-08-15 09:34:17 +06:00
apps Update README.md 2022-08-09 11:14:10 +06:00
common Add common folder 2022-08-15 09:34:17 +06:00
config Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
deployments Fix project tree 2022-01-26 14:04:30 +06:00
docs Add initial structure 2022-01-26 08:45:34 +06:00
logs Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
media Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
requirements Add initial structure 2022-01-26 08:45:34 +06:00
scripts Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
static Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
.env.example Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
.gitignore Add initial structure 2022-01-26 08:45:34 +06:00
README.md Add common folder 2022-08-15 09:34:17 +06:00
entrypoint.sh Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
manage.py Add initial structure 2022-01-26 08:45:34 +06:00
pyproject.toml Remove unnecessary example application and add additional more to core 2022-08-09 10:13:35 +06:00
pytest.ini Add initial structure 2022-01-26 08:45:34 +06:00

README.md

Django Project Structure

This is a template/project structure for developing django-based applications - either strictly through the django-rest-framework or just django.

The project is meant to be easily clonable, and used as the starter template for the next big thing our team develops.

Getting Started

  1. Clone the repo from GitHub/BitBucket
  2. Delete the .git folder
  3. Remove/add anything as you see fit
  4. Initialize as a new git repository for your own project
  5. DONE.

Creating an App

  1. Create a folder with the app name in apps. For example: poll
  2. Run python manage.py startapp poll apps/poll from the root directory of the project

Scope

  • Goal: Develop a structure for both django-rest-framework and django projects.
  • Easily clonable when starting new projects
  • Folder structure only, not “best practices”
  • We wont be enforcing about best practices in implementation details
  • Well hold all questions in a GitHub repository, so things can move forward
  • The discussions also serve historic significance - people can backtrack why some decisions were made.

Project Tree

.
├── apps
│   └── example_api # A django rest app
│       ├── api
│       │   ├── v1
│       │   │   ├── __init__.py
│       │   │   ├── serializers.py
│       │   │   ├── services.py
│       │   │   ├── tests.py
│       │   │   ├── urls.py
│       │   │   └── views.py
│       │   ├── v2
│       │   │   ├── __init__.py
│       │   │   ├── serializers.py
│       │   │   ├── services.py
│       │   │   ├── tests.py
│       │   │   ├── urls.py
│       │   │   └── views.py
│       │   └── __init__.py
│       ├── management
│       │   ├── commands
│       │   │   └── command.py
│       │   └── __init__.py
│       ├── migrations
│       │   └── __init__.py
│       ├── templates
│       ├── tests
│       ├── admin.py
│       ├── apps.py
│       ├── __init__.py
│       ├── models.py
│       ├── urls.py
│       ├── utils.py
│       └── views.py
├── common # An optional folder containing common "stuff" for the entire project
├── config
│   ├── settings
│   │   ├── base.py
│   │   ├── development.py
│   │   ├── __init__.py
│   │   ├── local.py
│   │   ├── local_template.py
│   │   └── production.py
│   ├── asgi.py
│   ├── __init__.py
│   ├── urls.py
│   └── wsgi.py
├── deployments
│   ├── django-project
│   │   └── Dockerfile
│   ├── nginx
│   │   ├── default.conf
│   │   └── Dockerfile
│   └── docker-compose.yml
├── docs
│   ├── CHANGELOG.md
│   ├── CONTRIBUTING.md
│   ├── deployment.md
│   ├── local-development.md
│   └── swagger.yaml
├── requirements
│   ├── common.txt
│   ├── development.txt
│   ├── local.txt
│   └── production.txt
├── static
├── entrypoint.sh
├── manage.py
├── pytest.ini
└── README.md

Rationale

Each app should be designed in way to be pluggable, that is, dragged and dropped into any other project and itll work independently.

apps

  • A mother-folder containing all apps for our project. Congruent to any JS-framework's src folder.
  • An app can be a django template project, or an API.

api

  • We like to place all our API components into a package within an app called api. For example, in this repository it's the example_api/api folder. That allows us to isolate our API components in a consistent location. If we were to put it in the root of our app, then we would end up with a huge list of API-specific modules in the general area of the app.

For projects with a lot of small, interconnecting apps, it can be hard to hunt down where a particular API view lives. In contrast to placing all API code within each relevant app, sometimes it makes more sense to build an app specifically for the API. This is where all the serializers, renderers, and views are placed. Therefore, the name of the app should reflect its API version

api-versioning

It might often be necessary to support multiple versions of an API throughout the lifetime of a project. Therefore, we're adding in support right from the start.

For different API versions, we're assuming the following will change:

  • Serializers
  • Views
  • URLs
  • Services

models can be thought of as shared between versions. Therefore, migrating changes should be versioned carefully without breaking different versions of the API.

What's Version 2?

Currently we're proposing that major changes to the following, constitutes a new API version:

  1. Representation of data, either for submission or retrieval
  2. Major optimizations
  3. Major code reorganization and code refactor

config

  • Contains project configuration files, including the primary URL file
  • Contains settings split into base, local, production and development.

deployments

  • Contains Docker, Docker-Compose and nginx specific files for deploying in different environments

documentation

  • Well have CHANGELOG.md
  • Well have CONTRIBUTING.md
  • Well have deployment instructions
  • Well have local startup instructions

services

  • Well be writing business logic in services instead of anywhere else.

gitignore

References