-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathconfig.py
137 lines (110 loc) · 5.01 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
import os
from app.lemmatizers import LemmatizerService
from typing import List
basedir = os.path.abspath(os.path.dirname(__file__))
class Config:
APP_NAME = 'Pyrrha'
if os.environ.get('SECRET_KEY'):
SECRET_KEY = os.environ.get('SECRET_KEY')
else:
SECRET_KEY = 'SECRET_KEY_ENV_VAR_NOT_SET'
print('SECRET KEY ENV VAR NOT SET! SHOULD NOT SEE IN PRODUCTION')
# SQLALCHEMY_COMMIT_ON_TEARDOWN = True
# Deprecated
SQLALCHEMY_COMMIT_ON_TEARDOWN = False
template_folder = os.path.join(basedir, "app", "templates")
static_folder = os.path.join(basedir, "app", "statics")
# SQLALCHEMY_ECHO = True
# Email
MAIL_SERVER = os.environ.get('MAIL_SERVER')
MAIL_PORT = 587
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS') or True
MAIL_USE_SSL = os.environ.get('MAIL_USE_SSL') or False
MAIL_USERNAME = os.environ.get('MAIL_USERNAME')
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD')
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER')
SEND_MAIL_STATUS = os.environ.get('SEND_MAIL_STATUS', True)
# Admin account
ADMIN_PASSWORD = os.environ.get('ADMIN_PASSWORD') or 'admin'
ADMIN_EMAIL = os.environ.get('ADMIN_EMAIL') or '[email protected]'
EMAIL_SUBJECT_PREFIX = '[{}]'.format(APP_NAME)
EMAIL_SENDER = '{app_name} Admin <{email}>'.format(app_name=APP_NAME, email=MAIL_USERNAME)
# Defaults
PAGINATION_DEFAULT_TOKENS = 100
# Lemmatizer (until Deucalion client)
LEMMATIZERS: List[LemmatizerService] = []
# Change automatically the Postgresql instance language if not english
FORCE_PSQL_EN_LOCALE = True
@staticmethod
def init_app(app):
pass
class DevelopmentConfig(Config):
DEBUG = True
ASSETS_DEBUG = True
SQLALCHEMY_DATABASE_URI = os.environ.get('DEV_DATABASE_URL') or \
"postgresql://user:pwd@localhost:5432/data-dev"
print('THIS APP IS IN DEBUG MODE. YOU SHOULD NOT SEE THIS IN PRODUCTION.')
# Email
MAIL_SERVER = 'smtp.mailgun.org'
MAIL_PORT = 465
MAIL_USE_TLS = False
MAIL_USE_SSL = True
MAIL_USERNAME = '[email protected]'
MAIL_PASSWORD = 'c3c7cc3c785815a8728a6266745a70db-b6183ad4-c78d7487'
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER')
ADMIN_PASSWORD = os.environ.get('ADMIN_PASSWORD') or 'admin'
ADMIN_EMAIL = os.environ.get('ADMIN_EMAIL') or '[email protected]'
EMAIL_SUBJECT_PREFIX = '[{}]'.format(Config.APP_NAME)
SEND_MAIL_STATUS = os.environ.get('SEND_MAIL_STATUS', False)
EMAIL_SENDER = '{app_name} Admin <{email}>'.format(app_name=Config.APP_NAME, email=MAIL_USERNAME)
LEMMATIZERS = [
("Ancien Français", "http://localhost:5001/")
]
BABEL_TRANSLATION_DIRECTORIES = os.path.join(os.path.dirname(__file__), "translations")
class BaseTestConfig(Config):
"""Test configuration base class."""
DEBUG = True
ASSETS_DEBUG = True
print('THIS APP IS IN DEBUG MODE. YOU SHOULD NOT SEE THIS IN PRODUCTION.')
# Disable CSRF for login purpose
WTF_CSRF_ENABLED = False
# Email
MAIL_SERVER = os.environ.get('MAIL_SERVER') or 'smtp.mailgun.org'
MAIL_PORT = 465
MAIL_USE_TLS = os.environ.get('MAIL_USE_TLS') or False
MAIL_USE_SSL = os.environ.get('MAIL_USE_SSL') or True
MAIL_USERNAME = os.environ.get('MAIL_USERNAME') or '[email protected]'
MAIL_PASSWORD = os.environ.get('MAIL_PASSWORD') or 'c3c7cc3c785815a8728a6266745a70db-b6183ad4-c78d7487'
MAIL_DEFAULT_SENDER = os.environ.get('MAIL_DEFAULT_SENDER')
SEND_MAIL_STATUS = os.environ.get('SEND_MAIL_STATUS', False)
ADMIN_PASSWORD = os.environ.get('ADMIN_PASSWORD') or 'admin'
ADMIN_EMAIL = os.environ.get('ADMIN_EMAIL') or '[email protected]'
EMAIL_SUBJECT_PREFIX = '[{}]'.format(Config.APP_NAME)
EMAIL_SENDER = '{app_name} Admin <{email}>'.format(app_name=Config.APP_NAME, email=MAIL_USERNAME)
LEMMATIZERS = [
LemmatizerService(
"Dummy lemmatizer",
"http://localhost:4567/lemma",
provider="ProviderInstitution",
ui="someui.com",
apa="Clérice et al. 2019",
bibtex="""@article{camps2021corpus,
title = {Corpus and Models for Lemmatisation and POS-tagging of Old French},
author = {Camps, Jean-Baptiste and Cl{\'e}rice, Thibault and Duval, Fr{\'e}d{\'e}ric and Kanaoka, Naomi and Pinche, Ariane and others},
year = 2021,
journal = {arXiv preprint arXiv:2109.11442},
keywords = {Old French}
}"""
)
]
class SQLiteTestConfig(BaseTestConfig):
SQLALCHEMY_DATABASE_URI = os.environ.get('TEST_DATABASE_URL') or \
'sqlite:///' + os.path.join(basedir, 'data-test.sqlite')
class PostgreSQLTestConfig(BaseTestConfig):
SQLALCHEMY_DATABASE_URI = os.environ.get('TEST_DATABASE_URL') or \
'postgresql:///data-test'
config = {
"dev": DevelopmentConfig,
"prod": Config,
"test": PostgreSQLTestConfig if os.environ.get("TEST_DBMS", "sqlite").lower() == "postgresql" else SQLiteTestConfig
}