Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/spapas/cookiecutter-django-starter
Start a django project using a cookiecutter
https://github.com/spapas/cookiecutter-django-starter
cookiecutter django django-cookiecutter python
Last synced: 30 days ago
JSON representation
Start a django project using a cookiecutter
- Host: GitHub
- URL: https://github.com/spapas/cookiecutter-django-starter
- Owner: spapas
- Created: 2016-06-28T13:11:09.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-10-08T21:35:18.000Z (3 months ago)
- Last Synced: 2024-10-17T02:16:38.649Z (3 months ago)
- Topics: cookiecutter, django, django-cookiecutter, python
- Language: Python
- Size: 2.91 MB
- Stars: 20
- Watchers: 4
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Simple Django cookiecutter
==========================This cookiecutter has LDAP authentication configured - if you don't want it you need to remove the lines
```
from .ldap_conf import *
AUTHENTICATION_BACKENDS = (
'django_auth_ldap.backend.LDAPBackend',
'{{cookiecutter.project_name}}.core.auth.NoLoginModelBackend',
)```
from ``settings/base.py``
Other things that are used (and configured except the LDAP auth):
* Three different environments (dev - uat - prod) with different requirements and settings for each
* django-tables2 for nice tables
* django-filters for nice qs filtering
* django-crispy-forms for nice forms
* django-debug-toolbar configured for dev env
* django-reversion to enable change auditing
* django-compressor to combine and compress your static assets
* django-extensions to enable some useful functionality
* django-hijack to allow superusers to hijaco other users
* Werkzeug to run the dev server
* Custom User model with login/logout pages
* Bootstrap 5 templates
* Usage of thread locals to retrieve request (and user)
* An abstract model that saves created/modified datetime and user.
* Upgraded to Django 5.1 and all latest packagesI have some scripts to help me on Windows - but should work anywhere. The scripts are:
* dovenv.bat to enable the virtualenv and correctly set the settings (to the dev env ones)
* dj.bat to run python manage.py command (i.e run ``dj migrate`` for applying migrations)
* rsp.bat to run the runserver_plus command
* test.bat to run the test suiteUsage
-----Install cookiecutter (https://github.com/audreyr/cookiecutter) to your global python packages
(or the virtualenv you are going to create -- also checkout my post @ https://spapas.github.io/2017/12/20/python-2-3-windows/ for using python 2 and 3 on windows). Then, activate your venv and run cookiecutter with this repo, i.e```
mkdir parent_folder
cd parent_folder
py -3 -m venv venv
pip install cookiecutter
cookiecutter https://github.com/spapas/cookiecutter-django-starter```
Now answer the questions - the most important is the project name (i.e project name) - it will dump your project there:
```
cd project_name
dovenv.bat
pip install -r requirements\dev.txt
```If you see ldap-related errors then install correct version of python-ldap from https://www.lfd.uci.edu/~gohlke/pythonlibs/#python-ldap (download it and run ``pip install python_ldap-xxx.whl``) - then run again ``pip install -r requrements\dev.txt``).
If you see rcssmin related errors then install it like this: ``pip install -U rcssmin --install-option="--without-c-extensions"``
Project is ready - from the same directory (where you run ``dovenv.bat``) run the following to also create your git repo (a proper .gitignore is alreadt provided courtesy of https://gitignore.io and some additions of mine):
```
git init
git add -A
git commit
git remote add origin http://...
git push origin master
```Now you can run the migrations, create your superuser and run the dev server:
```
dj migrate
dj createsuperuser
rsp
```Please notice that this project has been configured for usage in Greece. If you want to
convert it to your language you should probably change the ``LANGUAGE_CODE`` and ``TIMEZONE`` in
settings.py and make some small changes to the templates.### The fabric situation
Please notice that I've included a fabric 1.x script for e-z deploy. For reasons that I don't want to explain here I won't support fabric 2.x. To use that fabric script you'll need to use the life saving fab-classic project (https://ploxiln.github.io/fab-classic/) that is a fork of fabric 1.x properly supporting ypthon 3.x! This dependency is already installed with the requirements/dev.txt.
### Removing LDAP
If you don't want to use LDAP remove the ldap-related requirements from requirements/base.txt, remove the ldap_conf.py file from settings, remove the line importing ldap_conf from settings/base.py and either change your AUTHENTICATION_BACKEDS to your liking or completely remove that line from base.py and dev.py to fallback to model authentication.