Skip to content
This repository has been archived by the owner on Mar 30, 2021. It is now read-only.

A Django project skeleton which can help bootstrap a new project in minutes

License

Notifications You must be signed in to change notification settings

intelligems/django-skeleton

Repository files navigation

Django Project Skeleton - Intelligems

A Django project template that makes no assumptions but saves you a couple of initial work hours per project.

Note: Since pipenv is gaining traction in the Python community we offer support for both requirements.txt and pipenv workflows. Master branch will support requirements.txt workflow, but you can find support for pipenv package management workflow and compatible Dockerfiles in branch: pipenv

Repository unmaintained

As Intelligems has stopped operations since Aug19, this repository remains unmaintained. Whoever may be interested to keep it up-to-date or extend it, DM koslib to arrange project transfer.

General

This is a project template, which means no naming conventions apply in the project name. There are some pre-loaded 3rd-party libraries which we have found are very common in all our applications.

3rd-party apps it includes:

  • celery, for background jobs processing
  • flower, celery monitoring
  • django-storages, to store files in AWS S3 (the most commonly used object storage)
  • django-anymail, for transactional emails
  • djangorestframework, for your RESTful API
  • django-rest-swagger, to generate documentation for your RESTful API endpoints
  • django-filter, which provides filtering capabilities in the DRF API views (and not only there)
  • django-guardian, for custom object or model level permissions
  • django-extensions, offering a collection of custom extensions for Django
  • django-environ, following the 12-factor methodology
  • django-health-check, for Django health checking
  • django-pdb, command line Django debugger
  • django-storages, easy integration with storage backends
  • python-decouple, safe casting of environment variables to Python types in Django settings.
  • s3transfer, boto3, integration with AWS S3
  • fabric, automation and provisioning
  • PyYaml, for auto-generation of yml files and templating

Prerequisites

  • Python3 (Python 3.7 not working yet)
  • Git
  • pip
  • virtualenv (recommended)

How to use

To start a new project with this template, it's really simple:

django-admin.py startproject \
  --template=https://github.com/intelligems/django-skeleton/zipball/master \
  --extension=py,rst,yml,sh,production \
  --name=Procfile \
  <project_name>

After that just keep doing the configuration you use as a standard in your Django projects. The modules directory is intended to gather your django apps, so that you keep a clean and simple project structure.

Templating

The skeleton has support for template values in .drone.yml automation and swarm stack-deploy compose yml files.

After the skeleton has been built, you can provide specific configuration values in config_source.yml that will populate the templates and create all necessary files.

Example config_source.yml

project_name: testproject

# Swarm stack compose file
repo_url: aws_id.dkr.ecr.us-east-1.amazonaws.com
redis_url: redis.staging.elasticache
memcached_url: memcached.staging.elasticache

# Staging environment drone
staging_repo_url: aws_id.dkr.ecr.us-east-1.amazonaws.com
staging_region: us-east-1
staging_ip_instances:
  - 192.168.2.1
  - 192.168.2.2

# Production environment drone
production_repo_url: aws_id.dkr.ecr.eu-west-1.amazonaws.com
production_region: eu-west-1
production_ip_instances:
  - 172.131.0.1
  - 172.131.0.2
  - 172.131.0.3

Also keep in mind that project_name field does not need to be changed as it's value is automatically generated during project startup.

If you are happy with the configuration values, you can create the yml files by running bootstrap.sh from inside a virtualenv and also inside the project folder created.

chmod +x bootstrap.sh
./bootstrap.sh

Warning any subsequent call to bootstrap.sh or python -m config_templates.chartmap will ovewrite auto-generated .yml files from earlier runs.

Docker and Heroku support

There is built-in docker support. We have added the Dockerfile and docker-compose.yml file that suits our working set, which of course you may feel free to change and adapt as per your requirements.

As you will see, by default our .stolos.yml file is configured to be working with Stolos.io, which is our preferred staging environment provider.

Also, you will find a Procfile inside, with just the basic config required to get your project running on Heroku asap.

Roadmap

  • Add basic Drone CI config file
  • Any ideas? You can contribute!

How to Build Documentation with Sphinx

  • Create a docs folder and answer the sphinx-quickstart's setup questions to initialize the documentation folder:

    $ mkdir docs
    $ cd docs
    $ sphinx-quickstart
    

    Most of the questions have recommended answers that will do for most cases. Simply fill in the project name, author etc., as asked.

  • The process will create inside the docs folder some sub-folders and some configuration files. We need to do the following inside docs to be set to go:

    $ mkdir source/this_project
    

    Then in an editor open the source/conf.py file and add the following:

    1. On the Path Setup section add:

      import os
      import sys
      import django
      
      sys.path.insert(0, os.path.abspath('../..'))
      os.environ['DJANGO_SETTINGS_MODULE'] = 'this_project.settings'
      django.setup()
      
    2. If we want to use the autodoc extension to create docs from docstrings automatically then we add the following to the extensions list:

      extensions = ['sphinx.ext.autodoc', ...]
      

      If we use autodoc we need also to add the following in the exclude_patterns in order to avoid seeing migrations, urls etc on the documentation:

      exclude_patterns = [
          "**/*.migrations*",
          "**/*.admin*",
          "**/*.apps*",
          "**/*.tests*",
          "**/*.urls*",
      ]
      
    3. To use the RTD Theme (it is already installed via pip) we need to modify the html_theme as follows:

      html_theme = "sphinx_rtd_theme"
      
  • To generate documentation from docstrings we need to execute the following:

    $ cd docs
    $ sphinx-apidoc -fMe -o source/your_project/ ..
    $ make clean && make html
    

    The .rst results will be located inside source/your_project and the .html files will be inside the docs/build folder.

  • To create custom documentation we will need to follow the official Sphinx documentation.

About

A Django project skeleton which can help bootstrap a new project in minutes

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •