2021-05-29 18:22:51 +02:00
|
|
|
# -*- coding: UTF-8 -*
|
|
|
|
# pylint: disable=invalid-name
|
|
|
|
|
2021-07-28 08:12:57 +02:00
|
|
|
from app.scodoc.sco_exceptions import ScoValueError
|
2021-05-29 18:22:51 +02:00
|
|
|
import os
|
2021-07-01 18:54:07 +02:00
|
|
|
import sys
|
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
import logging
|
|
|
|
from logging.handlers import SMTPHandler, RotatingFileHandler
|
|
|
|
|
|
|
|
from flask import request
|
|
|
|
from flask import Flask
|
2021-06-25 18:25:46 +02:00
|
|
|
from flask import current_app
|
|
|
|
from flask import g
|
2021-07-28 08:12:57 +02:00
|
|
|
from flask import render_template
|
2021-05-29 18:22:51 +02:00
|
|
|
from flask_sqlalchemy import SQLAlchemy
|
|
|
|
from flask_migrate import Migrate
|
|
|
|
from flask_login import LoginManager
|
|
|
|
from flask_mail import Mail
|
|
|
|
from flask_bootstrap import Bootstrap
|
|
|
|
from flask_moment import Moment
|
2021-07-19 19:53:01 +02:00
|
|
|
from flask_caching import Cache
|
2021-05-29 18:22:51 +02:00
|
|
|
|
|
|
|
from config import Config
|
|
|
|
|
2021-06-25 18:25:46 +02:00
|
|
|
from app.scodoc import notesdb as ndb
|
2021-07-19 19:53:01 +02:00
|
|
|
from app.scodoc import sco_cache
|
2021-06-25 18:25:46 +02:00
|
|
|
|
2021-07-20 17:32:04 +02:00
|
|
|
db = SQLAlchemy()
|
|
|
|
migrate = Migrate()
|
2021-05-29 18:22:51 +02:00
|
|
|
login = LoginManager()
|
|
|
|
login.login_view = "auth.login"
|
|
|
|
login.login_message = "Please log in to access this page."
|
|
|
|
mail = Mail()
|
2021-07-20 17:32:04 +02:00
|
|
|
bootstrap = Bootstrap()
|
2021-05-29 18:22:51 +02:00
|
|
|
moment = Moment()
|
|
|
|
|
2021-07-27 14:33:11 +02:00
|
|
|
cache = Cache( # XXX TODO: configuration file
|
|
|
|
config={
|
|
|
|
# "CACHE_TYPE": "MemcachedCache"
|
|
|
|
"CACHE_TYPE": "RedisCache"
|
|
|
|
}
|
|
|
|
)
|
2021-07-19 19:53:01 +02:00
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
|
2021-07-28 08:12:57 +02:00
|
|
|
def handle_sco_value_error(exc):
|
|
|
|
return render_template("sco_value_error.html", exc=exc), 404
|
|
|
|
|
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
def create_app(config_class=Config):
|
2021-07-20 17:32:04 +02:00
|
|
|
print("create_app")
|
2021-06-16 16:59:31 +02:00
|
|
|
app = Flask(__name__, static_url_path="/ScoDoc/static", static_folder="static")
|
|
|
|
app.logger.setLevel(logging.DEBUG)
|
2021-05-29 18:22:51 +02:00
|
|
|
app.config.from_object(config_class)
|
|
|
|
db.init_app(app)
|
|
|
|
migrate.init_app(app, db)
|
|
|
|
login.init_app(app)
|
|
|
|
mail.init_app(app)
|
|
|
|
bootstrap.init_app(app)
|
|
|
|
moment.init_app(app)
|
2021-07-19 19:53:01 +02:00
|
|
|
cache.init_app(app)
|
|
|
|
sco_cache.CACHE = cache
|
2021-05-29 18:22:51 +02:00
|
|
|
|
2021-07-28 08:12:57 +02:00
|
|
|
app.register_error_handler(ScoValueError, handle_sco_value_error)
|
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
from app.auth import bp as auth_bp
|
|
|
|
|
|
|
|
app.register_blueprint(auth_bp, url_prefix="/auth")
|
|
|
|
|
2021-05-31 00:14:15 +02:00
|
|
|
from app.views import essais_bp
|
|
|
|
|
|
|
|
app.register_blueprint(essais_bp, url_prefix="/Essais")
|
|
|
|
|
2021-07-04 12:32:13 +02:00
|
|
|
from app.main import bp as main_bp
|
|
|
|
from app.views import scodoc_bp
|
2021-05-31 00:14:15 +02:00
|
|
|
from app.views import scolar_bp
|
2021-05-29 18:22:51 +02:00
|
|
|
from app.views import notes_bp
|
2021-06-26 21:57:54 +02:00
|
|
|
from app.views import users_bp
|
2021-05-31 00:14:15 +02:00
|
|
|
from app.views import absences_bp
|
2021-05-29 18:22:51 +02:00
|
|
|
|
2021-07-04 12:32:13 +02:00
|
|
|
app.register_blueprint(main_bp) # XXX à enlever en production #sco8
|
|
|
|
# https://scodoc.fr/ScoDoc
|
|
|
|
app.register_blueprint(scodoc_bp)
|
2021-05-31 00:14:15 +02:00
|
|
|
# https://scodoc.fr/ScoDoc/RT/Scolarite/...
|
|
|
|
app.register_blueprint(scolar_bp, url_prefix="/ScoDoc/<scodoc_dept>/Scolarite")
|
|
|
|
# https://scodoc.fr/ScoDoc/RT/Scolarite/Notes/...
|
|
|
|
app.register_blueprint(notes_bp, url_prefix="/ScoDoc/<scodoc_dept>/Scolarite/Notes")
|
2021-06-26 21:57:54 +02:00
|
|
|
# https://scodoc.fr/ScoDoc/RT/Scolarite/Users/...
|
|
|
|
app.register_blueprint(users_bp, url_prefix="/ScoDoc/<scodoc_dept>/Scolarite/Users")
|
2021-05-31 00:14:15 +02:00
|
|
|
# https://scodoc.fr/ScoDoc/RT/Scolarite/Absences/...
|
|
|
|
app.register_blueprint(
|
|
|
|
absences_bp, url_prefix="/ScoDoc/<scodoc_dept>/Scolarite/Absences"
|
|
|
|
)
|
2021-05-29 18:22:51 +02:00
|
|
|
|
|
|
|
if not app.debug and not app.testing:
|
|
|
|
if app.config["MAIL_SERVER"]:
|
|
|
|
auth = None
|
|
|
|
if app.config["MAIL_USERNAME"] or app.config["MAIL_PASSWORD"]:
|
|
|
|
auth = (app.config["MAIL_USERNAME"], app.config["MAIL_PASSWORD"])
|
|
|
|
secure = None
|
|
|
|
if app.config["MAIL_USE_TLS"]:
|
|
|
|
secure = ()
|
|
|
|
mail_handler = SMTPHandler(
|
|
|
|
mailhost=(app.config["MAIL_SERVER"], app.config["MAIL_PORT"]),
|
|
|
|
fromaddr="no-reply@" + app.config["MAIL_SERVER"],
|
|
|
|
toaddrs=[app.config["ADMINS"]],
|
|
|
|
subject="ScoDoc8 Failure",
|
|
|
|
credentials=auth,
|
|
|
|
secure=secure,
|
|
|
|
)
|
|
|
|
mail_handler.setLevel(logging.ERROR)
|
|
|
|
app.logger.addHandler(mail_handler)
|
|
|
|
|
|
|
|
if not os.path.exists("logs"):
|
|
|
|
os.mkdir("logs")
|
|
|
|
file_handler = RotatingFileHandler(
|
|
|
|
"logs/scodoc.log", maxBytes=10240, backupCount=10
|
|
|
|
)
|
|
|
|
file_handler.setFormatter(
|
|
|
|
logging.Formatter(
|
|
|
|
"%(asctime)s %(levelname)s: %(message)s " "[in %(pathname)s:%(lineno)d]"
|
|
|
|
)
|
|
|
|
)
|
|
|
|
file_handler.setLevel(logging.INFO)
|
|
|
|
app.logger.addHandler(file_handler)
|
|
|
|
|
|
|
|
app.logger.setLevel(logging.INFO)
|
|
|
|
app.logger.info("ScoDoc8 startup")
|
|
|
|
|
|
|
|
return app
|