Skip to main content

Create custom Django project with style...

Project description

Python Django Version Codacy Badge

django-vb-admin

Creates custom Django project layout. Compatible with Django 2.x and requires Python 3.7.x or higher version. By default, project uses PostgreSQL, this means you need to install :) macOS users can install via brew install postgres

Installation

Let’s create PostgreSQL database first:

$ createdb -E UTF8 -T template0 my_project_dev  # create your database
$ createdb -E UTF8 -T template0 --lc-collate=tr_TR.UTF-8 --lc-ctype=tr_TR.UTF-8 my_project_dev  # or create your database with Turkish locale support

Now, install package:

$ pip install django-vb-admin

This package heavily depends on django-vb-baseapp. All the rake tasks are related to django-vb-baseapp. You don’t need to do anything, django-vb-admin installs required packages automatically.

Usage

After installation, you’ll have a command: django-vb-admin

$ django-vb-admin -h

usage: django-vb-admin [-h] [-t TARGET] [-v {0,1}] [--version]
                       [{startproject}]

Create new Django project

positional arguments:
  {startproject}        Name of command(s)

optional arguments:
  -h, --help            show this help message and exit
  -t TARGET, --target TARGET
                        Target path
  -v {0,1}, --verbosity {0,1}
                        Verbose mode
  --version             show program's version number and exit

Let’s create project:

$ mkdir /path/to/my-django-project/
$ cd /path/to/my-django-project
$ django-vb-admin startproject                             # create structure to current working directory

# or
$ django-vb-admin startproject --target="/path/to/folder"  # create structure to given path

When creation completed, you can create your virtual environment and set your environment variables:

export DJANGO_SECRET=$(head -c 75 /dev/random | base64 | tr -dc 'a-zA-Z0-9' | head -c 50)
export DATABASE_URL="postgres://localhost:5432/my_project_dev"

then;

$ pip install -r requirements/development.pip

Directory structure:

.
├── applications
├── config
│   ├── settings
│      ├── __init__.py
│      ├── base.py
│      ├── development.example.py
│      ├── heroku.py
│      ├── production.py
│      └── test.example.py
│   ├── __init__.py
│   ├── urls.py
│   └── wsgi.py
├── locale
│   └── tr
│       └── LC_MESSAGES
│           ├── django.mo
│           └── django.po
├── requirements
│   ├── base.pip
│   ├── development.pip
│   ├── heroku.pip
│   └── production.pip
├── static
│   ├── css
│      ├── application.css
│      └── bulma.min.X.X.X.css
│   ├── images
│      └── .gitkeep
│   └── js
│       ├── .gitkeep
│       ├── application.js
│       └── fontawesome.X.X.X.all.js
├── templates
│   ├── admin
│      └── base_site.html
│   ├── custom_errors
│      ├── 400.html
│      ├── 403.html
│      ├── 404.html
│      └── 500.html
│   └── base.html
├── .bandit
├── .flake8
├── .gitignore
├── .isort.cfg
├── .pylintrc
├── .python-version
├── .ruby-version
├── .tm_properties
├── Procfile
├── manage.py
├── pyproject.toml
├── requirements.txt
└── runtime.txt

Now you can init git:

$ cd /path/to/my-django-project/
$ git init

Packages

Common packages: requirements/base.pip

Django==2.2.6
Pillow==6.2.0
django-extensions==2.2.3
python-slugify==3.0.6
psycopg2-binary==2.8.3
dj-database-url==0.5.0

Development packages: requirements/development.pip

-r base.pip
ipython==7.8.0
bpython==0.18
ptpython==2.0.6
Werkzeug==0.16.0
django-debug-toolbar==2.0
coverage==4.5.4
isort==4.3.21
black==19.3b0
flake8==3.7.8
flake8-bandit==2.1.2
flake8-blind-except==0.1.1
flake8-bugbear==19.8.0
flake8-builtins==1.4.1
flake8-polyfill==1.0.2
flake8-print==3.1.1
flake8-quotes==2.1.0
flake8-string-format==0.2.3
pylint==2.4.2

Heroku related packages: requirements/heroku.pip

-r base.pip
gunicorn==19.9.0
whitenoise==4.1.4
boto3==1.9.253
django-storages==1.7.2

Built-in support for AWS-S3 Storage. You need to create/get your:

  • S3_ACCESS_KEY_ID
  • S3_SECRET_ACCESS_KEY

and set those variables on Heroku. Please check config/settings/heroku.py for more details. Basic Heroku setup:

$ heroku login
$ heroku apps:create
$ heroku addons:create heroku-postgresql:hobby-dev
$ heroku config:set DJANGO_ENV="heroku"
$ heroku config:set DJANGO_SECRET='YOUR_GENERATED_RANDOM_SECRET'
$ heroku config:set S3_ACCESS_KEY_ID='YOUR_S3_ACCESS_KEY_ID'
$ heroku config:set S3_SECRET_ACCESS_KEY='YOUR_S3_SECRET_ACCESS_KEY'
$ heroku config:set S3_BUCKET_NAME='YOUR_S3_BUCKET_NAME'
$ heroku config:set WEB_CONCURRENCY=3
$ git push heroku master
$ heroku run python manage.py migrate
$ heroku run python manage.py createsuperuser

If you want to use email reporter for Django errors, you need to set couple more environment variables on Heroku side too.

Linux/Production packages: requirements/production.pip

-r base.pip
uWSGI==2.0.18

Rakefile

If you have Ruby installed on your system (if you are on macOS you’ll have it by default) you can easily automate your basic operations. Run rake -T for listing available tasks:

$ rake -T

rake db:migrate[database]                                        # Run migration for given database (default: 'default')
rake db:roll_back[name_of_application,name_of_migration]         # Roll-back (name of application, name of migration)
rake db:shell                                                    # run database shell ..
rake db:show[name_of_application]                                # Show migrations for an application (default: 'all')
rake db:update[name_of_application,name_of_migration,is_empty]   # Update migration (name of application, name of migration?, is empty?)
rake default                                                     # Default task: run_server+
rake locale:compile                                              # Compile locale dictionary
rake locale:update                                               # Update locale dictionary
rake new:application[name_of_application]                        # Create new Django application
rake new:model[name_of_application,name_of_model,type_of_model]  # Create new Model for given application: django,basemodel,softdelete
rake runserver                                                   # Run server
rake runserver_plus                                              # Run server+
rake shell[repl]                                                 # Run shell+ avail: ptpython,ipython,bpython default: ptpython
rake test:browse_coverage[port]                                  # Browse test coverage
rake test:coverage[cli_args]                                     # Show test coverage (default: '--show-missing --ignore-errors --skip-covered')
rake test:run[name_of_application,verbose]                       # Run tests for given application

Rake tasks are the wrapper for Django’s management commands. Mostly related to django-vb-baseapp application. Please checkout https://github.com/vbyazilim/django-vb-baseapp for more detail and examples. django-vb-baseapp has lot of features :)


License

This project is licensed under MIT


Contributer(s)


Contribute

All PR’s are welcome!

  1. fork (https://github.com/vbyazilim/django-vb-admin/fork)
  2. Create your branch (git checkout -b my-features)
  3. commit yours (git commit -am 'Add awesome feature')
  4. push your branch (git push origin my-features)
  5. Than create a new Pull Request!

Change Log

2019-10-20

  • Add current git tag and python version information indicator to django-admin index
  • Add django-vb-baseapp as package dependency
  • Upgrade python packages
  • Add templates/base.html using Bulma.io 0.8.0
  • Bump version: 1.0.13

2019-09-19

  • Add Codacy integration
  • Add setup completed message

2019-08-12

  • Add templates/base.html using Bulma.io 0.7.5
  • Add templates/admin/ for base admin site.
  • Add static/js/application.js
  • Add global locale path
  • Bump version: 1.0.4
  • Bump version: 1.0.5 (Fix README file)

2019-08-07

  • Add --version option, version bump to 1.0.3
  • Bump version: 1.0.2
  • Add Rake tasks
  • Fix MAFIFEST.in file
  • Initial Beta relase: 1.0.0

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-vb-admin-1.0.17.tar.gz (407.4 kB view details)

Uploaded Source

Built Distribution

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

django_vb_admin-1.0.17-py3-none-any.whl (418.2 kB view details)

Uploaded Python 3

File details

Details for the file django-vb-admin-1.0.17.tar.gz.

File metadata

  • Download URL: django-vb-admin-1.0.17.tar.gz
  • Upload date:
  • Size: 407.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for django-vb-admin-1.0.17.tar.gz
Algorithm Hash digest
SHA256 8e978b0fda7e6ebcdef794c728cf9a87aedbbc2b99dfb584ddaf285928f9de55
MD5 0478e6c569bf22649053778e1997bd26
BLAKE2b-256 9ceb798bc1a725198f7e846fc81c4a8fef34bdfff2c1336f981a9a868afab13c

See more details on using hashes here.

File details

Details for the file django_vb_admin-1.0.17-py3-none-any.whl.

File metadata

  • Download URL: django_vb_admin-1.0.17-py3-none-any.whl
  • Upload date:
  • Size: 418.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/42.0.1 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.7.4

File hashes

Hashes for django_vb_admin-1.0.17-py3-none-any.whl
Algorithm Hash digest
SHA256 3d92e1e6f24b0c2d7826ce9a6c00525578ab53cfe9f5ffc486dbc3d58200a62f
MD5 a64134800cb011ce15911cdeb4e05357
BLAKE2b-256 2bb5702f0bd87f850edc95fe962e13046d5907ef64604f876ee2e7eaa66fca85

See more details on using hashes here.

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