ScoDoc/app/views/__init__.py

42 lines
1.3 KiB
Python
Raw Normal View History

2021-05-29 18:22:51 +02:00
# -*- coding: UTF-8 -*
"""ScoDoc Flask views
"""
import datetime
2021-05-29 18:22:51 +02:00
from flask import Blueprint
2021-08-13 00:34:58 +02:00
from flask import g, current_app
from flask_login import current_user
from app import db
from app.scodoc import notesdb as ndb
2021-05-29 18:22:51 +02:00
2021-07-04 12:32:13 +02:00
scodoc_bp = Blueprint("scodoc", __name__)
scolar_bp = Blueprint("scolar", __name__)
2021-05-29 18:22:51 +02:00
notes_bp = Blueprint("notes", __name__)
users_bp = Blueprint("users", __name__)
absences_bp = Blueprint("absences", __name__)
2021-05-29 18:22:51 +02:00
2021-08-17 22:11:35 +02:00
from app.views import scodoc, notes, scolar, absences, users
2021-08-13 00:34:58 +02:00
# Cette fonction est bien appelée avant toutes les requêtes
# de tous les blueprints
# mais apparemment elle n'a pas acces aux arguments
@scodoc_bp.before_app_request
2021-08-13 00:34:58 +02:00
def start_scodoc_request():
"""Affecte toutes les requêtes, de tous les blueprints"""
# current_app.logger.info(f"start_scodoc_request")
2021-08-13 00:34:58 +02:00
ndb.open_db_connection()
2021-10-16 19:20:36 +02:00
if current_user and current_user.is_authenticated:
current_user.last_seen = datetime.datetime.utcnow()
db.session.commit()
# caches locaux (durée de vie=la requête en cours)
g.stored_get_formsemestre = {}
# g.stored_etud_info = {} optim en cours, voir si utile
@scodoc_bp.teardown_app_request
def close_dept_db_connection(arg):
2021-08-13 00:34:58 +02:00
# current_app.logger.info("close_db_connection")
ndb.close_db_connection()