settings.py 8.17 KB
Newer Older
Arnaud Fabre's avatar
Arnaud Fabre committed
1
2
3
4
5
6
7
8
9
10
11
12
13
"""
Django settings for memopol project.

For more information on this file, see
https://docs.djangoproject.com/en/1.7/topics/settings/

For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.7/ref/settings/
"""

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
import os

Jamesie Pic's avatar
Jamesie Pic committed
14
from django.conf import global_settings
Arnaud Fabre's avatar
Arnaud Fabre committed
15

Jamesie Pic's avatar
Jamesie Pic committed
16
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
Arnaud Fabre's avatar
Arnaud Fabre committed
17

Jamesie Pic's avatar
Jamesie Pic committed
18
19
20
DATA_DIR = os.environ.get('OPENSHIFT_DATA_DIR', 'data')
if not os.path.exists(DATA_DIR):
    os.makedirs(DATA_DIR)
Arnaud Fabre's avatar
Arnaud Fabre committed
21

Jamesie Pic's avatar
Jamesie Pic committed
22
23
24
LOG_DIR = os.environ.get('OPENSHIFT_LOG_DIR', 'log')
if not os.path.exists(LOG_DIR):
    os.makedirs(LOG_DIR)
Arnaud Fabre's avatar
Arnaud Fabre committed
25

Jamesie Pic's avatar
Jamesie Pic committed
26
PUBLIC_DIR = os.path.join(os.environ.get('OPENSHIFT_REPO_DIR', ''), 'wsgi/static')
Arnaud Fabre's avatar
Arnaud Fabre committed
27
28
29
30
31

# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.7/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
Jamesie Pic's avatar
Jamesie Pic committed
32
33
34
35
36
37
38
39
40
41
SECRET_FILE = os.path.join(DATA_DIR, 'secret.txt')

from django.utils.crypto import get_random_string
if not os.path.exists(SECRET_FILE):
    chars = 'abcdefghijklmnopqrstuvwxyz0123456789!@#$%^&*(-_=+)'
    with open(SECRET_FILE, 'w+') as f:
        f.write(get_random_string(50, chars))

with open(SECRET_FILE, 'r') as f:
    SECRET_KEY = f.read()
Arnaud Fabre's avatar
Arnaud Fabre committed
42

Jamesie Pic's avatar
Jamesie Pic committed
43
44

DEBUG = os.environ.get('DEBUG', False)
Arnaud Fabre's avatar
Arnaud Fabre committed
45
TEMPLATE_DEBUG = DEBUG
Jamesie Pic's avatar
Jamesie Pic committed
46
47
48
49
LOG_LEVEL = os.environ.get('DJANGO_LOG_LEVEL', 'INFO')

if SECRET_KEY == 'notsecret' and not DEBUG:
    raise Exception('Please export DJANGO_SECRET_KEY or DEBUG')
Arnaud Fabre's avatar
Arnaud Fabre committed
50

Jamesie Pic's avatar
Jamesie Pic committed
51
52
53
54
from socket import gethostname
ALLOWED_HOSTS = [
    gethostname(),
]
Arnaud Fabre's avatar
Arnaud Fabre committed
55

Jamesie Pic's avatar
Jamesie Pic committed
56
57
58
DNS = os.environ.get('OPENSHIFT_APP_DNS', None),
if DNS:
    ALLOWED_HOSTS += DNS
Arnaud Fabre's avatar
Arnaud Fabre committed
59

Jamesie Pic's avatar
Jamesie Pic committed
60
61
62
63
64
if 'DJANGO_ALLOWED_HOSTS' in os.environ:
    ALLOWED_HOSTS += os.environ.get('DJANGO_ALLOWED_HOSTS').split(',')

REDIS_DB = os.environ.get('REDIS_DB', 1)
ORGANIZATION_NAME = os.environ.get('ORGANIZATION', 'Memopol Demo')
Arnaud Fabre's avatar
Arnaud Fabre committed
65
66
67

INSTALLED_APPS = (
    # 'django.contrib.admin',
Jamesie Pic's avatar
Jamesie Pic committed
68
    'autocomplete_light',
Arnaud Fabre's avatar
Arnaud Fabre committed
69
70
    # Instead of contrib.admin to use Django-Admin-Plus
    'django.contrib.admin.apps.SimpleAdminConfig',
Arnaud Fabre's avatar
Arnaud Fabre committed
71
72
73
74
75
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
Arnaud Fabre's avatar
Arnaud Fabre committed
76
    'django.contrib.humanize',
77
    # 3rd party apps
Arnaud Fabre's avatar
Arnaud Fabre committed
78
79
    'compressor',
    'adminplus',
80
    'constance',
Jamesie Pic's avatar
Jamesie Pic committed
81
    'constance.backends.database',
Arnaud Fabre's avatar
Arnaud Fabre committed
82
83
    'bootstrap3',
    'datetimewidget',
84
85
    'django_filters',
    'taggit',
Arnaud Fabre's avatar
Arnaud Fabre committed
86
87
88
89
90
91
    # ---
    'core',
    'representatives',
    'representatives_votes',
    'legislature',
    'votes',
Jamesie Pic's avatar
Jamesie Pic committed
92
93
    'positions',
    'django_extensions',
Arnaud Fabre's avatar
Arnaud Fabre committed
94
95
)

96
if DEBUG:
Arnaud Fabre's avatar
Arnaud Fabre committed
97
98
    INSTALLED_APPS += (
        'debug_toolbar',
Arnaud Fabre's avatar
Arnaud Fabre committed
99
    )
Arnaud Fabre's avatar
Arnaud Fabre committed
100

Arnaud Fabre's avatar
Arnaud Fabre committed
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
MIDDLEWARE_CLASSES = (
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
)

ROOT_URLCONF = 'memopol.urls'

WSGI_APPLICATION = 'memopol.wsgi.application'


# Database
# https://docs.djangoproject.com/en/1.7/ref/settings/#databases

DATABASES = {
    'default': {
Jamesie Pic's avatar
Jamesie Pic committed
121
122
123
124
125
126
127
128
        'NAME': os.environ.get('DJANGO_DATABASE_DEFAULT_NAME', 'db.sqlite'),
        'USER': os.environ.get('DJANGO_DATABASE_DEFAULT_USER', ''),
        'PASSWORD': os.environ.get('DJANGO_DATABASE_DEFAULT_PASSWORD', ''),
        'HOST': os.environ.get('DJANGO_DATABASE_DEFAULT_HOST', ''),
        'PORT': os.environ.get('DJANGO_DATABASE_DEFAULT_PORT', ''),
        'ENGINE': os.environ.get('DJANGO_DATABASE_DEFAULT_ENGINE',
            'django.db.backends.sqlite3'),

Arnaud Fabre's avatar
Arnaud Fabre committed
129
130
131
    }
}

Jamesie Pic's avatar
Jamesie Pic committed
132
133
134
135
136
137
138
139
140
if 'OPENSHIFT_DATA_DIR' in os.environ:
    DATABASES['default']['NAME'] = os.path.join(DATA_DIR, 'db.sqlite')

if 'OPENSHIFT_POSTGRESQL_DB_HOST' in os.environ:
    DATABASES['default']['NAME'] = os.environ['OPENSHIFT_APP_NAME']
    DATABASES['default']['USER'] = os.environ['OPENSHIFT_POSTGRESQL_DB_USERNAME']
    DATABASES['default']['PASSWORD'] = os.environ['OPENSHIFT_POSTGRESQL_DB_PASSWORD']
    DATABASES['default']['HOST'] = os.environ['OPENSHIFT_POSTGRESQL_DB_HOST']
    DATABASES['default']['PORT'] = os.environ['OPENSHIFT_POSTGRESQL_DB_PORT']
Arnaud Fabre's avatar
Arnaud Fabre committed
141
142
143
144
145
    DATABASES['default']['ENGINE'] = 'django.db.backends.postgresql_psycopg2'

# Internationalization
# https://docs.djangoproject.com/en/1.7/topics/i18n/

Jamesie Pic's avatar
Jamesie Pic committed
146
LANGUAGE_CODE = os.environ.get('DJANGO_LANGUAGE_CODE', 'en-us')
Arnaud Fabre's avatar
Arnaud Fabre committed
147
148
149
150
151
152
153
154
155
156
157
158
159

TIME_ZONE = 'UTC'

USE_I18N = True

USE_L10N = True

USE_TZ = True


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.7/howto/static-files/

Jamesie Pic's avatar
Jamesie Pic committed
160
161
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

Arnaud Fabre's avatar
Arnaud Fabre committed
162
STATIC_URL = '/static/'
Jamesie Pic's avatar
Jamesie Pic committed
163
164
165
166
167
168
169
170
171
COMPRESS_ROOT = 'static/'

if DATA_DIR:
    MEDIA_URL = '/static/media/'
    MEDIA_ROOT = os.path.join(DATA_DIR, 'media')

if PUBLIC_DIR:
    STATIC_URL = '/static/collected/'
    STATIC_ROOT = os.path.join(PUBLIC_DIR, 'collected')
Arnaud Fabre's avatar
Arnaud Fabre committed
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195

# HAML Templates
# https://github.com/jessemiller/hamlpy

TEMPLATE_DIRS = (
    'core/templates',
)

TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader',
    'hamlpy.template.loaders.HamlPyFilesystemLoader',
    'hamlpy.template.loaders.HamlPyAppDirectoriesLoader',
)

"""
TEMPLATE_LOADERS = (
    ('django.template.loaders.cached.Loader', (
        'hamlpy.template.loaders.HamlPyFilesystemLoader',
        'hamlpy.template.loaders.HamlPyAppDirectoriesLoader',
    )),
)
"""

Jamesie Pic's avatar
Jamesie Pic committed
196
197
198
199
TEMPLATE_CONTEXT_PROCESSORS = global_settings.TEMPLATE_CONTEXT_PROCESSORS + (
    'constance.context_processors.config',
)

Arnaud Fabre's avatar
Arnaud Fabre committed
200
201
202
203
204
205
# Static files finders


STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
Arnaud Fabre's avatar
Arnaud Fabre committed
206
    # Compressor finder
Arnaud Fabre's avatar
Arnaud Fabre committed
207
208
209
    'compressor.finders.CompressorFinder',
)

Arnaud Fabre's avatar
Arnaud Fabre committed
210
# Use compressor even in debug
Arnaud Fabre's avatar
Arnaud Fabre committed
211
COMPRESS_ENABLED = False
Arnaud Fabre's avatar
Arnaud Fabre committed
212

Arnaud Fabre's avatar
Arnaud Fabre committed
213
214
215
216
217
218
219
220
COMPRESS_PRECOMPILERS = (
    # ('text/coffeescript', 'coffee --compile --stdio'),
    ('text/less', 'lessc {infile} {outfile}'),
    ('text/x-sass', 'sass {infile} {outfile}'),
    ('text/x-scss', 'sass --scss {infile} {outfile}'),
    # ('text/stylus', 'stylus < {infile} > {outfile}'),
    # ('text/foobar', 'path.to.MyPrecompilerFilter'),
)
Arnaud Fabre's avatar
Arnaud Fabre committed
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235


LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
        },
        'simple': {
            'format': '%(levelname)s[%(module)s]: %(message)s'
        },
    },
    'handlers': {
        'console': {
Jamesie Pic's avatar
Jamesie Pic committed
236
            'level': LOG_LEVEL,
Arnaud Fabre's avatar
Arnaud Fabre committed
237
238
239
240
241
242
243
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
    },
    'loggers': {
        'memopol': {
            'handlers': ['console'],
Jamesie Pic's avatar
Jamesie Pic committed
244
            'level': LOG_LEVEL,
Arnaud Fabre's avatar
Arnaud Fabre committed
245
246
247
        },
        'representatives': {
            'handlers': ['console'],
Jamesie Pic's avatar
Jamesie Pic committed
248
            'level': LOG_LEVEL,
Arnaud Fabre's avatar
Arnaud Fabre committed
249
250
251
        },
        'representatives_votes': {
            'handlers': ['console'],
Jamesie Pic's avatar
Jamesie Pic committed
252
            'level': LOG_LEVEL,
Arnaud Fabre's avatar
Arnaud Fabre committed
253
254
255
        }
    },
}
256

Jamesie Pic's avatar
Jamesie Pic committed
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
if DEBUG:
    LOGGING['handlers']['debug'] = {
        'level': 'DEBUG',
        'class': 'logging.FileHandler',
        'filename': os.path.join(LOG_DIR, 'debug.log'),
    }
    for logger in LOGGING['loggers'].values():
        logger['handlers'].append('debug')

RAVEN_FILE = os.path.join(DATA_DIR, 'sentry')
if os.path.exists(RAVEN_FILE):
    INSTALLED_APPS += ('raven.contrib.django.raven_compat',)

    LOGGING['handlers']['sentry'] = {
        'level': 'INFO',
        'class': 'raven.contrib.django.raven_compat.handlers.SentryHandler',
    }
    LOGGING['loggers']['sentry.errors'] = LOGGING['loggers']['raven'] = {
        'level': 'INFO',
        'handlers': ['console'],
        'propagate': False,
    }

    with open(RAVEN_FILE, 'r') as f:
        RAVEN_CONFIG = {
            'dsn': f.read().strip()
        }

Jamesie Pic's avatar
Jamesie Pic committed
285
CONSTANCE_BACKEND = 'constance.backends.database.DatabaseBackend'
286
287
288
289

CONSTANCE_CONFIG = {
    'USE_COUNTRY': (True, 'Use country for representative'),
    'MAIN_GROUP_KIND': ('group', 'Main group kind'),
Arnaud Fabre's avatar
Arnaud Fabre committed
290
291
    'ORGANIZATION_NAME': ('La Quadrature du Net', 'Organization name'),
    'POSITION_PUBLISHED': (False, 'Default position published status')
292
}