2021-09-15 12:31:53 +02:00
|
|
|
from dotenv import load_dotenv
|
2022-02-15 09:25:34 +01:00
|
|
|
from flask import Flask
|
2021-09-15 17:58:17 +02:00
|
|
|
from logging.handlers import RotatingFileHandler
|
2020-05-27 12:52:41 +02:00
|
|
|
from werkzeug.middleware.proxy_fix import ProxyFix
|
2019-09-11 14:50:29 +02:00
|
|
|
import logging
|
2020-10-08 12:34:02 +02:00
|
|
|
import os
|
2019-07-03 10:31:23 +02:00
|
|
|
|
|
|
|
|
2021-09-15 12:31:53 +02:00
|
|
|
basedir = os.path.abspath(os.path.dirname(__file__))
|
|
|
|
load_dotenv(os.path.join(basedir, '.env'))
|
2019-09-05 10:12:40 +02:00
|
|
|
|
2020-05-27 11:03:50 +02:00
|
|
|
|
2020-10-08 12:34:02 +02:00
|
|
|
class Config:
|
2020-11-13 10:01:51 +01:00
|
|
|
''' # Flask # '''
|
2020-11-19 12:30:13 +01:00
|
|
|
PREFERRED_URL_SCHEME = os.environ.get('PREFERRED_URL_SCHEME', 'http')
|
2020-11-13 10:01:51 +01:00
|
|
|
SECRET_KEY = os.environ.get('SECRET_KEY', 'hard to guess string')
|
2020-11-19 12:30:13 +01:00
|
|
|
SERVER_NAME = os.environ.get('SERVER_NAME')
|
2020-11-13 10:01:51 +01:00
|
|
|
SESSION_COOKIE_SECURE = \
|
|
|
|
os.environ.get('SESSION_COOKIE_SECURE', 'false').lower() == 'true'
|
2021-11-15 14:34:07 +01:00
|
|
|
TEMPLATES_AUTO_RELOAD = \
|
|
|
|
os.environ.get('TEMPLATES_AUTO_RELOAD', 'false').lower() == 'true'
|
2020-10-21 13:07:10 +02:00
|
|
|
|
2021-12-08 11:25:33 +01:00
|
|
|
''' # Flask-Hashids '''
|
|
|
|
HASHIDS_MIN_LENGTH = 32
|
|
|
|
|
2020-11-13 10:01:51 +01:00
|
|
|
''' # Flask-Login # '''
|
|
|
|
REMEMBER_COOKIE_HTTPONLY = True
|
|
|
|
REMEMBER_COOKIE_SECURE = \
|
|
|
|
os.environ.get('REMEMBER_COOKIE_SECURE', 'false').lower() == 'true'
|
|
|
|
|
|
|
|
''' # Flask-Mail # '''
|
|
|
|
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER')
|
|
|
|
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD')
|
|
|
|
MAIL_PORT = int(os.environ.get('MAIL_PORT'))
|
|
|
|
MAIL_SERVER = os.environ.get('MAIL_SERVER')
|
|
|
|
MAIL_USERNAME = os.environ.get('MAIL_USERNAME')
|
|
|
|
MAIL_USE_SSL = os.environ.get('MAIL_USE_SSL', 'false').lower() == 'true'
|
|
|
|
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS', 'false').lower() == 'true'
|
|
|
|
|
|
|
|
''' # Flask-SQLAlchemy # '''
|
2021-09-15 12:31:53 +02:00
|
|
|
SQLALCHEMY_DATABASE_URI = os.environ.get(
|
|
|
|
'SQLALCHEMY_DATABASE_URI',
|
|
|
|
'sqlite:///' + os.path.join(basedir, 'app.db')
|
|
|
|
)
|
2020-10-08 12:34:02 +02:00
|
|
|
SQLALCHEMY_RECORD_QUERIES = True
|
|
|
|
SQLALCHEMY_TRACK_MODIFICATIONS = False
|
2020-06-17 09:26:37 +02:00
|
|
|
|
2020-11-13 10:01:51 +01:00
|
|
|
''' # nopaque # '''
|
|
|
|
NOPAQUE_ADMIN = os.environ.get('NOPAQUE_ADMIN')
|
2021-09-22 13:53:39 +02:00
|
|
|
NOPAQUE_DAEMON_ENABLED = \
|
|
|
|
os.environ.get('NOPAQUE_DAEMON_ENABLED', 'true').lower() == 'true'
|
2022-02-08 15:39:15 +01:00
|
|
|
NOPAQUE_DATA_DIR = \
|
|
|
|
os.path.abspath(os.environ.get('NOPAQUE_DATA_DIR', '/mnt/nopaque'))
|
2021-11-15 14:34:07 +01:00
|
|
|
NOPAQUE_DOCKER_REGISTRY = 'gitlab.ub.uni-bielefeld.de:4567'
|
|
|
|
NOPAQUE_DOCKER_IMAGE_PREFIX = f'{NOPAQUE_DOCKER_REGISTRY}/sfb1288inf/'
|
|
|
|
NOPAQUE_DOCKER_REGISTRY_USERNAME = \
|
|
|
|
os.environ.get('NOPAQUE_DOCKER_REGISTRY_USERNAME')
|
|
|
|
NOPAQUE_DOCKER_REGISTRY_PASSWORD = \
|
|
|
|
os.environ.get('NOPAQUE_DOCKER_REGISTRY_PASSWORD')
|
2020-11-13 10:01:51 +01:00
|
|
|
NOPAQUE_MAIL_SUBJECT_PREFIX = '[nopaque]'
|
2021-11-18 12:09:15 +01:00
|
|
|
NOPAQUE_SERVICE_DESK = 'gitlab-ub-incoming+sfb1288inf-nopaque-1324-issue-@jura.uni-bielefeld.de' # noqa
|
2020-11-13 10:01:51 +01:00
|
|
|
NOPAQUE_SOCKETIO_MESSAGE_QUEUE_URI = \
|
|
|
|
os.environ.get('NOPAQUE_SOCKETIO_MESSAGE_QUEUE_URI')
|
2020-10-21 13:07:10 +02:00
|
|
|
|
2021-09-16 11:04:47 +02:00
|
|
|
NOPAQUE_LOG_DATE_FORMAT = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_DATE_FORMAT', '%Y-%m-%d %H:%M:%S')
|
2021-09-15 17:58:17 +02:00
|
|
|
NOPAQUE_LOG_FORMAT = os.environ.get(
|
|
|
|
'NOPAQUE_LOG_DATE_FORMAT',
|
|
|
|
'[%(asctime)s] %(levelname)s in '
|
|
|
|
'%(pathname)s (function: %(funcName)s, line: %(lineno)d): %(message)s'
|
|
|
|
)
|
|
|
|
NOPAQUE_LOG_LEVEL = os.environ.get('NOPAQUE_LOG_LEVEL', 'INFO')
|
2021-09-16 11:04:47 +02:00
|
|
|
NOPAQUE_LOG_FILE_ENABLED = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_FILE_ENABLED', 'true').lower() == 'true'
|
|
|
|
NOPAQUE_LOG_FILE_DIR = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_FILE_DIR', os.path.join(basedir, 'logs'))
|
|
|
|
NOPAQUE_LOG_FILE_LEVEL = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_FILE_LEVEL', NOPAQUE_LOG_LEVEL)
|
|
|
|
NOPAQUE_LOG_STDERR_ENABLED = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_STDERR_ENABLED', 'false').lower() == 'true'
|
|
|
|
NOPAQUE_LOG_STDERR_LEVEL = \
|
|
|
|
os.environ.get('NOPAQUE_LOG_STDERR_LEVEL', NOPAQUE_LOG_LEVEL)
|
2021-09-15 17:58:17 +02:00
|
|
|
|
|
|
|
NOPAQUE_PROXY_FIX_X_FOR = \
|
|
|
|
int(os.environ.get('NOPAQUE_PROXY_FIX_X_FOR', '0'))
|
|
|
|
NOPAQUE_PROXY_FIX_X_HOST = \
|
|
|
|
int(os.environ.get('NOPAQUE_PROXY_FIX_X_HOST', '0'))
|
|
|
|
NOPAQUE_PROXY_FIX_X_PORT = \
|
|
|
|
int(os.environ.get('NOPAQUE_PROXY_FIX_X_PORT', '0'))
|
|
|
|
NOPAQUE_PROXY_FIX_X_PREFIX = \
|
|
|
|
int(os.environ.get('NOPAQUE_PROXY_FIX_X_PREFIX', '0'))
|
|
|
|
NOPAQUE_PROXY_FIX_X_PROTO = \
|
|
|
|
int(os.environ.get('NOPAQUE_PROXY_FIX_X_PROTO', '0'))
|
|
|
|
|
2022-04-04 13:31:09 +02:00
|
|
|
NOPAQUE_TRANSKRIBUS_ENABLED = \
|
|
|
|
os.environ.get('NOPAQUE_TRANSKRIBUS_ENABLED', 'true').lower() == 'true'
|
|
|
|
NOPAQUE_READCOOP_USERNAME = os.environ.get('NOPAQUE_READCOOP_USERNAME')
|
|
|
|
NOPAQUE_READCOOP_PASSWORD = os.environ.get('NOPAQUE_READCOOP_PASSWORD')
|
|
|
|
|
2020-10-21 13:07:10 +02:00
|
|
|
@classmethod
|
2022-02-15 09:25:34 +01:00
|
|
|
def init_app(cls, app: Flask):
|
2020-11-13 10:01:51 +01:00
|
|
|
# Set up logging according to the corresponding (NOPAQUE_LOG_*)
|
2021-09-15 17:58:17 +02:00
|
|
|
# configurations
|
2021-09-16 11:04:47 +02:00
|
|
|
app.logger.setLevel(app.config.get('NOPAQUE_LOG_LEVEL'))
|
|
|
|
# Remove existing handlers
|
2021-09-15 17:58:17 +02:00
|
|
|
for handler in app.logger.handlers:
|
|
|
|
app.logger.removeHandler(handler)
|
2021-09-16 11:04:47 +02:00
|
|
|
# Setup handlers
|
2021-09-15 17:58:17 +02:00
|
|
|
formatter = logging.Formatter(
|
|
|
|
fmt=app.config.get('NOPAQUE_LOG_FORMAT'),
|
|
|
|
datefmt=app.config.get('NOPAQUE_LOG_DATE_FORMAT')
|
|
|
|
)
|
2021-09-16 11:04:47 +02:00
|
|
|
if app.config.get('NOPAQUE_LOG_STDERR_ENABLED'):
|
2021-09-15 17:58:17 +02:00
|
|
|
stream_handler = logging.StreamHandler()
|
|
|
|
stream_handler.setFormatter(formatter)
|
2021-09-16 11:04:47 +02:00
|
|
|
stream_handler.setLevel(app.config.get('NOPAQUE_LOG_STDERR_LEVEL'))
|
2021-09-15 17:58:17 +02:00
|
|
|
app.logger.addHandler(stream_handler)
|
2021-09-16 11:04:47 +02:00
|
|
|
if app.config.get('NOPAQUE_LOG_FILE_ENABLED'):
|
|
|
|
if not os.path.exists(app.config.get('NOPAQUE_LOG_FILE_DIR')):
|
|
|
|
os.mkdir(app.config.get('NOPAQUE_LOG_FILE_DIR'))
|
2021-09-15 17:58:17 +02:00
|
|
|
rotating_file_handler = RotatingFileHandler(
|
2021-09-16 11:04:47 +02:00
|
|
|
os.path.join(app.config.get('NOPAQUE_LOG_FILE_DIR'), 'nopaque.log'), # noqa
|
2021-09-15 17:58:17 +02:00
|
|
|
maxBytes=10240,
|
|
|
|
backupCount=10
|
|
|
|
)
|
|
|
|
rotating_file_handler.setFormatter(formatter)
|
2021-09-16 11:04:47 +02:00
|
|
|
rotating_file_handler.setLevel(app.config.get('NOPAQUE_LOG_FILE_LEVEL')) # noqa
|
2021-09-15 17:58:17 +02:00
|
|
|
app.logger.addHandler(rotating_file_handler)
|
|
|
|
|
2020-10-21 13:07:10 +02:00
|
|
|
# Set up and apply the ProxyFix middleware according to the
|
2021-09-15 17:58:17 +02:00
|
|
|
# corresponding (NOPAQUE_PROXY_FIX_*) configurations
|
|
|
|
app.wsgi_app = ProxyFix(
|
|
|
|
app.wsgi_app,
|
|
|
|
x_for=app.config.get('NOPAQUE_PROXY_FIX_X_FOR'),
|
|
|
|
x_host=app.config.get('NOPAQUE_PROXY_FIX_X_HOST'),
|
|
|
|
x_port=app.config.get('NOPAQUE_PROXY_FIX_X_PORT'),
|
|
|
|
x_prefix=app.config.get('NOPAQUE_PROXY_FIX_X_PREFIX'),
|
|
|
|
x_proto=app.config.get('NOPAQUE_PROXY_FIX_X_PROTO')
|
|
|
|
)
|