2021-05-29 18:22:51 +02:00
|
|
|
# -*- coding: UTF-8 -*
|
|
|
|
|
|
|
|
|
|
|
|
"""Application Flask: ScoDoc
|
|
|
|
|
|
|
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
|
2021-06-24 10:59:03 +02:00
|
|
|
import os
|
2021-05-29 18:22:51 +02:00
|
|
|
from pprint import pprint as pp
|
2021-05-31 09:57:23 +02:00
|
|
|
import sys
|
2021-05-29 18:22:51 +02:00
|
|
|
|
|
|
|
import click
|
|
|
|
import flask
|
2021-06-24 10:59:03 +02:00
|
|
|
from flask.cli import with_appcontext
|
2021-08-10 12:57:38 +02:00
|
|
|
from app import create_app, cli, db
|
|
|
|
from app import initialize_scodoc_database
|
|
|
|
from app import clear_scodoc_cache
|
2021-06-24 10:59:03 +02:00
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
from app.auth.models import User, Role, UserRole
|
2021-08-07 15:20:30 +02:00
|
|
|
from app import models
|
2021-08-09 11:33:04 +02:00
|
|
|
|
2021-06-14 18:08:52 +02:00
|
|
|
from app.views import notes, scolar, absences
|
2021-07-05 00:07:17 +02:00
|
|
|
import app.utils as utils
|
2021-05-29 18:22:51 +02:00
|
|
|
|
2021-08-09 23:23:11 +02:00
|
|
|
from config import DevConfig
|
2021-05-29 18:22:51 +02:00
|
|
|
|
2021-08-09 23:23:11 +02:00
|
|
|
app = create_app(DevConfig)
|
2021-05-29 18:22:51 +02:00
|
|
|
cli.register(app)
|
|
|
|
|
|
|
|
|
|
|
|
@app.shell_context_processor
|
|
|
|
def make_shell_context():
|
2021-07-25 23:31:59 +03:00
|
|
|
from app.scodoc import notesdb as ndb
|
2021-07-29 11:19:00 +03:00
|
|
|
from app.scodoc import sco_utils as scu
|
2021-08-01 10:52:28 +03:00
|
|
|
from flask_login import login_user, logout_user, current_user
|
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
return {
|
|
|
|
"db": db,
|
|
|
|
"User": User,
|
|
|
|
"Role": Role,
|
|
|
|
"UserRole": UserRole,
|
2021-06-14 18:08:52 +02:00
|
|
|
"notes": notes,
|
|
|
|
"scolar": scolar,
|
2021-07-25 23:31:59 +03:00
|
|
|
"ndb": ndb,
|
2021-07-29 11:19:00 +03:00
|
|
|
"scu": scu,
|
2021-05-29 18:22:51 +02:00
|
|
|
"pp": pp,
|
|
|
|
"flask": flask,
|
|
|
|
"current_app": flask.current_app,
|
2021-08-01 10:52:28 +03:00
|
|
|
"current_user": current_user,
|
|
|
|
"login_user": login_user,
|
|
|
|
"logout_user": logout_user,
|
|
|
|
"ctx": app.test_request_context(),
|
2021-08-07 15:20:30 +02:00
|
|
|
"models": models,
|
2021-05-29 18:22:51 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-08-01 10:52:28 +03:00
|
|
|
# ctx.push()
|
|
|
|
# login_user(admin)
|
|
|
|
|
|
|
|
|
2021-05-29 18:22:51 +02:00
|
|
|
@app.cli.command()
|
2021-08-09 23:23:11 +02:00
|
|
|
def db_init(): # db-init
|
|
|
|
"""Initialize the database.
|
|
|
|
Starts from an existing database and create all
|
|
|
|
the necessary SQL tables and functions.
|
|
|
|
"""
|
|
|
|
initialize_scodoc_database()
|
2021-05-29 18:22:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
2021-05-31 09:57:23 +02:00
|
|
|
def user_db_clear():
|
2021-08-09 23:23:11 +02:00
|
|
|
"""Erase all users and roles from the database !"""
|
2021-05-31 09:57:23 +02:00
|
|
|
click.echo("Erasing the users database !")
|
|
|
|
_clear_users_db()
|
2021-05-29 18:22:51 +02:00
|
|
|
|
|
|
|
|
2021-05-31 09:57:23 +02:00
|
|
|
def _clear_users_db():
|
2021-05-29 18:22:51 +02:00
|
|
|
"""Erase (drop) all tables of users database !"""
|
2021-08-09 23:23:11 +02:00
|
|
|
click.confirm(
|
|
|
|
"This will erase all users and roles.\nAre you sure you want to continue?",
|
|
|
|
abort=True,
|
|
|
|
)
|
2021-05-29 18:22:51 +02:00
|
|
|
db.reflect()
|
2021-08-09 23:23:11 +02:00
|
|
|
try:
|
|
|
|
db.session.query(UserRole).delete()
|
|
|
|
db.session.query(User).delete()
|
|
|
|
db.session.query(User).delete()
|
|
|
|
db.session.commit()
|
|
|
|
except:
|
|
|
|
db.session.rollback()
|
|
|
|
raise
|
2021-05-31 09:57:23 +02:00
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@click.argument("username")
|
|
|
|
@click.argument("role")
|
|
|
|
@click.argument("dept")
|
2021-08-08 09:50:10 +02:00
|
|
|
@click.option("-n", "--nom", "nom")
|
|
|
|
@click.option("-p", "--prenom", "prenom")
|
|
|
|
def user_create(username, role, dept, nom=None, prenom=None): # user-create
|
2021-05-31 09:57:23 +02:00
|
|
|
"Create a new user"
|
|
|
|
r = Role.get_named_role(role)
|
|
|
|
if not r:
|
2021-07-05 21:56:28 +02:00
|
|
|
sys.stderr.write("user_create: role {r} does not exists\n".format(r=role))
|
2021-05-31 09:57:23 +02:00
|
|
|
return 1
|
2021-06-26 21:57:54 +02:00
|
|
|
u = User.query.filter_by(user_name=username).first()
|
2021-05-31 09:57:23 +02:00
|
|
|
if u:
|
2021-07-05 21:56:28 +02:00
|
|
|
sys.stderr.write("user_create: user {u} already exists\n".format(u=u))
|
2021-05-31 09:57:23 +02:00
|
|
|
return 2
|
2021-07-05 21:56:28 +02:00
|
|
|
if dept == "@all":
|
|
|
|
dept = None
|
2021-08-08 09:50:10 +02:00
|
|
|
u = User(user_name=username, dept=dept, nom=nom, prenom=prenom)
|
2021-05-31 09:57:23 +02:00
|
|
|
u.add_role(r, dept)
|
|
|
|
db.session.add(u)
|
|
|
|
db.session.commit()
|
|
|
|
click.echo(
|
2021-06-26 21:57:54 +02:00
|
|
|
"created user, login: {u.user_name}, with role {r} in dept. {dept}".format(
|
2021-05-31 09:57:23 +02:00
|
|
|
u=u, r=r, dept=dept
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@click.argument("username")
|
|
|
|
@click.password_option()
|
2021-07-05 21:56:28 +02:00
|
|
|
def user_password(username, password=None): # user-password
|
2021-05-31 09:57:23 +02:00
|
|
|
"Set (or change) user's password"
|
|
|
|
if not password:
|
|
|
|
sys.stderr.write("user_password: missing password")
|
|
|
|
return 1
|
2021-06-26 21:57:54 +02:00
|
|
|
u = User.query.filter_by(user_name=username).first()
|
2021-05-31 09:57:23 +02:00
|
|
|
if not u:
|
|
|
|
sys.stderr.write("user_password: user {} does not exists".format(username))
|
|
|
|
return 1
|
|
|
|
|
|
|
|
u.set_password(password)
|
|
|
|
db.session.add(u)
|
|
|
|
db.session.commit()
|
|
|
|
click.echo("changed password for user {}".format(u))
|
2021-06-24 10:59:03 +02:00
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@click.argument("dept")
|
2021-07-30 10:36:30 +03:00
|
|
|
def sco_delete_dept(dept): # sco-delete-dept
|
2021-06-24 10:59:03 +02:00
|
|
|
"Delete existing departement"
|
2021-08-09 23:23:11 +02:00
|
|
|
raise NotImplementedError()
|
2021-08-09 08:25:33 +02:00
|
|
|
if os.system('tools/delete_dept.sh -n "{}"'.format(dept)):
|
2021-06-24 10:59:03 +02:00
|
|
|
sys.stderr.write("error deleting dept " + dept)
|
|
|
|
return 1
|
|
|
|
return 0
|
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@click.argument("dept")
|
2021-07-30 10:36:30 +03:00
|
|
|
def sco_create_dept(dept): # sco-create-dept
|
2021-06-24 10:59:03 +02:00
|
|
|
"Create new departement"
|
2021-08-09 23:23:11 +02:00
|
|
|
raise NotImplementedError()
|
2021-08-09 08:25:33 +02:00
|
|
|
if os.system(f'tools/create_dept.sh -n "{dept}"'):
|
2021-07-30 10:36:30 +03:00
|
|
|
sys.stderr.write(f"error creating dept {dept}\n")
|
2021-06-24 10:59:03 +02:00
|
|
|
return 1
|
|
|
|
return 0
|
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@click.argument("filename")
|
|
|
|
@with_appcontext
|
|
|
|
def test_interactive(filename=None):
|
|
|
|
"Run interactive test"
|
|
|
|
import flask_login
|
|
|
|
from app import decorators
|
|
|
|
|
|
|
|
click.echo("Executing {}".format(filename))
|
|
|
|
with app.test_request_context(""):
|
|
|
|
u = User.query.first()
|
|
|
|
flask_login.login_user(u)
|
|
|
|
REQUEST = decorators.ZRequest()
|
|
|
|
exec(open(filename).read())
|
|
|
|
|
|
|
|
click.echo("Done.")
|
2021-07-05 00:07:17 +02:00
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@with_appcontext
|
|
|
|
def user_db_import_scodoc7(): # user-db-import-scodoc7
|
|
|
|
"""Import used defined in ScoDoc7 postgresql database into ScoDoc8
|
|
|
|
The old database SCOUSERS must be alive and readable by the current user.
|
2021-07-27 17:07:03 +03:00
|
|
|
This script is typically run as unix user "scodoc".
|
|
|
|
The original SCOUSERS database is left unmodified.
|
2021-07-05 00:07:17 +02:00
|
|
|
"""
|
|
|
|
utils.import_scodoc7_user_db()
|
2021-07-29 11:30:13 +03:00
|
|
|
|
|
|
|
|
|
|
|
@app.cli.command()
|
|
|
|
@with_appcontext
|
|
|
|
def clear_cache(): # clear-cache
|
|
|
|
"""Clear ScoDoc cache
|
|
|
|
This cache (currently Redis) is persistent between invocation
|
|
|
|
and it may be necessary to clear it during developement or tests.
|
|
|
|
"""
|
2021-08-10 12:57:38 +02:00
|
|
|
clear_scodoc_cache()
|
2021-07-29 11:30:13 +03:00
|
|
|
click.echo("Redis caches flushed.")
|