settings.py 8.15 KB
Newer Older
Arnaud Fabre's avatar
Arnaud Fabre committed
1
2
3
4
5
6
7
8
9
10
11
12
"""
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
Quality    
Jamesie Pic committed
13
from socket import gethostname
Arnaud Fabre's avatar
Arnaud Fabre committed
14

Jamesie Pic's avatar
Jamesie Pic committed
15
from django.conf import global_settings
Jamesie Pic's avatar
Quality    
Jamesie Pic committed
16
from django.utils.crypto import get_random_string
Arnaud Fabre's avatar
Arnaud Fabre committed
17

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

Jamesie Pic's avatar
Jamesie Pic committed
20
21
22
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
23

Jamesie Pic's avatar
Jamesie Pic committed
24
25
26
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
27

Jamesie Pic's avatar
Quality    
Jamesie Pic committed
28
29
30
31
32
PUBLIC_DIR = os.path.join(
    os.environ.get(
        'OPENSHIFT_REPO_DIR',
        ''),
    'wsgi/static')
Arnaud Fabre's avatar
Arnaud Fabre committed
33
34
35
36
37

# 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
38
39
40
41
42
43
44
45
46
SECRET_FILE = os.path.join(DATA_DIR, 'secret.txt')

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
47

Jamesie Pic's avatar
Jamesie Pic committed
48

Jamesie Pic's avatar
Quality    
Jamesie Pic committed
49
DEBUG = os.environ.get('DJANGO_DEBUG', False)
Arnaud Fabre's avatar
Arnaud Fabre committed
50
TEMPLATE_DEBUG = DEBUG
Jamesie Pic's avatar
Jamesie Pic committed
51
52
53
54
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
55

Jamesie Pic's avatar
Jamesie Pic committed
56
57
58
ALLOWED_HOSTS = [
    gethostname(),
]
Arnaud Fabre's avatar
Arnaud Fabre committed
59

Jamesie Pic's avatar
Jamesie Pic committed
60
61
62
DNS = os.environ.get('OPENSHIFT_APP_DNS', None),
if DNS:
    ALLOWED_HOSTS += DNS
Arnaud Fabre's avatar
Arnaud Fabre committed
63

Jamesie Pic's avatar
Jamesie Pic committed
64
65
66
67
68
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
69
70
71

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

98
if DEBUG:
Jamesie Pic's avatar
Quality    
Jamesie Pic committed
99
100
101
102
103
104
    try:
        import debug_toolbar  # noqa
    except:
        pass
    else:
        INSTALLED_APPS += ('debug_toolbar',)
Arnaud Fabre's avatar
Arnaud Fabre committed
105

Arnaud Fabre's avatar
Arnaud Fabre committed
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
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
126
127
128
129
130
131
        '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',
Jamesie Pic's avatar
Quality    
Jamesie Pic committed
132
                                 'django.db.backends.sqlite3'),
Jamesie Pic's avatar
Jamesie Pic committed
133

Arnaud Fabre's avatar
Arnaud Fabre committed
134
135
136
    }
}

Jamesie Pic's avatar
Jamesie Pic committed
137
138
139
140
141
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']
Jamesie Pic's avatar
Quality    
Jamesie Pic committed
142
143
144
145
    DATABASES['default']['USER'] = os.environ[
        'OPENSHIFT_POSTGRESQL_DB_USERNAME']
    DATABASES['default']['PASSWORD'] = os.environ[
        'OPENSHIFT_POSTGRESQL_DB_PASSWORD']
Jamesie Pic's avatar
Jamesie Pic committed
146
147
    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
148
149
150
151
152
    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
153
LANGUAGE_CODE = os.environ.get('DJANGO_LANGUAGE_CODE', 'en-us')
Arnaud Fabre's avatar
Arnaud Fabre committed
154
155
156
157
158
159
160
161
162
163
164
165
166

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
167
168
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]

Arnaud Fabre's avatar
Arnaud Fabre committed
169
STATIC_URL = '/static/'
Jamesie Pic's avatar
Jamesie Pic committed
170
171
172
173
174
175
176
177
178
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
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202

# 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
203
204
205
206
TEMPLATE_CONTEXT_PROCESSORS = global_settings.TEMPLATE_CONTEXT_PROCESSORS + (
    'constance.context_processors.config',
)

Arnaud Fabre's avatar
Arnaud Fabre committed
207
208
209
210
211
212
# Static files finders


STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
Arnaud Fabre's avatar
Arnaud Fabre committed
213
    # Compressor finder
Arnaud Fabre's avatar
Arnaud Fabre committed
214
215
216
    'compressor.finders.CompressorFinder',
)

Arnaud Fabre's avatar
Arnaud Fabre committed
217
# Use compressor even in debug
Arnaud Fabre's avatar
Arnaud Fabre committed
218
COMPRESS_ENABLED = False
Arnaud Fabre's avatar
Arnaud Fabre committed
219

Arnaud Fabre's avatar
Arnaud Fabre committed
220
221
222
223
224
225
226
227
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
228
229
230
231
232
233
234
235
236
237
238
239


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

Jamesie Pic's avatar
Jamesie Pic committed
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
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
289
CONSTANCE_BACKEND = 'constance.backends.database.DatabaseBackend'
290
291
292
293

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