nopaque/config.py

95 lines
3.2 KiB
Python
Raw Normal View History

2019-07-03 10:31:23 +02:00
import os
2019-09-11 14:50:29 +02:00
import logging
2019-07-03 10:31:23 +02:00
class Config:
2019-09-05 10:12:40 +02:00
''' ### Flask ### '''
SECRET_KEY = os.environ.get('SECRET_KEY') or 'hard to guess string'
''' ### Flask-Mail ### '''
2019-08-26 09:57:26 +02:00
MAIL_SERVER = os.environ.get('MAIL_SERVER')
MAIL_PORT = int(os.environ.get('MAIL_PORT'))
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS').lower() == 'true'
2019-07-08 11:29:11 +02:00
MAIL_USERNAME = os.environ.get('MAIL_USERNAME')
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD')
2019-09-05 10:12:40 +02:00
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER')
''' ### Flask-SQLAlchemy ### '''
SQLALCHEMY_TRACK_MODIFICATIONS = False
2019-07-03 15:40:09 +02:00
2019-09-05 10:12:40 +02:00
''' ### Opaque ### '''
OPAQUE_ADMIN = os.environ.get('OPAQUE_ADMIN')
2019-09-09 15:21:29 +02:00
OPAQUE_STORAGE_DIRECTORY = '/mnt/opaque'
2019-09-05 10:12:40 +02:00
2019-07-03 15:40:09 +02:00
@staticmethod
def init_app(app):
pass
class DevelopmentConfig(Config):
2019-09-05 10:12:40 +02:00
''' ### Flask ### '''
2019-07-03 15:40:09 +02:00
DEBUG = True
2019-09-05 10:12:40 +02:00
''' ### Flask-SQLAlchemy ### '''
2019-09-24 16:16:55 +02:00
SQLALCHEMY_ENGINE_OPTIONS = {'pool_size': 30,
'pool_timeout': 30}
2019-09-06 13:42:47 +02:00
SQLALCHEMY_DATABASE_URI = 'postgresql://{}:{}@db/{}'.format(
2019-09-05 16:39:50 +02:00
os.environ.get('POSTGRES_USER'),
os.environ.get('POSTGRES_PASSWORD'),
os.environ.get('POSTGRES_DB_NAME')
2019-09-05 10:12:40 +02:00
)
2019-09-12 11:35:23 +02:00
if not os.path.isfile('logs/opaque_web.log'):
file_path = os.path.join(os.getcwd(), 'logs/opaque_web.log')
log = open(file_path, 'w+')
log.close()
2019-09-12 16:44:53 +02:00
if os.environ.get('FLASK_CONFIG') == 'development':
log_format = ("%(asctime)s - %(levelname)s - %(name)s - "
"%(filename)s - %(lineno)d - %(message)s")
logging.basicConfig(filename='logs/opaque_web.log', level='WARNING',
format=log_format, datefmt='%Y-%m-%d %H:%M:%S',
filemode='w')
logger = logging.getLogger(__name__)
logger.warning('Logging has started with level WARNING.'
' From development config.')
2019-07-03 15:40:09 +02:00
class TestingConfig(Config):
2019-09-05 16:39:50 +02:00
''' ### Flask ### '''
TESTING = True
''' ### Flask-SQLAlchemy ### '''
SQLALCHEMY_DATABASE_URI = 'sqlite://'
2019-09-05 16:39:50 +02:00
''' ### Flask-WTF ### '''
WTF_CSRF_ENABLED = False
2019-09-05 10:12:40 +02:00
class ProductionConfig(Config):
''' ### Flask-SQLAlchemy ### '''
2019-09-06 13:42:47 +02:00
SQLALCHEMY_DATABASE_URI = 'postgresql://{}:{}@db/{}'.format(
2019-09-05 16:39:50 +02:00
os.environ.get('POSTGRES_USER'),
os.environ.get('POSTGRES_PASSWORD'),
os.environ.get('POSTGRES_DB_NAME')
)
if not os.path.isfile('logs/opaque_web.log'):
file_path = os.path.join(os.getcwd(), 'logs/opaque_web.log')
log = open(file_path, 'w+')
log.close()
2019-09-12 16:44:53 +02:00
if os.environ.get('FLASK_CONFIG') == 'production':
log_format = ("%(asctime)s - %(levelname)s - %(name)s - "
"%(filename)s - %(lineno)d - %(message)s")
logging.basicConfig(filename='logs/opaque_web.log', level='ERROR',
format=log_format, datefmt='%Y-%m-%d %H:%M:%S',
filemode='w')
logger = logging.getLogger(__name__)
logger.error('Logging has started with level ERROR.'
' From production config.')
2019-07-03 15:40:09 +02:00
config = {
'development': DevelopmentConfig,
2019-07-08 10:52:36 +02:00
'testing': TestingConfig,
2019-09-05 10:12:40 +02:00
'production': ProductionConfig,
2019-07-03 15:40:09 +02:00
'default': DevelopmentConfig
}