|
4 | 4 |
|
5 | 5 | import os |
6 | 6 | from pathlib import Path |
| 7 | +import sys |
7 | 8 |
|
8 | 9 | BASE_DIR = Path(__file__).resolve().parent.parent |
9 | 10 |
|
10 | 11 | SECRET_KEY = os.environ.get('SECRET_KEY', 'django-insecure-dev-key-argus-ia-2024') |
11 | 12 |
|
12 | 13 | DEBUG = os.environ.get('DEBUG', 'False').lower() == 'true' |
13 | 14 |
|
14 | | -ALLOWED_HOSTS = ['argus-ia.up.railway.app', '.railway.app', 'localhost', '127.0.0.1'] |
| 15 | +ALLOWED_HOSTS = [ |
| 16 | + h.strip() for h in os.environ.get( |
| 17 | + 'ALLOWED_HOSTS', |
| 18 | + 'argus-ia.up.railway.app,localhost,127.0.0.1' |
| 19 | + ).split(',') |
| 20 | +] |
15 | 21 |
|
16 | 22 | INSTALLED_APPS = [ |
17 | 23 | 'django.contrib.admin', |
|
54 | 60 |
|
55 | 61 | WSGI_APPLICATION = 'argus_ia.wsgi.application' |
56 | 62 |
|
57 | | -# Database Configuration |
58 | | -# DATABASES |
59 | | -DATABASES = { |
60 | | - 'default': { |
61 | | - 'ENGINE': 'django.db.backends.sqlite3', |
62 | | - 'NAME': BASE_DIR / 'db.sqlite3', |
63 | | - } |
64 | | -} |
65 | 63 |
|
| 64 | +# ================= DATABASE ===================== |
66 | 65 | if 'DATABASE_URL' in os.environ: |
67 | 66 | import dj_database_url |
68 | | - DATABASES['default'] = dj_database_url.config( |
69 | | - conn_max_age=600, |
70 | | - ssl_require=False |
71 | | - ) |
| 67 | + DATABASES = { |
| 68 | + 'default': dj_database_url.config( |
| 69 | + conn_max_age=600, |
| 70 | + conn_health_checks=True, |
| 71 | + ssl_require=False |
| 72 | + ) |
| 73 | + } |
| 74 | +else: |
| 75 | + DATABASES = { |
| 76 | + 'default': { |
| 77 | + 'ENGINE': 'django.db.backends.sqlite3', |
| 78 | + 'NAME': BASE_DIR / 'db.sqlite3', |
| 79 | + } |
| 80 | + } |
| 81 | + |
72 | 82 |
|
73 | | -# Password validation |
| 83 | +# ================= PASSWORD ===================== |
74 | 84 | AUTH_PASSWORD_VALIDATORS = [ |
75 | | - { |
76 | | - 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', |
77 | | - }, |
78 | | - { |
79 | | - 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', |
80 | | - }, |
81 | | - { |
82 | | - 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', |
83 | | - }, |
84 | | - { |
85 | | - 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', |
86 | | - }, |
| 85 | + {'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator'}, |
| 86 | + {'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator'}, |
| 87 | + {'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator'}, |
| 88 | + {'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator'}, |
87 | 89 | ] |
88 | 90 |
|
| 91 | + |
| 92 | +# ================= LOCALE ===================== |
89 | 93 | LANGUAGE_CODE = 'pt-br' |
90 | 94 | TIME_ZONE = 'America/Sao_Paulo' |
91 | 95 | USE_I18N = True |
92 | 96 | USE_TZ = True |
93 | 97 |
|
94 | | -# Static files |
| 98 | + |
| 99 | +# ================= STATIC FILES ===================== |
95 | 100 | STATIC_URL = '/static/' |
96 | 101 | STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles') |
97 | | -STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')] |
98 | 102 |
|
99 | | -# Whitenoise configuration |
100 | | -STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage' |
| 103 | +if DEBUG: |
| 104 | + STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')] |
101 | 105 |
|
102 | | -# Corrige o warning do Whitenoise |
| 106 | +STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage' |
103 | 107 | WHITENOISE_ROOT = os.path.join(BASE_DIR, 'staticfiles') |
104 | 108 |
|
| 109 | + |
105 | 110 | DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' |
106 | 111 |
|
107 | | -# Session configuration |
| 112 | + |
| 113 | +# ================= SESSION ===================== |
108 | 114 | SESSION_ENGINE = 'django.contrib.sessions.backends.db' |
109 | | -SESSION_COOKIE_AGE = 3600 # 1 hora |
| 115 | +SESSION_COOKIE_AGE = 3600 |
110 | 116 | SESSION_SAVE_EVERY_REQUEST = True |
111 | 117 | SESSION_EXPIRE_AT_BROWSER_CLOSE = False |
112 | 118 |
|
113 | | -# CSRF configuration |
| 119 | + |
| 120 | +# ================= CSRF ===================== |
114 | 121 | CSRF_TRUSTED_ORIGINS = [ |
115 | 122 | 'https://argus-ia.up.railway.app', |
116 | | - 'https://*.railway.app' |
| 123 | + 'https://*.railway.app', |
117 | 124 | ] |
118 | 125 |
|
119 | | -# if not DEBUG: |
120 | | -# SECURE_SSL_REDIRECT = True |
121 | | -# SESSION_COOKIE_SECURE = True |
122 | | -# CSRF_COOKIE_SECURE = True |
123 | | -# SECURE_BROWSER_XSS_FILTER = True |
124 | | -# SECURE_CONTENT_TYPE_NOSNIFF = True |
| 126 | +# Segurança em produção — NÃO aplicar no ambiente local |
| 127 | +if not DEBUG and not ('localhost' in ALLOWED_HOSTS or '127.0.0.1' in ALLOWED_HOSTS): |
| 128 | + SECURE_SSL_REDIRECT = True |
| 129 | + SESSION_COOKIE_SECURE = True |
| 130 | + CSRF_COOKIE_SECURE = True |
| 131 | + SECURE_BROWSER_XSS_FILTER = True |
| 132 | + SECURE_CONTENT_TYPE_NOSNIFF = True |
| 133 | + SECURE_HSTS_SECONDS = 31536000 |
| 134 | + SECURE_HSTS_INCLUDE_SUBDOMAINS = True |
| 135 | + SECURE_HSTS_PRELOAD = True |
| 136 | +else: |
| 137 | + # Ambiente local — não usar SSL |
| 138 | + SECURE_SSL_REDIRECT = False |
| 139 | + SESSION_COOKIE_SECURE = False |
| 140 | + CSRF_COOKIE_SECURE = False |
| 141 | + |
| 142 | +PORT = os.environ.get('PORT', 8000) |
0 commit comments