diff --git a/config/settings/base.py b/config/settings/base.py index f63fec9..147aea8 100644 --- a/config/settings/base.py +++ b/config/settings/base.py @@ -1,16 +1,10 @@ -""" -Django settings for CCDB -""" - import environ -ROOT_DIR = environ.Path(__file__) - 3 # (/a/b/myfile.py - 3 = /) +ROOT_DIR = environ.Path(__file__) - 3 APPS_DIR = ROOT_DIR.path('ccdb') env = environ.Env() -# APP CONFIGURATION -# ------------------------------------------------------------------------------ DJANGO_APPS = ( 'django.contrib.auth', 'django.contrib.contenttypes', @@ -26,8 +20,6 @@ THIRD_PARTY_APPS = ( 'corsheaders', 'djoser', ) - -# Apps specific for this project go here. LOCAL_APPS = ( 'ccdb.utils', 'ccdb.users', @@ -40,11 +32,8 @@ LOCAL_APPS = ( 'ccdb.experiments', ) -# See: https://docs.djangoproject.com/en/dev/ref/settings/#installed-apps INSTALLED_APPS = DJANGO_APPS + THIRD_PARTY_APPS + LOCAL_APPS -# MIDDLEWARE CONFIGURATION -# ------------------------------------------------------------------------------ MIDDLEWARE = ( 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', @@ -55,57 +44,30 @@ MIDDLEWARE = ( 'django.middleware.clickjacking.XFrameOptionsMiddleware', ) -# DEBUG -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#debug DEBUG = env.bool("DJANGO_DEBUG", False) -# FIXTURE CONFIGURATION -# ------------------------------------------------------------------------------ -# https://docs.djangoproject.com/en/dev/ref/settings/#std:setting-FIXTURE_DIRS FIXTURE_DIRS = ( str(APPS_DIR.path('fixtures')), ) -# EMAIL CONFIGURATION -# ------------------------------------------------------------------------------ EMAIL_BACKEND = env('DJANGO_EMAIL_BACKEND', default='django.core.mail.backends.smtp.EmailBackend') -# MANAGER CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#admins ADMINS = ( ("""Matthew Ryan Dillon""", 'matthewrdillon@gmail.com'), ) -# See: https://docs.djangoproject.com/en/dev/ref/settings/#managers MANAGERS = ADMINS -# DATABASE CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#databases DATABASES = { - # Raises ImproperlyConfigured exception if DATABASE_URL not in os.environ 'default': env.db("DATABASE_URL", default="postgres:///ccdbdjango"), } DATABASES['default']['ATOMIC_REQUESTS'] = True - -# GENERAL CONFIGURATION -# ------------------------------------------------------------------------------ -# Local time zone for this installation. Choices can be found here: -# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name -# although not all choices may be available on all operating systems. -# In a Windows environment this must be set to your system time zone. TIME_ZONE = 'UTC' -# See: https://docs.djangoproject.com/en/dev/ref/settings/#use-tz USE_TZ = True -# TEMPLATE CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#templates TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', @@ -133,12 +95,8 @@ TEMPLATES = [ }, ] -# STATIC FILE CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-root STATIC_ROOT = str(ROOT_DIR('staticfiles')) -# See: https://docs.djangoproject.com/en/dev/ref/settings/#static-url STATIC_URL = '/static/' STATICFILES_DIRS = ( @@ -150,42 +108,27 @@ STATICFILES_FINDERS = ( 'django.contrib.staticfiles.finders.AppDirectoriesFinder', ) -# MEDIA CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-root MEDIA_ROOT = str(APPS_DIR('media')) -# See: https://docs.djangoproject.com/en/dev/ref/settings/#media-url MEDIA_URL = '/media/' -# URL Configuration -# ------------------------------------------------------------------------------ ROOT_URLCONF = 'config.urls' -# See: https://docs.djangoproject.com/en/dev/ref/settings/#wsgi-application WSGI_APPLICATION = 'config.wsgi.application' -# AUTHENTICATION CONFIGURATION -# ------------------------------------------------------------------------------ AUTHENTICATION_BACKENDS = ( 'django.contrib.auth.backends.ModelBackend', ) -# Custom user app defaults -# Select the correct user model AUTH_USER_MODEL = 'users.User' LOGIN_REDIRECT_URL = 'users:redirect' LOGIN_URL = 'account_login' - -# Location of root django.contrib.admin URL, use {% url 'admin:index' %} ADMIN_URL = r'^admin/' GRAPPELLI_ADMIN_TITLE = 'CCDB' - MANIFEST_URL = env('MANIFEST_URL', default=None) - REST_FRAMEWORK = { 'DEFAULT_PERMISSION_CLASSES': [ 'rest_framework.permissions.IsAuthenticated', diff --git a/config/settings/local.py b/config/settings/local.py index 8e4907c..1440799 100644 --- a/config/settings/local.py +++ b/config/settings/local.py @@ -1,11 +1,3 @@ -''' -Local settings - -- Run in Debug mode -- Use console backend for emails -- Add Django Debug Toolbar -''' - import warnings import sys import logging @@ -18,39 +10,23 @@ with warnings.catch_warnings(record=True) as warning: for w in warning: print(w.message) - -# DEBUG -# ------------------------------------------------------------------------------ DEBUG = env.bool('DJANGO_DEBUG', default=True) TEMPLATES[0]['OPTIONS']['debug'] = DEBUG -# SECRET CONFIGURATION -# ------------------------------------------------------------------------------ -# 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", default='t69v7lq5ayk^k_)uyvjvpo(sljrcnbh)&$(rsqqjg-87160@^%') -# Mail settings -# ------------------------------------------------------------------------------ EMAIL_HOST = 'localhost' EMAIL_PORT = 1025 EMAIL_BACKEND = env('DJANGO_EMAIL_BACKEND', default='django.core.mail.backends.console.EmailBackend') - -# Testing -# ------------------------------------------------------------------------------ INSTALLED_APPS += ('django_extensions',) INTERNAL_IPS = ('127.0.0.1', ) - -# TESTING -# ------------------------------------------------------------------------------ TEST_RUNNER = 'django.test.runner.DiscoverRunner' - # http://stackoverflow.com/a/28560805/313548 class DisableMigrations(object): def __contains__(self, item): @@ -59,7 +35,6 @@ class DisableMigrations(object): def __getitem__(self, item): return "notmigrations" - TESTS_IN_PROGRESS = False if 'test' in sys.argv[1:] or 'jenkins' in sys.argv[1:]: logging.disable(logging.CRITICAL) diff --git a/config/settings/production.py b/config/settings/production.py index cff377c..a890ea9 100644 --- a/config/settings/production.py +++ b/config/settings/production.py @@ -1,41 +1,17 @@ -''' -Production Configurations - -- Use Amazon's S3 for storing static files and uploaded media -- Use mailgun to send emails - -''' - from boto.s3.connection import OrdinaryCallingFormat from django.utils import six from .base import * # noqa -# SECRET CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#secret-key -# Raises ImproperlyConfigured exception if DJANGO_SECRET_KEY not in os.environ SECRET_KEY = env("DJANGO_SECRET_KEY") -# This ensures that Django will be able to detect a secure connection -# properly on Heroku. SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', 'https') -# SITE CONFIGURATION -# ------------------------------------------------------------------------------ -# Hosts/domain names that are valid for this site -# See https://docs.djangoproject.com/en/1.6/ref/settings/#allowed-hosts ALLOWED_HOSTS = env.list('DJANGO_ALLOWED_HOSTS', default=['ccdb.info']) -# END SITE CONFIGURATION INSTALLED_APPS += ("gunicorn", ) -# STORAGE CONFIGURATION -# ------------------------------------------------------------------------------ -# Uploaded Media Files -# ------------------------ -# See: http://django-storages.readthedocs.org/en/latest/index.html INSTALLED_APPS += ( 'storages', ) @@ -48,28 +24,17 @@ AWS_AUTO_CREATE_BUCKET = True AWS_QUERYSTRING_AUTH = False AWS_S3_CALLING_FORMAT = OrdinaryCallingFormat() -# AWS cache settings, don't change unless you know what you're doing: AWS_EXPIRY = 60 * 60 * 24 * 7 -# TODO See: https://github.com/jschneier/django-storages/issues/47 -# Revert the following and use str after the above-mentioned bug is fixed in -# either django-storage-redux or boto AWS_HEADERS = { 'Cache-Control': six.b('max-age=%d, s-maxage=%d, must-revalidate' % ( AWS_EXPIRY, AWS_EXPIRY)) } -# URL that handles the media served from MEDIA_ROOT, used for managing -# stored files. MEDIA_URL = 'https://s3.amazonaws.com/%s/' % AWS_STORAGE_BUCKET_NAME -# Static Assets -# ------------------------ STATICFILES_STORAGE = 'whitenoise.django.GzipManifestStaticFilesStorage' - -# EMAIL -# ------------------------------------------------------------------------------ DEFAULT_FROM_EMAIL = env('DJANGO_DEFAULT_FROM_EMAIL', default='CCDB Admin ') EMAIL_BACKEND = 'django_mailgun.MailgunBackend' @@ -79,10 +44,6 @@ EMAIL_SUBJECT_PREFIX = env("DJANGO_EMAIL_SUBJECT_PREFIX", default='[ccdb] ') SERVER_EMAIL = env('DJANGO_SERVER_EMAIL', default=DEFAULT_FROM_EMAIL) -# TEMPLATE CONFIGURATION -# ------------------------------------------------------------------------------ -# See: -# https://docs.djangoproject.com/en/dev/ref/templates/api/#django.template.loaders.cached.Loader TEMPLATES[0]['OPTIONS']['loaders'] = [ ( 'django.template.loaders.cached.Loader', @@ -93,20 +54,9 @@ TEMPLATES[0]['OPTIONS']['loaders'] = [ ), ] -# DATABASE CONFIGURATION -# ------------------------------------------------------------------------------ -# Raises ImproperlyConfigured exception if DATABASE_URL not in os.environ DATABASES['default'] = env.db("DATABASE_URL") -# LOGGING CONFIGURATION -# ------------------------------------------------------------------------------ -# See: https://docs.djangoproject.com/en/dev/ref/settings/#logging -# A sample logging configuration. The only tangible logging -# performed by this configuration is to send an email to -# the site admins on every HTTP 500 error when DEBUG=False. -# See http://docs.djangoproject.com/en/dev/topics/logging for -# more details on how to customize your logging configuration. LOGGING = { 'version': 1, 'disable_existing_loggers': False, @@ -147,7 +97,6 @@ LOGGING = { } } -# Custom Admin URL, use {% url 'admin:index' %} ADMIN_URL = env('DJANGO_ADMIN_URL') CORS_ORIGIN_ALLOW_ALL = False diff --git a/config/wsgi.py b/config/wsgi.py index 2b2c014..ec265bd 100644 --- a/config/wsgi.py +++ b/config/wsgi.py @@ -1,18 +1,3 @@ -""" -WSGI config for CCDB. - -This module contains the WSGI application used by Django's development server -and any production WSGI deployments. It should expose a module-level variable -named ``application``. Django's ``runserver`` and ``runfcgi`` commands discover -this application via the ``WSGI_APPLICATION`` setting. - -Usually you will have the standard Django WSGI application here, but it also -might make sense to replace the whole Django WSGI application with a custom one -that later delegates to the Django one. For example, you could introduce WSGI -middleware here, or combine a Django application with an application of another -framework. - -""" import os @@ -20,22 +5,8 @@ from django.core.wsgi import get_wsgi_application from whitenoise.django import DjangoWhiteNoise -# We defer to a DJANGO_SETTINGS_MODULE already in the environment. This breaks -# 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 -# os.environ["DJANGO_SETTINGS_MODULE"] = "config.settings.production" os.environ.setdefault("DJANGO_SETTINGS_MODULE", "config.settings.production") -# This application object is used by any WSGI server configured to use this -# file. This includes Django's development server, if the WSGI_APPLICATION -# setting points here. application = get_wsgi_application() -# Use Whitenoise to serve static files -# See: https://whitenoise.readthedocs.org/ application = DjangoWhiteNoise(application) - - -# Apply WSGI middleware here. -# from helloworld.wsgi import HelloWorldApplication -# application = HelloWorldApplication(application)