deployment stuff
[cas.git] / src / cas / settings.py
index 47afd45..5668804 100644 (file)
@@ -1,35 +1,65 @@
-from os import path
+import os
 
 
-PROJECT_ROOT = path.realpath(path.dirname(__file__))
-
-DEBUG = True
+PROJECT_ROOT = os.path.realpath(os.path.dirname(__file__))
 
 ADMINS = [
 
 ADMINS = [
+    tuple(adm.split(':'))
+    for adm in
+    os.environ.get('ADMINS', '').split('\n')
+    if adm
 ]
 
 ]
 
-MANAGERS = ADMINS
+MANAGERS = [
+    tuple(adm.split(':'))
+    for adm in
+    os.environ.get('MANAGERS', os.environ.get('ADMINS', '')).split('\n')
+    if adm
+]
 
 
-DATABASES = {
-    'default': {
-        'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'postgresql', 'mysql', 'sqlite3' or 'oracle'.
-        'NAME': path.join(PROJECT_ROOT, 'dev.sqlite'), # Or path to database file if using sqlite3.
-        'USER': '',                      # Not used with sqlite3.
-        'PASSWORD': '',                  # Not used with sqlite3.
-        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
-        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
+DEBUG = False
+
+if 'DB_NAME' in os.environ:
+    DATABASES = {
+        'default': {
+            'ENGINE': 'django.db.backends.postgresql_psycopg2',
+            'NAME': os.environ['DB_NAME'],
+            'USER': os.environ.get('DB_USER', ''),
+            'PASSWORD': os.environ.get('DB_PASSWORD', ''),
+            'HOST': os.environ.get('DB_HOST', ''),
+            'PORT': os.environ.get('DB_PORT', ''),
+        }
+    }
+else:
+    DEBUG = True
+
+    DATABASES = {
+        'default': {
+            'ENGINE': 'django.db.backends.sqlite3',
+            'NAME': '/app/src/cas/dev.sqlite',
+        }
     }
     }
-}
+
+
+DEBUG = os.environ.get('DEBUG', str(DEBUG)).lower() == 'true'
+
+EMAIL_HOST = os.environ.get('EMAIL_HOST', 'localhost')
+DEFAULT_FROM_EMAIL = os.environ.get('DEFAULT_FROM_EMAIL', '')
+EMAIL_SUBJECT_PREFIX = os.environ.get('EMAIL_SUBJECT_PREFIX', '')
+SECRET_KEY = os.environ.get('SECRET_KEY', '')
+ALLOWED_HOSTS = os.environ.get('ALLOWED_HOSTS', '').split()
+EMAILS_BASE_DOMAINS = os.environ.get('EMAILS_BASE_DOMAINS', '').split()
+SECURE_PROXY_SSL_HEADER = os.environ.get('SECURE_PROXY_SSL_HEADER', '').split()
 
 # 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.
 # If running in a Windows environment this must be set to the same as your
 # system time zone.
 
 # 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.
 # If running in a Windows environment this must be set to the same as your
 # system time zone.
-TIME_ZONE = 'UTC'
+TIME_ZONE = os.environ.get('TIME_ZONE', 'Europe/Warsaw')
 
 # Language code for this installation. All choices can be found here:
 # http://www.i18nguy.com/unicode/language-identifiers.html
 
 # Language code for this installation. All choices can be found here:
 # http://www.i18nguy.com/unicode/language-identifiers.html
-LANGUAGE_CODE = 'pl'
+LANGUAGE_CODE = os.environ.get('LANGUAGE_CODE', 'pl')
 
 SITE_ID = 1
 
 
 SITE_ID = 1
 
@@ -41,18 +71,38 @@ USE_TZ = True
 
 # Absolute path to the directory that holds media.
 # Example: "/home/media/media.lawrence.com/"
 
 # Absolute path to the directory that holds media.
 # Example: "/home/media/media.lawrence.com/"
-MEDIA_ROOT = path.join(PROJECT_ROOT, '../../media/')
+MEDIA_ROOT = '/app/media/'
 
 # URL that handles the media served from MEDIA_ROOT. Make sure to use a
 # trailing slash if there is a path component (optional in other cases).
 # Examples: "http://media.lawrence.com", "http://example.com/media/"
 MEDIA_URL = '/media/'
 
 
 # URL that handles the media served from MEDIA_ROOT. Make sure to use a
 # trailing slash if there is a path component (optional in other cases).
 # Examples: "http://media.lawrence.com", "http://example.com/media/"
 MEDIA_URL = '/media/'
 
-STATIC_ROOT = path.join(PROJECT_ROOT, '../../static/')
+STATIC_ROOT = '/app/static/'
 STATIC_URL = '/static/'
 
 STATIC_URL = '/static/'
 
+
+
+SESSION_COOKIE_NAME = 'fnpcas'
+
+GRAVATAR_DEFAULT_IMAGE = 'mm'
+GRAVATAR_URL_PREFIX = 'https://www.gravatar.com/'
+
+SITE_TITLE = 'Fundacja Wolne Lektury'
+
+
+# Import localsettings file, which may override settings defined here
+try:
+    from .localsettings import *
+except ImportError:
+    pass
+
+
+
+DEFAULT_AUTO_FIELD = 'django.db.models.AutoField'
+
 STATICFILES_DIRS = [
 STATICFILES_DIRS = [
-    path.join(PROJECT_ROOT, 'static'),
+    os.path.join(PROJECT_ROOT, 'static'),
 ]
 
 ROOT_URLCONF = 'cas.urls'
 ]
 
 ROOT_URLCONF = 'cas.urls'
@@ -87,6 +137,7 @@ LOCALE_PATHS = (
 INSTALLED_APPS = (
     'accounts.apps.AccountsConfig',
     'emails.apps.EmailsConfig',
 INSTALLED_APPS = (
     'accounts.apps.AccountsConfig',
     'emails.apps.EmailsConfig',
+    'ftp',
     'services.apps.ServicesConfig',
     'ssh_keys.apps.SshKeysConfig',
 
     'services.apps.ServicesConfig',
     'ssh_keys.apps.SshKeysConfig',
 
@@ -114,19 +165,19 @@ MIDDLEWARE = (
 )
 
 # django-cas-provider settings
 )
 
 # django-cas-provider settings
-LOGIN_URL = '/cas/login/'
-LOGOUT_URL = '/cas/logout/'
+LOGIN_URL = '/cas/login'
+LOGOUT_URL = '/cas/logout'
 LOGIN_REDIRECT_URL = '/accounts/'
 CAS_CUSTOM_ATTRIBUTES_CALLBACK = 'cas.utils.custom_attributes_callback'
 LOGIN_REDIRECT_URL = '/accounts/'
 CAS_CUSTOM_ATTRIBUTES_CALLBACK = 'cas.utils.custom_attributes_callback'
-SESSION_COOKIE_NAME = 'fnpcas'
 
 
-GRAVATAR_DEFAULT_IMAGE = 'mm'
-GRAVATAR_URL_PREFIX = 'https://www.gravatar.com/'
 
 
-SITE_TITLE = 'Fundacja Nowoczesna Polska'
+OIDC_USERINFO = 'emails.oidc.userinfo'
 
 
-# Import localsettings file, which may override settings defined here
-try:
-    from .localsettings import *
-except ImportError:
-    pass
+PASSWORD_HASHERS = (
+    'cas.hashers.FNPBCryptPasswordHasher',
+)
+
+if DEBUG:
+    EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
+    ALLOWED_HOSTS = ALLOWED_HOSTS or ['*']
+    SECRET_KEY = SECRET_KEY or 'dev-secret-key'