forked from ScoDoc/ScoDoc
108 lines
3.2 KiB
Python
108 lines
3.2 KiB
Python
##############################################################################
|
|
# ScoDoc
|
|
# Copyright (c) 1999 - 2024 Emmanuel Viennet. All rights reserved.
|
|
# See LICENSE
|
|
##############################################################################
|
|
|
|
"""
|
|
API : billets d'absences
|
|
|
|
CATEGORY
|
|
--------
|
|
Billets d'absence
|
|
|
|
"""
|
|
|
|
from flask import g, request
|
|
from flask_json import as_json
|
|
from flask_login import login_required
|
|
|
|
from app import db
|
|
from app.api import api_bp as bp, api_web_bp
|
|
from app.decorators import scodoc, permission_required
|
|
from app.scodoc.sco_utils import json_error
|
|
from app.models import BilletAbsence
|
|
from app.models.etudiants import Identite
|
|
from app.scodoc import sco_abs_billets
|
|
from app.scodoc.sco_permissions import Permission
|
|
from app.scodoc import sco_utils as scu
|
|
|
|
|
|
@bp.route("/billets_absence/etudiant/<int:etudid>")
|
|
@api_web_bp.route("/billets_absence/etudiant/<int:etudid>")
|
|
@login_required
|
|
@scodoc
|
|
@permission_required(Permission.ScoView)
|
|
@as_json
|
|
def billets_absence_etudiant(etudid: int):
|
|
"""Liste des billets d'absence pour cet étudiant."""
|
|
billets = sco_abs_billets.query_billets_etud(etudid)
|
|
return [billet.to_dict() for billet in billets]
|
|
|
|
|
|
@bp.route("/billets_absence/create", methods=["POST"])
|
|
@api_web_bp.route("/billets_absence/create", methods=["POST"])
|
|
@login_required
|
|
@scodoc
|
|
@permission_required(Permission.AbsAddBillet)
|
|
@as_json
|
|
def billets_absence_create():
|
|
"""Ajout d'un billet d'absence. Renvoie le billet créé en json.
|
|
|
|
DATA
|
|
----
|
|
```json
|
|
{
|
|
"etudid" : int,
|
|
"abs_begin" : date_iso,
|
|
"abs_end" : date_iso,
|
|
"description" : string,
|
|
"justified" : bool
|
|
}
|
|
```
|
|
|
|
SAMPLES
|
|
-------
|
|
/billets_absence/create;{""etudid"":""1"",""abs_begin"":""2023-10-27T10:00"",""abs_end"":""2023-10-28T10:00"",""description"":""grave malade"",""justified"":""1""}
|
|
"""
|
|
data = request.get_json(force=True) # may raise 400 Bad Request
|
|
etudid = data.get("etudid")
|
|
abs_begin = data.get("abs_begin")
|
|
abs_end = data.get("abs_end")
|
|
description = data.get("description", "")
|
|
justified = scu.to_bool(data.get("justified", False))
|
|
if None in (etudid, abs_begin, abs_end):
|
|
return json_error(
|
|
404, message="Paramètre manquant: etudid, abs_begin, abs_end requis"
|
|
)
|
|
etud = Identite.get_etud(etudid)
|
|
billet = BilletAbsence(
|
|
etudid=etud.id,
|
|
abs_begin=abs_begin,
|
|
abs_end=abs_end,
|
|
description=description,
|
|
etat=False,
|
|
justified=justified,
|
|
)
|
|
db.session.add(billet)
|
|
db.session.commit()
|
|
return billet.to_dict()
|
|
|
|
|
|
@bp.route("/billets_absence/<int:billet_id>/delete", methods=["POST"])
|
|
@api_web_bp.route("/billets_absence/<int:billet_id>/delete", methods=["POST"])
|
|
@login_required
|
|
@scodoc
|
|
@permission_required(Permission.AbsAddBillet)
|
|
@as_json
|
|
def billets_absence_delete(billet_id: int):
|
|
"""Suppression d'un billet d'absence"""
|
|
query = BilletAbsence.query.filter_by(id=billet_id)
|
|
if g.scodoc_dept is not None:
|
|
# jointure avec departement de l'étudiant
|
|
query = query.join(BilletAbsence.etudiant).filter_by(dept_id=g.scodoc_dept_id)
|
|
billet = query.first_or_404()
|
|
db.session.delete(billet)
|
|
db.session.commit()
|
|
return {"OK": True}
|