settings.py 9.38 KB
Newer Older
Thom Wiggers's avatar
Thom Wiggers committed
1
2
3
"""
Django settings for thaliawebsite project.

4
5
6
This file is loaded by __init__.py.

Its settings may be overridden by files loaded after it.
Thom Wiggers's avatar
Thom Wiggers committed
7
8
9
10
11
12
13
14
15

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

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

import os
16

17
from django.core.management.commands import makemessages
18
from django.utils.translation import ugettext_lazy as _
Thom Wiggers's avatar
Thom Wiggers committed
19
20

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
Thom Wiggers's avatar
Thom Wiggers committed
21
22
23
BASE_DIR = os.path.abspath(os.path.join(
    os.path.dirname(os.path.abspath(__file__)),
    '..', '..'))
Thom Wiggers's avatar
Thom Wiggers committed
24
25
26
27
28
29
30
31
32

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

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '#o-0d1q5&^&06tn@8pr1f(n3$crafd++^%sacao7hj*ea@c)^t'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
33
INTERNAL_IPS = ['127.0.0.1']
34
ALLOWED_HOSTS = ['*']
Thom Wiggers's avatar
Thom Wiggers committed
35

Thom Wiggers's avatar
Thom Wiggers committed
36
if not DEBUG:  # Django 1.10.3 security release changed behaviour
37
    ALLOWED_HOSTS = ['*']
Thom Wiggers's avatar
Thom Wiggers committed
38

Joost Rijneveld's avatar
Joost Rijneveld committed
39
SITE_ID = 1
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
40
41
SITE_DOMAIN = os.environ.get('SITE_DOMAIN', 'thalia.localhost')
BASE_URL = f'https://{SITE_DOMAIN}'
Thom Wiggers's avatar
Thom Wiggers committed
42

43
44
DATA_UPLOAD_MAX_NUMBER_FIELDS = 10000  # Useful for managing members

Thom Wiggers's avatar
Thom Wiggers committed
45
46
47
48
49
50
51
52
53
# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
Thom Wiggers's avatar
Thom Wiggers committed
54
55
    'django.contrib.sites',
    'django.contrib.sitemaps',
Luuk Scholten's avatar
Luuk Scholten committed
56
    # Dependencies
57
    'bootstrap4',
58
    'tinymce',
59
    'rest_framework',
60
    'rest_framework.authtoken',
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
61
    'compressor',
62
    # Our apps
63
64
    # Directly link to the app config when applicable as recommended
    # by the docs: https://docs.djangoproject.com/en/2.0/ref/applications/
Thom Wiggers's avatar
Thom Wiggers committed
65
    'thaliawebsite',  # include for admin settings
66
67
68
69
70
    'pushnotifications.apps.PushNotificationsConfig',
    'members.apps.MembersConfig',
    'documents.apps.DocumentsConfig',
    'activemembers.apps.ActiveMembersConfig',
    'photos.apps.PhotosConfig',
71
    'utils',
72
73
74
75
76
77
78
79
80
81
82
    'mailinglists.apps.MailinglistsConfig',
    'merchandise.apps.MerchandiseConfig',
    'thabloid.apps.ThabloidConfig',
    'partners.apps.PartnersConfig',
    'events.apps.EventsConfig',
    'pizzas.apps.PizzasConfig',
    'newsletters.apps.NewslettersConfig',
    'education.apps.EducationConfig',
    'announcements.apps.AnnouncementsConfig',
    'registrations.apps.RegistrationsConfig',
    'payments.apps.PaymentsConfig',
Thom Wiggers's avatar
Thom Wiggers committed
83
84
]

85
86
87
88
89
90
91
92
93
# enable template check if it's installed
# this allows us to not have it enabled in production
try:
    import django_template_check
    del django_template_check
    INSTALLED_APPS.append('django_template_check')
except ImportError:
    pass

Thom Wiggers's avatar
Thom Wiggers committed
94
95
96
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
Thom Wiggers's avatar
Thom Wiggers committed
97
    'django.middleware.http.ConditionalGetMiddleware',
Thom Wiggers's avatar
Thom Wiggers committed
98
99
100
101
102
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.locale.LocaleMiddleware',
103
104
    # Our middleware
    'members.middleware.MemberMiddleware',
Thom Wiggers's avatar
Thom Wiggers committed
105
106
107
108
]

ROOT_URLCONF = 'thaliawebsite.urls'

Thom Wiggers's avatar
Thom Wiggers committed
109
110
# WARNING
# Also update this in production.py!!!
Thom Wiggers's avatar
Thom Wiggers committed
111
112
113
TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
114
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
Thom Wiggers's avatar
Thom Wiggers committed
115
116
117
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
118
                'thaliawebsite.context_processors.source_commit',
Thom Wiggers's avatar
Thom Wiggers committed
119
120
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
Thom Wiggers's avatar
Thom Wiggers committed
121
                'django.template.context_processors.media',
Thom Wiggers's avatar
Thom Wiggers committed
122
123
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
Joost Rijneveld's avatar
Joost Rijneveld committed
124
                'announcements.context_processors.announcements',
125
                'thaliawebsite.context_processors.thumbnail_sizes',
Thom Wiggers's avatar
Thom Wiggers committed
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
            ],
        },
    },
]

WSGI_APPLICATION = 'thaliawebsite.wsgi.application'

# Database
# https://docs.djangoproject.com/en/dev/ref/settings/#databases
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}

142
143
144
145
146
147
# Login pages

LOGIN_URL = '/login/'

LOGIN_REDIRECT_URL = '/'

148
149
150
# Email settings
EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'

Thom Wiggers's avatar
Thom Wiggers committed
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
# Password validation
# https://docs.djangoproject.com/en/dev/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': ('django.contrib.auth.'
                 'password_validation.UserAttributeSimilarityValidator'),
    },
    {
        'NAME': ('django.contrib.auth.'
                 'password_validation.MinimumLengthValidator'),
    },
    {
        'NAME': ('django.contrib.auth.'
                 'password_validation.CommonPasswordValidator'),
    },
    {
        'NAME': ('django.contrib.auth.'
                 'password_validation.NumericPasswordValidator'),
    },
]

Thom Wiggers's avatar
Thom Wiggers committed
173
174
175
176
177
178
# allow to use md5 in tests
PASSWORD_HASHERS = (
    'django.contrib.auth.hashers.PBKDF2PasswordHasher',
    'django.contrib.auth.hashers.MD5PasswordHasher',
)

Thom Wiggers's avatar
Thom Wiggers committed
179
180
AUTHENTICATION_BACKENDS = [
    'django.contrib.auth.backends.ModelBackend',
181
    'activemembers.backends.MemberGroupBackend',
Thom Wiggers's avatar
Thom Wiggers committed
182
183
]

184
185
REST_FRAMEWORK = {
    'DEFAULT_AUTHENTICATION_CLASSES': (
186
        'rest_framework.authentication.SessionAuthentication',
187
        'rest_framework.authentication.TokenAuthentication',
188
189
190
    ),
    'DEFAULT_PAGINATION_CLASS':
        'rest_framework.pagination.LimitOffsetPagination',
191
    'DEFAULT_VERSIONING_CLASS':
Thom Wiggers's avatar
Thom Wiggers committed
192
        'rest_framework.versioning.URLPathVersioning',
193
194
}

Thom Wiggers's avatar
Thom Wiggers committed
195
196
197
# Internationalization
# https://docs.djangoproject.com/en/dev/topics/i18n/

198
LANGUAGE_CODE = 'en'
Thom Wiggers's avatar
Thom Wiggers committed
199

200
TIME_ZONE = 'Europe/Amsterdam'
Thom Wiggers's avatar
Thom Wiggers committed
201
202
203
204
205
206
207

USE_I18N = True

USE_L10N = True

USE_TZ = True

208
209
210
211
212
LANGUAGES = [
    ('en', _('English')),
    ('nl', _('Dutch'))
]

213
LOCALE_PATHS = ('locale',)
214

Thom Wiggers's avatar
Thom Wiggers committed
215
216
217
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/dev/howto/static-files/

Thom Wiggers's avatar
Thom Wiggers committed
218
# Where to store uploaded files
Thom Wiggers's avatar
Thom Wiggers committed
219
MEDIA_ROOT = os.path.join(BASE_DIR, 'media')
220
MEDIA_URL = '/media/'  # Public is included by the db fields
Luuk Scholten's avatar
Luuk Scholten committed
221

222
223
SENDFILE_BACKEND = 'sendfile.backends.development'

Luuk Scholten's avatar
Luuk Scholten committed
224
225
226
227
228
229
230
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'static')

STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
    # other finders
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
231
    'compressor.finders.CompressorFinder',
Luuk Scholten's avatar
Luuk Scholten committed
232
233
)

Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
234
235
236
# Compressor settings
COMPRESS_ENABLED = True

237
COMPRESS_PRECOMPILERS = (
Thom Wiggers's avatar
Thom Wiggers committed
238
    ('text/x-scss', 'django_libsass.SassCompiler'),
239
240
241
242
243
)

COMPRESS_CSS_FILTERS = ['compressor.filters.css_default.CssAbsoluteFilter',
                        'compressor.filters.cssmin.rCSSMinFilter']

Luuk Scholten's avatar
Luuk Scholten committed
244
245
# Precompiler settings
STATIC_PRECOMPILER_LIST_FILES = True
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
246

247
248
249
250
251
252
# Membership prices
MEMBERSHIP_PRICES = {
    'year': 7.5,
    'study': 30,
}

253
254
255
256
THUMBNAIL_SIZES = {
    'small': '150x150',
    'medium': '300x300',
    'large': '1024x768',
257
    'slide': '2000x430'
258
259
}

260
261
262
# Placeholder Firebase config
FIREBASE_CREDENTIALS = {}

Thom Wiggers's avatar
Thom Wiggers committed
263
# Default FROM email
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
264
DEFAULT_FROM_EMAIL = f'noreply@{SITE_DOMAIN}'
265
266
SERVER_EMAIL = DEFAULT_FROM_EMAIL

Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
267
# Newsletter settings
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
268
NEWSLETTER_FROM_ADDRESS = f'newsletter@{SITE_DOMAIN}'
269
270

# Board notification address
271
BOARD_NOTIFICATION_ADDRESS = f'info@{SITE_DOMAIN}'
272

273
# Partners notification email
274
PARTNER_NOTIFICATION_ADDRESS = f'samenwerking@{SITE_DOMAIN}'
275

Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
276
# Conscribo settings
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
277
278
279
CONSCRIBO_ACCOUNT = os.environ.get('CONSCRIBO_ACCOUNT', '')
CONSCRIBO_USER = os.environ.get('CONSCRIBO_USER', '')
CONSCRIBO_PASSWORD = os.environ.get('CONSCRIBO_PASSWORD', '')
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
280

281
282
283
# Payments creditor identifier
SEPA_CREDITOR_ID = os.environ.get('SEPA_CREDITOR_ID', 'PLACEHOLDER')

284
# Mailinglist API key
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
285
MAILINGLIST_API_SECRET = os.environ.get('MAILINGLIST_API_SECRET', '')
286

287
# Members Sentry API key
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
288
MEMBERS_SENTRY_API_SECRET = os.environ.get('MEMBERS_SENTRY_API_SECRET', '')
289

290
# Activemembers NextCloud API key
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
291
292
ACTIVEMEMBERS_NEXTCLOUD_API_SECRET = os.environ.get(
    'ACTIVEMEMBERS_NEXTCLOUD_API_SECRET', '')
293

294
# Google maps API key and secrets
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
295
296
GOOGLE_MAPS_API_KEY = os.environ.get('GOOGLE_MAPS_API_KEY', '')
GOOGLE_MAPS_API_SECRET = os.environ.get('GOOGLE_MAPS_API_SECRET', '')
Thalia Technicie's avatar
Thalia Technicie committed
297
GOOGLE_PLACES_API_KEY = os.environ.get('GOOGLE_PLACES_API_KEY', '')
298

299
300
# Photos settings
PHOTO_UPLOAD_SIZE = 1920, 1080
Thom Wiggers's avatar
Thom Wiggers committed
301
302

# API key for wiki
Sébastiaan Versteeg's avatar
Sébastiaan Versteeg committed
303
WIKI_API_KEY = os.environ.get('WIKI_API_KEY', 'debug')
Wietse Kuipers's avatar
Wietse Kuipers committed
304

305
# TinyMCE config
Thom Wiggers's avatar
Thom Wiggers committed
306
TINYMCE_JS_URL = '/static/tinymce/js/tinymce/tinymce.min.js'
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323

TINYMCE_DEFAULT_CONFIG = {
    'selector': 'textarea',
    'theme': 'modern',
    'plugins': 'link image paste code contextmenu',
    'toolbar1': 'bold italic underline strikethrough | link unlink | '
                'bullist numlist | undo redo | code',
    'contextmenu': 'bold italic underline strikethrough | image',
    'menubar': False,
    'inline': False,
    'statusbar': True,
    'width': 'auto',
    'height': 240,
    'paste_as_text': True,
    'relative_urls': False,
    'remove_script_host': False,
}
Thom Wiggers's avatar
Thom Wiggers committed
324

325
326
327
328
BOOTSTRAP4 = {
    'required_css_class': 'required-field'
}

Thom Wiggers's avatar
Thom Wiggers committed
329
330
331

DEFAULT_EXCEPTION_REPORTER_FILTER = (
    'utils.exception_filter.ThaliaSafeExceptionReporterFilter')
332
333
334
335


# Make sure the locations in django.po files don't include line nrs.
makemessages.Command.xgettext_options.append('--add-location=file')