mirror of
https://github.com/cookiecutter/cookiecutter-django.git
synced 2025-10-24 20:51:06 +03:00
Replace django-configuration with django-environ
- makes it compatible with django 1.8 - removes magic
This commit is contained in:
parent
b007a8e0ac
commit
89c0fb3ff8
|
@ -24,7 +24,7 @@ Features
|
||||||
* For Django 1.7
|
* For Django 1.7
|
||||||
* Twitter Bootstrap_ 3
|
* Twitter Bootstrap_ 3
|
||||||
* AngularJS_
|
* AngularJS_
|
||||||
* Settings management via django-configurations_
|
* Settings management via django-environ_
|
||||||
* Registration via django-allauth_
|
* Registration via django-allauth_
|
||||||
* User avatars via django-avatar_
|
* User avatars via django-avatar_
|
||||||
* Procfile_ for deploying to Heroku
|
* Procfile_ for deploying to Heroku
|
||||||
|
@ -35,7 +35,7 @@ Features
|
||||||
|
|
||||||
.. _Bootstrap: https://github.com/twbs/bootstrap
|
.. _Bootstrap: https://github.com/twbs/bootstrap
|
||||||
.. _AngularJS: https://github.com/angular/angular.js
|
.. _AngularJS: https://github.com/angular/angular.js
|
||||||
.. _django-configurations: https://github.com/jezdez/django-configurations
|
.. _django-environ: https://github.com/joke2k/django-environ
|
||||||
.. _django-allauth: https://github.com/pennersr/django-allauth
|
.. _django-allauth: https://github.com/pennersr/django-allauth
|
||||||
.. _django-avatar: https://github.com/jezdez/django-avatar/
|
.. _django-avatar: https://github.com/jezdez/django-avatar/
|
||||||
.. _Procfile: https://devcenter.heroku.com/articles/procfile
|
.. _Procfile: https://devcenter.heroku.com/articles/procfile
|
||||||
|
|
|
@ -19,8 +19,8 @@ Environment Variable Django Setting Development
|
||||||
DJANGO_AWS_ACCESS_KEY_ID AWS_ACCESS_KEY_ID n/a raises error
|
DJANGO_AWS_ACCESS_KEY_ID AWS_ACCESS_KEY_ID n/a raises error
|
||||||
DJANGO_AWS_SECRET_ACCESS_KEY AWS_SECRET_ACCESS_KEY n/a raises error
|
DJANGO_AWS_SECRET_ACCESS_KEY AWS_SECRET_ACCESS_KEY n/a raises error
|
||||||
DJANGO_AWS_STORAGE_BUCKET_NAME AWS_STORAGE_BUCKET_NAME n/a raises error
|
DJANGO_AWS_STORAGE_BUCKET_NAME AWS_STORAGE_BUCKET_NAME n/a raises error
|
||||||
DJANGO_CACHES CACHES locmem memcached
|
DJANGO_CACHES CACHES (default) locmem memcached
|
||||||
DJANGO_DATABASES DATABASES See code See code
|
DJANGO_DATABASES DATABASES (default) See code See code
|
||||||
DJANGO_DEBUG DEBUG True False
|
DJANGO_DEBUG DEBUG True False
|
||||||
DJANGO_EMAIL_BACKEND EMAIL_BACKEND django.core.mail.backends.console.EmailBackend django.core.mail.backends.smtp.EmailBackend
|
DJANGO_EMAIL_BACKEND EMAIL_BACKEND django.core.mail.backends.console.EmailBackend django.core.mail.backends.smtp.EmailBackend
|
||||||
DJANGO_SECRET_KEY SECRET_KEY CHANGEME!!! raises error
|
DJANGO_SECRET_KEY SECRET_KEY CHANGEME!!! raises error
|
||||||
|
@ -99,7 +99,6 @@ Run these commands to deploy the project to Heroku:
|
||||||
heroku addons:add sendgrid:starter
|
heroku addons:add sendgrid:starter
|
||||||
heroku addons:add memcachier:dev
|
heroku addons:add memcachier:dev
|
||||||
heroku pg:promote DATABASE_URL
|
heroku pg:promote DATABASE_URL
|
||||||
heroku config:set DJANGO_CONFIGURATION=Production
|
|
||||||
heroku config:set DJANGO_SECRET_KEY=RANDOM_SECRET_KEY_HERE
|
heroku config:set DJANGO_SECRET_KEY=RANDOM_SECRET_KEY_HERE
|
||||||
heroku config:set DJANGO_AWS_ACCESS_KEY_ID=YOUR_AWS_ID_HERE
|
heroku config:set DJANGO_AWS_ACCESS_KEY_ID=YOUR_AWS_ID_HERE
|
||||||
heroku config:set DJANGO_AWS_SECRET_ACCESS_KEY=YOUR_AWS_SECRET_ACCESS_KEY_HERE
|
heroku config:set DJANGO_AWS_SECRET_ACCESS_KEY=YOUR_AWS_SECRET_ACCESS_KEY_HERE
|
||||||
|
@ -139,7 +138,6 @@ You can then deploy by running the following commands.
|
||||||
ssh -t dokku@yourservername.com dokku memcached:link {{cookiecutter.repo_name}}-memcached {{cookiecutter.repo_name}}
|
ssh -t dokku@yourservername.com dokku memcached:link {{cookiecutter.repo_name}}-memcached {{cookiecutter.repo_name}}
|
||||||
ssh -t dokku@yourservername.com dokku postgres:create {{cookiecutter.repo_name}}-postgres
|
ssh -t dokku@yourservername.com dokku postgres:create {{cookiecutter.repo_name}}-postgres
|
||||||
ssh -t dokku@yourservername.com dokku postgres:link {{cookiecutter.repo_name}}-postgres {{cookiecutter.repo_name}}
|
ssh -t dokku@yourservername.com dokku postgres:link {{cookiecutter.repo_name}}-postgres {{cookiecutter.repo_name}}
|
||||||
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_CONFIGURATION=Production
|
|
||||||
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_SECRET_KEY=RANDOM_SECRET_KEY_HERE
|
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_SECRET_KEY=RANDOM_SECRET_KEY_HERE
|
||||||
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_AWS_ACCESS_KEY_ID=YOUR_AWS_ID_HERE
|
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_AWS_ACCESS_KEY_ID=YOUR_AWS_ID_HERE
|
||||||
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_AWS_SECRET_ACCESS_KEY=YOUR_AWS_SECRET_ACCESS_KEY_HERE
|
ssh -t dokku@yourservername.com dokku config:set {{cookiecutter.repo_name}} DJANGO_AWS_SECRET_ACCESS_KEY=YOUR_AWS_SECRET_ACCESS_KEY_HERE
|
||||||
|
|
|
@ -2,10 +2,8 @@
|
||||||
django>=1.7.7,<1.8
|
django>=1.7.7,<1.8
|
||||||
|
|
||||||
# Configuration
|
# Configuration
|
||||||
django-configurations==0.8
|
django-environ==0.3.0
|
||||||
django-secure==1.0.1
|
django-secure==1.0.1
|
||||||
django-cache-url==0.8.0
|
|
||||||
dj-database-url==0.3.0
|
|
||||||
|
|
||||||
# Forms
|
# Forms
|
||||||
django-braces==1.4.0
|
django-braces==1.4.0
|
||||||
|
|
|
@ -1,5 +1 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
from __future__ import absolute_import
|
|
||||||
|
|
||||||
from .local import Local # noqa
|
|
||||||
from .production import Production # noqa
|
|
||||||
|
|
|
@ -8,19 +8,17 @@ https://docs.djangoproject.com/en/dev/topics/settings/
|
||||||
For the full list of settings and their values, see
|
For the full list of settings and their values, see
|
||||||
https://docs.djangoproject.com/en/dev/ref/settings/
|
https://docs.djangoproject.com/en/dev/ref/settings/
|
||||||
"""
|
"""
|
||||||
|
from __future__ import absolute_import, unicode_literals
|
||||||
|
|
||||||
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
|
import environ
|
||||||
import os
|
|
||||||
from os.path import join, dirname
|
|
||||||
|
|
||||||
from configurations import Configuration, values
|
APPS_DIR = environ.Path(__file__) - 1 # one folder back (/a/b/ - 2 = /a/)
|
||||||
|
ROOT_DIR = APPS_DIR - 1
|
||||||
|
|
||||||
BASE_DIR = dirname(dirname(__file__))
|
env = environ.Env()
|
||||||
|
|
||||||
|
|
||||||
class Common(Configuration):
|
|
||||||
|
|
||||||
# APP CONFIGURATION
|
# APP CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
DJANGO_APPS = (
|
DJANGO_APPS = (
|
||||||
# Default Django apps:
|
# Default Django apps:
|
||||||
'django.contrib.auth',
|
'django.contrib.auth',
|
||||||
|
@ -52,9 +50,9 @@ class Common(Configuration):
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#installed-apps
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#installed-apps
|
||||||
INSTALLED_APPS = DJANGO_APPS + THIRD_PARTY_APPS + LOCAL_APPS
|
INSTALLED_APPS = DJANGO_APPS + THIRD_PARTY_APPS + LOCAL_APPS
|
||||||
# END APP CONFIGURATION
|
|
||||||
|
|
||||||
# MIDDLEWARE CONFIGURATION
|
# MIDDLEWARE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
MIDDLEWARE_CLASSES = (
|
MIDDLEWARE_CLASSES = (
|
||||||
# Make sure djangosecure.middleware.SecurityMiddleware is listed first
|
# Make sure djangosecure.middleware.SecurityMiddleware is listed first
|
||||||
'django.contrib.sessions.middleware.SessionMiddleware',
|
'django.contrib.sessions.middleware.SessionMiddleware',
|
||||||
|
@ -64,41 +62,41 @@ class Common(Configuration):
|
||||||
'django.contrib.messages.middleware.MessageMiddleware',
|
'django.contrib.messages.middleware.MessageMiddleware',
|
||||||
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
'django.middleware.clickjacking.XFrameOptionsMiddleware',
|
||||||
)
|
)
|
||||||
# END MIDDLEWARE CONFIGURATION
|
|
||||||
|
|
||||||
# MIGRATIONS CONFIGURATION
|
# MIGRATIONS CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
MIGRATION_MODULES = {
|
MIGRATION_MODULES = {
|
||||||
'sites': 'contrib.sites.migrations'
|
'sites': 'contrib.sites.migrations'
|
||||||
}
|
}
|
||||||
# END MIGRATIONS CONFIGURATION
|
|
||||||
|
|
||||||
# DEBUG
|
# DEBUG
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#debug
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#debug
|
||||||
DEBUG = values.BooleanValue(False)
|
DEBUG = env.bool("DJANGO_DEBUG", False)
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-debug
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-debug
|
||||||
TEMPLATE_DEBUG = DEBUG
|
TEMPLATE_DEBUG = DEBUG
|
||||||
# END DEBUG
|
|
||||||
|
|
||||||
# SECRET CONFIGURATION
|
# SECRET CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#secret-key
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#secret-key
|
||||||
# Note: This key only used for development and testing.
|
# Raises ImproperlyConfigured exception if DJANO_SECRET_KEY not in os.environ
|
||||||
# In production, this is changed to a values.SecretValue() setting
|
SECRET_KEY = env("DJANGO_SECRET_KEY")
|
||||||
SECRET_KEY = 'CHANGEME!!!'
|
|
||||||
# END SECRET CONFIGURATION
|
|
||||||
|
|
||||||
# FIXTURE CONFIGURATION
|
# FIXTURE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#std:setting-FIXTURE_DIRS
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#std:setting-FIXTURE_DIRS
|
||||||
FIXTURE_DIRS = (
|
FIXTURE_DIRS = (
|
||||||
join(BASE_DIR, 'fixtures'),
|
str(APPS_DIR.path('fixtures')),
|
||||||
)
|
)
|
||||||
# END FIXTURE CONFIGURATION
|
|
||||||
|
|
||||||
# EMAIL CONFIGURATION
|
# EMAIL CONFIGURATION
|
||||||
EMAIL_BACKEND = values.Value('django.core.mail.backends.smtp.EmailBackend')
|
# ------------------------------------------------------------------------------
|
||||||
|
EMAIL_BACKEND = env('DJANGO_EMAIL_BACKEND', default='django.core.mail.backends.smtp.EmailBackend')
|
||||||
# END EMAIL CONFIGURATION
|
# END EMAIL CONFIGURATION
|
||||||
|
|
||||||
# MANAGER CONFIGURATION
|
# MANAGER CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#admins
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#admins
|
||||||
ADMINS = (
|
ADMINS = (
|
||||||
("""{{cookiecutter.author_name}}""", '{{cookiecutter.email}}'),
|
("""{{cookiecutter.author_name}}""", '{{cookiecutter.email}}'),
|
||||||
|
@ -106,26 +104,19 @@ class Common(Configuration):
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#managers
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#managers
|
||||||
MANAGERS = ADMINS
|
MANAGERS = ADMINS
|
||||||
# END MANAGER CONFIGURATION
|
|
||||||
|
|
||||||
# DATABASE CONFIGURATION
|
# DATABASE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#databases
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#databases
|
||||||
DATABASES = values.DatabaseURLValue('postgres://localhost/{{cookiecutter.repo_name}}')
|
DATABASES = {
|
||||||
# END DATABASE CONFIGURATION
|
# Raises ImproperlyConfigured exception if DATABASE_URL not in os.environ
|
||||||
|
'default': env.db("DATABASE_URL", default="postgres://localhost/{{cookiecutter.repo_name}}"),
|
||||||
|
}
|
||||||
|
DATABASES['default']['ATOMIC_REQUESTS'] = True
|
||||||
|
|
||||||
# CACHING
|
|
||||||
# Do this here because thanks to django-pylibmc-sasl and pylibmc
|
|
||||||
# memcacheify (used on heroku) is painful to install on windows.
|
|
||||||
CACHES = {
|
|
||||||
'default': {
|
|
||||||
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
|
|
||||||
'LOCATION': ''
|
|
||||||
}
|
|
||||||
}
|
|
||||||
# END CACHING
|
|
||||||
|
|
||||||
# GENERAL CONFIGURATION
|
# GENERAL CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# Local time zone for this installation. Choices can be found here:
|
# Local time zone for this installation. Choices can be found here:
|
||||||
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
|
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
|
||||||
# although not all choices may be available on all operating systems.
|
# although not all choices may be available on all operating systems.
|
||||||
|
@ -149,6 +140,7 @@ class Common(Configuration):
|
||||||
# END GENERAL CONFIGURATION
|
# END GENERAL CONFIGURATION
|
||||||
|
|
||||||
# TEMPLATE CONFIGURATION
|
# TEMPLATE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-context-processors
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-context-processors
|
||||||
TEMPLATE_CONTEXT_PROCESSORS = (
|
TEMPLATE_CONTEXT_PROCESSORS = (
|
||||||
'django.contrib.auth.context_processors.auth',
|
'django.contrib.auth.context_processors.auth',
|
||||||
|
@ -166,7 +158,7 @@ class Common(Configuration):
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-dirs
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-dirs
|
||||||
TEMPLATE_DIRS = (
|
TEMPLATE_DIRS = (
|
||||||
join(BASE_DIR, 'templates'),
|
str(APPS_DIR.path('templates')),
|
||||||
)
|
)
|
||||||
|
|
||||||
TEMPLATE_LOADERS = (
|
TEMPLATE_LOADERS = (
|
||||||
|
@ -176,18 +168,18 @@ class Common(Configuration):
|
||||||
|
|
||||||
# See: http://django-crispy-forms.readthedocs.org/en/latest/install.html#template-packs
|
# See: http://django-crispy-forms.readthedocs.org/en/latest/install.html#template-packs
|
||||||
CRISPY_TEMPLATE_PACK = 'bootstrap3'
|
CRISPY_TEMPLATE_PACK = 'bootstrap3'
|
||||||
# END TEMPLATE CONFIGURATION
|
|
||||||
|
|
||||||
# STATIC FILE CONFIGURATION
|
# STATIC FILE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-root
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-root
|
||||||
STATIC_ROOT = join(os.path.dirname(BASE_DIR), 'staticfiles')
|
STATIC_ROOT = str(ROOT_DIR('staticfiles'))
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-url
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-url
|
||||||
STATIC_URL = '/static/'
|
STATIC_URL = '/static/'
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/contrib/staticfiles/#std:setting-STATICFILES_DIRS
|
# See: https://docs.djangoproject.com/en/dev/ref/contrib/staticfiles/#std:setting-STATICFILES_DIRS
|
||||||
STATICFILES_DIRS = (
|
STATICFILES_DIRS = (
|
||||||
join(BASE_DIR, 'static'),
|
str(APPS_DIR.path('static')),
|
||||||
)
|
)
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/contrib/staticfiles/#staticfiles-finders
|
# See: https://docs.djangoproject.com/en/dev/ref/contrib/staticfiles/#staticfiles-finders
|
||||||
|
@ -195,24 +187,24 @@ class Common(Configuration):
|
||||||
'django.contrib.staticfiles.finders.FileSystemFinder',
|
'django.contrib.staticfiles.finders.FileSystemFinder',
|
||||||
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
|
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
|
||||||
)
|
)
|
||||||
# END STATIC FILE CONFIGURATION
|
|
||||||
|
|
||||||
# MEDIA CONFIGURATION
|
# MEDIA CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-root
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-root
|
||||||
MEDIA_ROOT = join(BASE_DIR, 'media')
|
MEDIA_ROOT = str(APPS_DIR('media'))
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-url
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-url
|
||||||
MEDIA_URL = '/media/'
|
MEDIA_URL = '/media/'
|
||||||
# END MEDIA CONFIGURATION
|
|
||||||
|
|
||||||
# URL Configuration
|
# URL Configuration
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
ROOT_URLCONF = 'urls'
|
ROOT_URLCONF = 'urls'
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#wsgi-application
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#wsgi-application
|
||||||
WSGI_APPLICATION = 'wsgi.application'
|
WSGI_APPLICATION = 'wsgi.application'
|
||||||
# End URL Configuration
|
|
||||||
|
|
||||||
# AUTHENTICATION CONFIGURATION
|
# AUTHENTICATION CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
AUTHENTICATION_BACKENDS = (
|
AUTHENTICATION_BACKENDS = (
|
||||||
'django.contrib.auth.backends.ModelBackend',
|
'django.contrib.auth.backends.ModelBackend',
|
||||||
'allauth.account.auth_backends.AuthenticationBackend',
|
'allauth.account.auth_backends.AuthenticationBackend',
|
||||||
|
@ -229,13 +221,13 @@ class Common(Configuration):
|
||||||
AUTH_USER_MODEL = 'users.User'
|
AUTH_USER_MODEL = 'users.User'
|
||||||
LOGIN_REDIRECT_URL = 'users:redirect'
|
LOGIN_REDIRECT_URL = 'users:redirect'
|
||||||
LOGIN_URL = 'account_login'
|
LOGIN_URL = 'account_login'
|
||||||
# END Custom user app defaults
|
|
||||||
|
|
||||||
# SLUGLIFIER
|
# SLUGLIFIER
|
||||||
AUTOSLUG_SLUGIFY_FUNCTION = 'slugify.slugify'
|
AUTOSLUG_SLUGIFY_FUNCTION = 'slugify.slugify'
|
||||||
# END SLUGLIFIER
|
|
||||||
|
|
||||||
# LOGGING CONFIGURATION
|
# LOGGING CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#logging
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#logging
|
||||||
# A sample logging configuration. The only tangible logging
|
# A sample logging configuration. The only tangible logging
|
||||||
# performed by this configuration is to send an email to
|
# performed by this configuration is to send an email to
|
||||||
|
@ -265,10 +257,5 @@ class Common(Configuration):
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
# END LOGGING CONFIGURATION
|
|
||||||
|
|
||||||
@classmethod
|
|
||||||
def post_setup(cls):
|
|
||||||
cls.DATABASES['default']['ATOMIC_REQUESTS'] = True
|
|
||||||
|
|
||||||
# Your common stuff: Below this line define 3rd party library settings
|
# Your common stuff: Below this line define 3rd party library settings
|
||||||
|
|
|
@ -1,34 +1,45 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
'''
|
'''
|
||||||
Local Configurations
|
Local settings
|
||||||
|
|
||||||
- Runs in Debug mode
|
- Runs in Debug mode
|
||||||
- Uses console backend for emails
|
- Uses console backend for emails
|
||||||
- Use Django Debug Toolbar
|
- Use Django Debug Toolbar
|
||||||
'''
|
'''
|
||||||
from configurations import values
|
|
||||||
from .common import Common
|
|
||||||
|
|
||||||
|
from .common import *
|
||||||
class Local(Common):
|
|
||||||
|
|
||||||
# DEBUG
|
# DEBUG
|
||||||
DEBUG = values.BooleanValue(True)
|
# ------------------------------------------------------------------------------
|
||||||
|
DEBUG = env.bool('DJANGO_DEBUG', default=True)
|
||||||
TEMPLATE_DEBUG = DEBUG
|
TEMPLATE_DEBUG = DEBUG
|
||||||
# END DEBUG
|
|
||||||
|
|
||||||
# INSTALLED_APPS
|
# SECRET CONFIGURATION
|
||||||
INSTALLED_APPS = Common.INSTALLED_APPS
|
# ------------------------------------------------------------------------------
|
||||||
# END INSTALLED_APPS
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#secret-key
|
||||||
|
# Note: This key only used for development and testing.
|
||||||
|
SECRET_KEY = env("DJANGO_SECRET_KEY", 'CHANGEME!!!')
|
||||||
|
|
||||||
# Mail settings
|
# Mail settings
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
EMAIL_HOST = 'localhost'
|
EMAIL_HOST = 'localhost'
|
||||||
EMAIL_PORT = 1025
|
EMAIL_PORT = 1025
|
||||||
EMAIL_BACKEND = values.Value('django.core.mail.backends.console.EmailBackend')
|
EMAIL_BACKEND = env('DJANGO_EMAIL_BACKEND',
|
||||||
# End mail settings
|
default='django.core.mail.backends.console.EmailBackend')
|
||||||
|
|
||||||
|
|
||||||
|
# CACHING
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
CACHES = {
|
||||||
|
'default': {
|
||||||
|
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
|
||||||
|
'LOCATION': ''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# django-debug-toolbar
|
# django-debug-toolbar
|
||||||
MIDDLEWARE_CLASSES = Common.MIDDLEWARE_CLASSES + ('debug_toolbar.middleware.DebugToolbarMiddleware',)
|
# ------------------------------------------------------------------------------
|
||||||
|
MIDDLEWARE_CLASSES += ('debug_toolbar.middleware.DebugToolbarMiddleware',)
|
||||||
INSTALLED_APPS += ('debug_toolbar', 'django_extensions',)
|
INSTALLED_APPS += ('debug_toolbar', 'django_extensions',)
|
||||||
|
|
||||||
INTERNAL_IPS = ('127.0.0.1', '10.0.2.2',)
|
INTERNAL_IPS = ('127.0.0.1', '10.0.2.2',)
|
||||||
|
@ -39,6 +50,5 @@ class Local(Common):
|
||||||
],
|
],
|
||||||
'SHOW_TEMPLATE_CONTEXT': True,
|
'SHOW_TEMPLATE_CONTEXT': True,
|
||||||
}
|
}
|
||||||
# end django-debug-toolbar
|
|
||||||
|
|
||||||
# Your local stuff: Below this line define 3rd party library settings
|
# Your local stuff: Below this line define 3rd party library settings
|
||||||
|
|
|
@ -7,49 +7,38 @@ Production Configurations
|
||||||
- Use sendgrid to send emails
|
- Use sendgrid to send emails
|
||||||
- Use MEMCACHIER on Heroku
|
- Use MEMCACHIER on Heroku
|
||||||
'''
|
'''
|
||||||
from configurations import values
|
from __future__ import absolute_import, unicode_literals
|
||||||
|
|
||||||
from .common import Common
|
|
||||||
|
|
||||||
|
|
||||||
class Production(Common):
|
from boto.s3.connection import OrdinaryCallingFormat
|
||||||
|
|
||||||
|
from .common import *
|
||||||
|
|
||||||
# This ensures that Django will be able to detect a secure connection
|
# This ensures that Django will be able to detect a secure connection
|
||||||
# properly on Heroku.
|
# properly on Heroku.
|
||||||
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
|
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https')
|
||||||
|
|
||||||
# INSTALLED_APPS
|
|
||||||
INSTALLED_APPS = Common.INSTALLED_APPS
|
|
||||||
# END INSTALLED_APPS
|
|
||||||
|
|
||||||
# SECRET KEY
|
|
||||||
SECRET_KEY = values.SecretValue()
|
|
||||||
# END SECRET KEY
|
|
||||||
|
|
||||||
# django-secure
|
# django-secure
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
INSTALLED_APPS += ("djangosecure", )
|
INSTALLED_APPS += ("djangosecure", )
|
||||||
|
|
||||||
# MIDDLEWARE CONFIGURATION
|
|
||||||
MIDDLEWARE_CLASSES = (
|
MIDDLEWARE_CLASSES = (
|
||||||
# Make sure djangosecure.middleware.SecurityMiddleware is listed first
|
# Make sure djangosecure.middleware.SecurityMiddleware is listed first
|
||||||
'djangosecure.middleware.SecurityMiddleware',
|
'djangosecure.middleware.SecurityMiddleware',
|
||||||
)
|
) + MIDDLEWARE_CLASSES
|
||||||
|
|
||||||
MIDDLEWARE_CLASSES += Common.MIDDLEWARE_CLASSES
|
|
||||||
# END MIDDLEWARE CONFIGURATION
|
|
||||||
|
|
||||||
# set this to 60 seconds and then to 518400 when you can prove it works
|
# set this to 60 seconds and then to 518400 when you can prove it works
|
||||||
SECURE_HSTS_SECONDS = 60
|
SECURE_HSTS_SECONDS = 60
|
||||||
SECURE_HSTS_INCLUDE_SUBDOMAINS = values.BooleanValue(True)
|
SECURE_HSTS_INCLUDE_SUBDOMAINS = env.bool("DJANGO_SECURE_HSTS_INCLUDE_SUBDOMAINS", default=True)
|
||||||
SECURE_FRAME_DENY = values.BooleanValue(True)
|
SECURE_FRAME_DENY = env.bool("DJANGO_SECURE_FRAME_DENY", default=True)
|
||||||
SECURE_CONTENT_TYPE_NOSNIFF = values.BooleanValue(True)
|
SECURE_CONTENT_TYPE_NOSNIFF = env.bool("DJANGO_SECURE_CONTENT_TYPE_NOSNIFF", default=True)
|
||||||
SECURE_BROWSER_XSS_FILTER = values.BooleanValue(True)
|
SECURE_BROWSER_XSS_FILTER = True
|
||||||
SESSION_COOKIE_SECURE = values.BooleanValue(False)
|
SESSION_COOKIE_SECURE = False
|
||||||
SESSION_COOKIE_HTTPONLY = values.BooleanValue(True)
|
SESSION_COOKIE_HTTPONLY = True
|
||||||
SECURE_SSL_REDIRECT = values.BooleanValue(True)
|
SECURE_SSL_REDIRECT = env.bool("DJANGO_SECURE_SSL_REDIRECT", default=True)
|
||||||
# end django-secure
|
|
||||||
|
|
||||||
# SITE CONFIGURATION
|
# SITE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# Hosts/domain names that are valid for this site
|
# Hosts/domain names that are valid for this site
|
||||||
# See https://docs.djangoproject.com/en/1.6/ref/settings/#allowed-hosts
|
# See https://docs.djangoproject.com/en/1.6/ref/settings/#allowed-hosts
|
||||||
ALLOWED_HOSTS = ["*"]
|
ALLOWED_HOSTS = ["*"]
|
||||||
|
@ -58,20 +47,20 @@ class Production(Common):
|
||||||
INSTALLED_APPS += ("gunicorn", )
|
INSTALLED_APPS += ("gunicorn", )
|
||||||
|
|
||||||
# STORAGE CONFIGURATION
|
# STORAGE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: http://django-storages.readthedocs.org/en/latest/index.html
|
# See: http://django-storages.readthedocs.org/en/latest/index.html
|
||||||
INSTALLED_APPS += (
|
INSTALLED_APPS += (
|
||||||
'storages',
|
'storages',
|
||||||
)
|
)
|
||||||
|
|
||||||
# See: http://django-storages.readthedocs.org/en/latest/backends/amazon-S3.html#settings
|
|
||||||
STATICFILES_STORAGE = DEFAULT_FILE_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
|
STATICFILES_STORAGE = DEFAULT_FILE_STORAGE = 'storages.backends.s3boto.S3BotoStorage'
|
||||||
|
|
||||||
# See: http://django-storages.readthedocs.org/en/latest/backends/amazon-S3.html#settings
|
AWS_ACCESS_KEY_ID = env("DJANGO_AWS_ACCESS_KEY_ID")
|
||||||
AWS_ACCESS_KEY_ID = values.SecretValue()
|
AWS_SECRET_ACCESS_KEY = env("DJANGO_AWS_SECRET_ACCESS_KEY")
|
||||||
AWS_SECRET_ACCESS_KEY = values.SecretValue()
|
AWS_STORAGE_BUCKET_NAME = env("DJANGO_AWS_STORAGE_BUCKET_NAME")
|
||||||
AWS_STORAGE_BUCKET_NAME = values.SecretValue()
|
|
||||||
AWS_AUTO_CREATE_BUCKET = True
|
AWS_AUTO_CREATE_BUCKET = True
|
||||||
AWS_QUERYSTRING_AUTH = False
|
AWS_QUERYSTRING_AUTH = False
|
||||||
|
AWS_S3_CALLING_FORMAT = OrdinaryCallingFormat()
|
||||||
|
|
||||||
# See: https://github.com/antonagestam/collectfast
|
# See: https://github.com/antonagestam/collectfast
|
||||||
# For Django 1.7+, 'collectfast' should come before 'django.contrib.staticfiles'
|
# For Django 1.7+, 'collectfast' should come before 'django.contrib.staticfiles'
|
||||||
|
@ -84,29 +73,24 @@ class Production(Common):
|
||||||
'Cache-Control': 'max-age=%d, s-maxage=%d, must-revalidate' % (
|
'Cache-Control': 'max-age=%d, s-maxage=%d, must-revalidate' % (
|
||||||
AWS_EXPIRY, AWS_EXPIRY)
|
AWS_EXPIRY, AWS_EXPIRY)
|
||||||
}
|
}
|
||||||
# See: http://django-storages.readthedocs.org/en/latest/backends/amazon-S3.html
|
|
||||||
try:
|
|
||||||
from boto.s3.connection import OrdinaryCallingFormat
|
|
||||||
AWS_S3_CALLING_FORMAT = OrdinaryCallingFormat()
|
|
||||||
except ImportError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-url
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-url
|
||||||
STATIC_URL = 'https://s3.amazonaws.com/%s/' % AWS_STORAGE_BUCKET_NAME
|
STATIC_URL = 'https://s3.amazonaws.com/%s/' % AWS_STORAGE_BUCKET_NAME
|
||||||
# END STORAGE CONFIGURATION
|
|
||||||
|
|
||||||
# EMAIL
|
# EMAIL
|
||||||
DEFAULT_FROM_EMAIL = values.Value('{{cookiecutter.project_name}} <noreply@{{cookiecutter.domain_name}}>')
|
# ------------------------------------------------------------------------------
|
||||||
EMAIL_HOST = values.Value('smtp.sendgrid.com')
|
DEFAULT_FROM_EMAIL = env('DJANGO_DEFAULT_FROM_EMAIL',
|
||||||
EMAIL_HOST_PASSWORD = values.SecretValue(environ_prefix="", environ_name="SENDGRID_PASSWORD")
|
default='{{cookiecutter.project_name}} <noreply@{{cookiecutter.domain_name}}>')
|
||||||
EMAIL_HOST_USER = values.SecretValue(environ_prefix="", environ_name="SENDGRID_USERNAME")
|
EMAIL_HOST = env("DJANGO_EMAIL_HOST", default='smtp.sendgrid.com')
|
||||||
EMAIL_PORT = values.IntegerValue(587, environ_prefix="", environ_name="EMAIL_PORT")
|
EMAIL_HOST_PASSWORD = env("SENDGRID_PASSWORD")
|
||||||
EMAIL_SUBJECT_PREFIX = values.Value('[{{cookiecutter.project_name}}] ', environ_name="EMAIL_SUBJECT_PREFIX")
|
EMAIL_HOST_USER = env('SENDGRID_USERNAME')
|
||||||
|
EMAIL_PORT = env.int("EMAIL_PORT", default=587)
|
||||||
|
EMAIL_SUBJECT_PREFIX = env("EMAIL_SUBJECT_PREFIX", default='[{{cookiecutter.project_name}}] ')
|
||||||
EMAIL_USE_TLS = True
|
EMAIL_USE_TLS = True
|
||||||
SERVER_EMAIL = EMAIL_HOST_USER
|
SERVER_EMAIL = EMAIL_HOST_USER
|
||||||
# END EMAIL
|
|
||||||
|
|
||||||
# TEMPLATE CONFIGURATION
|
# TEMPLATE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-dirs
|
# See: https://docs.djangoproject.com/en/dev/ref/settings/#template-dirs
|
||||||
TEMPLATE_LOADERS = (
|
TEMPLATE_LOADERS = (
|
||||||
('django.template.loaders.cached.Loader', (
|
('django.template.loaders.cached.Loader', (
|
||||||
|
@ -114,17 +98,23 @@ class Production(Common):
|
||||||
'django.template.loaders.app_directories.Loader',
|
'django.template.loaders.app_directories.Loader',
|
||||||
)),
|
)),
|
||||||
)
|
)
|
||||||
# END TEMPLATE CONFIGURATION
|
|
||||||
|
# DATABASE CONFIGURATION
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
# Raises ImproperlyConfigured exception if DATABASE_URL not in os.environ
|
||||||
|
DATABASES['defalut'] = env.db("DATABASE_URL")
|
||||||
|
|
||||||
# CACHING
|
# CACHING
|
||||||
|
# ------------------------------------------------------------------------------
|
||||||
|
try:
|
||||||
# Only do this here because thanks to django-pylibmc-sasl and pylibmc
|
# Only do this here because thanks to django-pylibmc-sasl and pylibmc
|
||||||
# memcacheify is painful to install on windows.
|
# memcacheify is painful to install on windows.
|
||||||
try:
|
|
||||||
# See: https://github.com/rdegges/django-heroku-memcacheify
|
# See: https://github.com/rdegges/django-heroku-memcacheify
|
||||||
from memcacheify import memcacheify
|
from memcacheify import memcacheify
|
||||||
CACHES = memcacheify()
|
CACHES = memcacheify()
|
||||||
except ImportError:
|
except ImportError:
|
||||||
CACHES = values.CacheURLValue(default="memcached://127.0.0.1:11211")
|
CACHES = {
|
||||||
# END CACHING
|
'default': env.cache_url("DJANGO_CACHE_URL", default="memcache://127.0.0.1:11211"),
|
||||||
|
}
|
||||||
|
|
||||||
# Your production stuff: Below this line define 3rd party library settings
|
# Your production stuff: Below this line define 3rd party library settings
|
||||||
|
|
|
@ -3,9 +3,8 @@ import os
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "config")
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "config.local")
|
||||||
os.environ.setdefault("DJANGO_CONFIGURATION", "Local")
|
|
||||||
|
|
||||||
from configurations.management import execute_from_command_line
|
from django.core.management import execute_from_command_line
|
||||||
|
|
||||||
execute_from_command_line(sys.argv)
|
execute_from_command_line(sys.argv)
|
||||||
|
|
|
@ -19,13 +19,12 @@ import os
|
||||||
# if running multiple sites in the same mod_wsgi process. To fix this, use
|
# if running multiple sites in the same mod_wsgi process. To fix this, use
|
||||||
# mod_wsgi daemon mode with each site in its own daemon process, or use
|
# mod_wsgi daemon mode with each site in its own daemon process, or use
|
||||||
# os.environ["DJANGO_SETTINGS_MODULE"] = "{{ repo_name }}.settings"
|
# os.environ["DJANGO_SETTINGS_MODULE"] = "{{ repo_name }}.settings"
|
||||||
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "config")
|
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "config.production")
|
||||||
os.environ.setdefault("DJANGO_CONFIGURATION", "Production")
|
|
||||||
|
|
||||||
# This application object is used by any WSGI server configured to use this
|
# This application object is used by any WSGI server configured to use this
|
||||||
# file. This includes Django's development server, if the WSGI_APPLICATION
|
# file. This includes Django's development server, if the WSGI_APPLICATION
|
||||||
# setting points here.
|
# setting points here.
|
||||||
from configurations.wsgi import get_wsgi_application # noqa
|
from django.core.wsgi import get_wsgi_application # noqa
|
||||||
application = get_wsgi_application()
|
application = get_wsgi_application()
|
||||||
|
|
||||||
# Apply WSGI middleware here.
|
# Apply WSGI middleware here.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user