django-project-structure/README.md

168 lines
5.8 KiB
Markdown
Raw Normal View History

2022-01-25 03:15:53 +00:00
# Django Project Structure
This is a template/project structure for developing django-based applications -
either strictly through the `django-rest-framework` or just `django`.
2022-01-18 02:27:09 +00:00
2022-01-25 03:15:53 +00:00
The project is meant to be easily clonable, and used as the starter template for
2022-01-26 08:04:30 +00:00
the next big thing our team develops.
2022-01-26 08:12:22 +00:00
## Disclaimer
* I don't have 10 years of experience, nor do I have access to people with 10
years of experience. What I do have is good reference material - books,
conferences, and documentation. These people are smarter than me, they are
better developers and they have more experience - I'm somewhat collecting and
presenting what they do.
## Scope
Develop a structure for both `django-rest-framework` and `django` projects.
Easily clonable when starting new projects
Folder structure only, not “best practices”
No questions, instead well have everything raised as an issue in a repository
We wont be talking 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.
2022-01-26 08:04:30 +00:00
## Project Tree
```bash
.
├── apps
2022-01-26 08:12:22 +00:00
│ ├── app_one # A Django Rest Framework Project
2022-01-26 08:04:30 +00:00
│ │ ├── 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.py
│ │ │ └── __init__.py
│ │ ├── migrations
│ │ │ └── __init__.py
│ │ ├── templates
│ │ ├── tests
│ │ ├── admin.py
│ │ ├── apps.py
│ │ ├── __init__.py
│ │ ├── models.py
│ │ ├── urls.py
│ │ ├── utils.py
│ │ └── views.py
2022-01-26 08:12:22 +00:00
│ └── app_two # A normal Django project
2022-01-26 08:04:30 +00:00
│ ├── migrations
│ │ └── __init__.py
│ ├── templates
│ ├── admin.py
│ ├── apps.py
│ ├── __init__.py
│ ├── models.py
│ ├── service.py
│ ├── tests.py
2022-01-26 08:12:22 +00:00
│ ├── urls.py
2022-01-26 08:04:30 +00:00
│ └── views.py
├── 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
2022-01-25 03:15:53 +00:00
```
2022-01-26 08:12:22 +00:00
2022-01-26 08:04:30 +00:00
## Rationale
2022-01-26 08:12:22 +00:00
Each `app` should be designed in way to be pluggable, that is, dragged and dropped
into any other project and itll work independently.
* We wont have a `core` in our projects. This should be maintained separately
and versioned accordingly as a library.
2022-01-26 08:04:30 +00:00
### `apps`
* A mother-folder containing all apps for our project.
* An app can be a django template project, or an api
2022-01-25 03:15:53 +00:00
2022-01-26 08:12:22 +00:00
#### `api`
* We like to place all our API components into a package within an app called
api/. 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
2022-01-25 03:15:53 +00:00
2022-01-26 08:04:30 +00:00
### `config`
* Contains project configuration files, including the primary URL file
* Contains settings split into `base`, `local`, `production` and `development`
2022-01-25 03:15:53 +00:00
2022-01-26 08:04:30 +00:00
### `deployments`
* Contains Docker and nginx specific files for deploying in different
environments
2022-01-25 03:15:53 +00:00
2022-01-26 08:12:22 +00:00
### `documentation`
* Well have CHANGELOG.md
* Well have CONTRIBUTING.md
* Well have deployment instructions
* Well have local instructions
### `services`
* Well be writing business logic in services instead of anywhere else.
### `gitignore`
* https://github.com/github/gitignore/blob/main/Python.gitignore
2022-01-25 03:15:53 +00:00
## References
2022-01-26 08:04:30 +00:00
- [Two Scoops of Django by Daniel and Audrey Feldroy](https://www.feldroy.com/books/two-scoops-of-django-3-x)
- [Django Best Practices](https://django-best-practices.readthedocs.io/en/latest/index.html)
- [Cookiecutter Django](https://github.com/cookiecutter/cookiecutter-django)
- [HackSoft Django Style Guide](https://github.com/HackSoftware/Django-Styleguide)
- [Radoslav Georgiev - Django Structure for Scale and Longevity](https://www.youtube.com/watch?v=yG3ZdxBb1oo)
2022-01-26 08:12:22 +00:00
- Vaccina Backend Projects (namely `backend-healthcheck`, thank you!)