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 clone-able, and used as the starter template for the next big thing our team develops.
- Clone the repo from GitHub/BitBucket
- Delete the
.git
folder - Remove/add anything as you see fit
- Initialize as a new git repository for your own project
- Run the project using
python manage.py runserver
and you should see the default success page provided by Django at http://127.0.0.1:8000/.
- Create a folder with the app name in
apps
. For example:poll
- Run
python manage.py startapp poll apps/poll
from the root directory of the project
- Goal: Develop a structure for both
django-rest-framework
anddjango
projects. - Easily clone-able when starting new projects
- Folder structure only, not “best practices”
- We won’t be enforcing about best practices in implementation details
- We’ll 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.
.
├── 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.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
Each app
should be designed in way to be plug-able, that is, dragged and dropped
into any other project and it’ll work independently.
- 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.
- We like to place all our API components into a package within an app called
api
. For example, in this repository it's theexample_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
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
model
s can be thought of as shared between versions. Therefore, migrating changes should be versioned carefully without breaking different versions of the API.
Currently we're proposing that major changes to the following, constitutes a new API version:
- Representation of data, either for submission or retrieval
- Major optimizations
- Major code reorganization and code refactor
- Contains project configuration files, including the primary URL file
Contains settings split into. Update: As environment specific variables will be handled using environment variables, we've deemed it unnecessary to have separate settings files.base
,local
,production
anddevelopment
.
- Contains Docker, Docker-Compose and nginx specific files for deploying in different environments
- We’ll have CHANGELOG.md
- We’ll have CONTRIBUTING.md
- We’ll have deployment instructions
- We’ll have local startup instructions
- We’ll be writing business logic in services instead of anywhere else.