FitTrackee/fittrackee/config.py

91 lines
2.7 KiB
Python
Raw Normal View History

2018-01-01 21:54:03 +01:00
import os
2018-01-14 20:49:35 +01:00
from dramatiq.brokers.redis import RedisBroker
from dramatiq.brokers.stub import StubBroker
2018-01-01 21:54:03 +01:00
from flask import current_app
from sqlalchemy.pool import NullPool
2018-01-01 21:54:03 +01:00
if os.getenv('APP_SETTINGS') == 'fittrackee.config.TestingConfig':
broker = StubBroker
else:
broker = RedisBroker
2018-01-01 21:54:03 +01:00
2017-12-16 21:00:46 +01:00
class BaseConfig:
"""Base configuration"""
2019-08-28 13:25:39 +02:00
2017-12-16 21:00:46 +01:00
DEBUG = False
TESTING = False
SQLALCHEMY_TRACK_MODIFICATIONS = False
BCRYPT_LOG_ROUNDS = 13
TOKEN_EXPIRATION_DAYS = 30
TOKEN_EXPIRATION_SECONDS = 0
PASSWORD_TOKEN_EXPIRATION_SECONDS = 3600
UPLOAD_FOLDER = os.path.join(
os.getenv('UPLOAD_FOLDER', current_app.root_path), 'uploads'
)
2018-01-01 21:54:03 +01:00
PICTURE_ALLOWED_EXTENSIONS = {'jpg', 'png', 'gif'}
WORKOUT_ALLOWED_EXTENSIONS = {'gpx', 'zip'}
2021-01-20 16:47:00 +01:00
TEMPLATES_FOLDER = os.path.join(current_app.root_path, 'emails/templates')
UI_URL = os.environ.get('UI_URL')
EMAIL_URL = os.environ.get('EMAIL_URL')
SENDER_EMAIL = os.environ.get('SENDER_EMAIL')
DRAMATIQ_BROKER = broker
TILE_SERVER = {
'URL': os.environ.get(
'TILE_SERVER_URL',
'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
),
'ATTRIBUTION': os.environ.get(
'MAP_ATTRIBUTION',
'&copy; <a href="http://www.openstreetmap.org/copyright" '
'target="_blank" rel="noopener noreferrer">OpenStreetMap</a>'
' contributors',
),
}
2017-12-16 21:00:46 +01:00
class DevelopmentConfig(BaseConfig):
"""Development configuration"""
2019-08-28 13:25:39 +02:00
2017-12-16 21:00:46 +01:00
DEBUG = True
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL')
2017-12-16 21:00:46 +01:00
SECRET_KEY = 'development key'
USERNAME = 'admin'
PASSWORD = 'default'
BCRYPT_LOG_ROUNDS = 4
DRAMATIQ_BROKER_URL = os.getenv('REDIS_URL', 'redis://')
2017-12-16 21:00:46 +01:00
class TestingConfig(BaseConfig):
2018-04-10 21:53:18 +02:00
"""Testing configuration"""
2019-08-28 13:25:39 +02:00
2017-12-16 21:00:46 +01:00
DEBUG = True
2018-04-09 22:09:58 +02:00
TESTING = True
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_TEST_URL')
2017-12-16 21:00:46 +01:00
SECRET_KEY = 'test key'
USERNAME = 'admin'
PASSWORD = 'default'
BCRYPT_LOG_ROUNDS = 4
TOKEN_EXPIRATION_DAYS = 0
TOKEN_EXPIRATION_SECONDS = 3
PASSWORD_TOKEN_EXPIRATION_SECONDS = 3
2020-05-02 10:39:43 +02:00
UPLOAD_FOLDER = '/tmp/fitTrackee/uploads'
2021-07-14 14:28:02 +02:00
UI_URL = 'http://0.0.0.0:5000'
SENDER_EMAIL = 'fittrackee@example.com'
class ProductionConfig(BaseConfig):
"""Production configuration"""
DEBUG = False
# https://docs.sqlalchemy.org/en/13/core/pooling.html#using-connection-pools-with-multiprocessing-or-os-fork # noqa
SQLALCHEMY_ENGINE_OPTIONS = (
{'poolclass': NullPool}
2020-09-19 13:56:14 +02:00
if os.getenv('DATABASE_DISABLE_POOLING', False)
else {}
)
SQLALCHEMY_DATABASE_URI = os.environ.get('DATABASE_URL')
SECRET_KEY = os.getenv('APP_SECRET_KEY')
DRAMATIQ_BROKER_URL = os.getenv('REDIS_URL', 'redis://')