-
Notifications
You must be signed in to change notification settings - Fork 0
/
__init__.py
46 lines (32 loc) · 1.11 KB
/
__init__.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
import logging
import os
import flask
from flask import Flask
from app import extensions
from app.blueprints import blueprints
from app.middleware import Middleware
def create_app(env_config: str) -> Flask:
app = flask.Flask(__name__)
app.config.from_object(env_config)
app.wsgi_app = Middleware(app)
init_logging(app)
init_app(app)
register_blueprints(app)
return app
def init_app(app: Flask) -> None:
"""Call the method 'init_app' to register the extensions in the flask.Flask
object passed as parameter."""
extensions.init_app(app)
def register_blueprints(app: Flask) -> None:
for blueprint in blueprints:
app.register_blueprint(blueprint)
def init_logging(app: Flask) -> None:
log_basename = os.path.basename(app.config.get('ROOT_DIRECTORY'))
log_dirname = '{}/app'.format(app.config.get('LOG_DIRECTORY'))
log_filename = f'{log_dirname}/{log_basename}.log'
config = {
'format': '%(asctime)s - %(levelname)s - %(name)s - %(message)s',
'level': logging.DEBUG,
'filename': log_filename,
}
logging.basicConfig(**config)