· 5 years ago · Aug 07, 2020, 04:44 PM
1"""
2Django settings for budget_controller project.
3
4Generated by 'django-admin startproject' using Django 3.0.4.
5
6For more information on this file, see
7https://docs.djangoproject.com/en/3.0/topics/settings/
8
9For the full list of settings and their values, see
10https://docs.djangoproject.com/en/3.0/ref/settings/
11"""
12
13import os
14import environ
15import datetime
16
17
18env = environ.Env(
19 DEBUG=(bool, False),
20)
21
22environ.Env.read_env(env_file='.environment')
23# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
24BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
25
26
27# Quick-start development settings - unsuitable for production
28# See https://docs.djangoproject.com/en/3.0/howto/deployment/checklist/
29
30# SECURITY WARNING: keep the secret key used in production secret!
31SECRET_KEY = env('SECRET_KEY')
32
33# SECURITY WARNING: don't run with debug turned on in production!
34DEBUG = env('DEBUG')
35
36ALLOWED_HOSTS = [env('SERVER_IP')]
37
38
39# Application definition
40
41INSTALLED_APPS = [
42 'django.contrib.admin',
43 'django.contrib.auth',
44 'django.contrib.contenttypes',
45 'django.contrib.sessions',
46 'django.contrib.messages',
47 'django.contrib.staticfiles',
48 'rest_framework',
49 'corsheaders',
50 'core',
51 'rest_registration',
52]
53
54REST_FRAMEWORK = {
55 'DEFAULT_FILTER_BACKENDS': ['django_filters.rest_framework.DjangoFilterBackend'],
56 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.PageNumberPagination',
57 'PAGE_SIZE': 50,
58 'DEFAULT_PERMISSION_CLASSES': [
59 'rest_framework.permissions.AllowAny'
60 ],
61 'DEFAULT_AUTHENTICATION_CLASSES': [
62 'rest_framework_simplejwt.authentication.JWTAuthentication',
63 ],
64 'DEFAULT_THROTTLE_CLASSES': [],
65 'DEFAULT_THROTTLE_RATES': {
66 'throttle_per_day': '10000/day',
67 'throttle_per_hour': '1000/hour',
68 'throttle_per_minute': '30/min',
69 }
70}
71
72MIDDLEWARE = [
73 'django.middleware.security.SecurityMiddleware',
74 'django.contrib.sessions.middleware.SessionMiddleware',
75 'django.middleware.common.CommonMiddleware',
76 'django.middleware.csrf.CsrfViewMiddleware',
77 'django.contrib.auth.middleware.AuthenticationMiddleware',
78 'django.contrib.messages.middleware.MessageMiddleware',
79 'django.middleware.clickjacking.XFrameOptionsMiddleware',
80]
81
82ROOT_URLCONF = 'budget_controller.urls'
83
84TEMPLATES = [
85 {
86 'BACKEND': 'django.template.backends.django.DjangoTemplates',
87 'DIRS': [],
88 'APP_DIRS': True,
89 'OPTIONS': {
90 'context_processors': [
91 'django.template.context_processors.debug',
92 'django.template.context_processors.request',
93 'django.contrib.auth.context_processors.auth',
94 'django.contrib.messages.context_processors.messages',
95 ],
96 },
97 },
98]
99
100WSGI_APPLICATION = 'budget_controller.wsgi.application'
101
102
103# Database
104# https://docs.djangoproject.com/en/3.0/ref/settings/#databases
105
106DATABASES = {
107 'default': env.db(),
108}
109
110
111# Password validation
112# https://docs.djangoproject.com/en/3.0/ref/settings/#auth-password-validators
113
114AUTH_PASSWORD_VALIDATORS = [
115 # {'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator'},
116 # {'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator'},
117 # {'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator'},
118 # {'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator'},
119]
120
121REST_REGISTRATION = {
122 'REGISTER_VERIFICATION_ENABLED': False,
123 'RESET_PASSWORD_VERIFICATION_ENABLED': False,
124 'REGISTER_EMAIL_VERIFICATION_ENABLED': False,
125}
126
127# Internationalization
128# https://docs.djangoproject.com/en/3.0/topics/i18n/
129
130LANGUAGE_CODE = 'en-us'
131
132TIME_ZONE = 'UTC'
133
134USE_I18N = True
135
136USE_L10N = True
137
138USE_TZ = True
139
140
141# Static files
142STATIC_URL = '/static/'
143STATIC_ROOT = os.path.join(BASE_DIR, 'static')
144
145# JWT settings
146SIMPLE_JWT = {
147 'ACCESS_TOKEN_LIFETIME': datetime.timedelta(minutes=int(env('ACCESS_TOKEN_LIFETIME_MINUTES'))),
148 'REFRESH_TOKEN_LIFETIME': datetime.timedelta(days=int(env('REFRESH_TOKEN_LIFETIME_DAYS'))),
149 'ROTATE_REFRESH_TOKENS': False,
150 'BLACKLIST_AFTER_ROTATION': True,
151
152 'ALGORITHM': env('SIMPLE_JWT_ALGORITHM'),
153 'SIGNING_KEY': env('SIMPLE_JWT_SIGNING_KEY'),
154 'VERIFYING_KEY': None,
155 'AUDIENCE': None,
156 'ISSUER': None,
157
158 'AUTH_HEADER_TYPES': ('Bearer',),
159 'USER_ID_FIELD': 'id',
160 'USER_ID_CLAIM': 'user_id',
161
162 'AUTH_TOKEN_CLASSES': ('rest_framework_simplejwt.tokens.AccessToken',),
163 'TOKEN_TYPE_CLAIM': 'token_type',
164
165 'JTI_CLAIM': 'jti',
166}
167
168EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
169EMAIL_HOST = 'smtp.gmail.com'
170EMAIL_USE_TLS = True
171EMAIL_PORT = env('EMAIL_PORT')
172EMAIL_HOST_USER = env('EMAIL_HOST_USER')
173EMAIL_HOST_PASSWORD = env('EMAIL_HOST_PASSWORD')
174