# Document expérimental sur les données du module Assiduité de ScoDoc Dans ce document je (Matthias Hartmann) détaillerais plusieurs méthodes pour enregistrer les données du module Assiduité et les utiliser. Je mettrai à jour ce document et je l'utiliserai lors de l'implémentation du cahier des charges. > Pour la suite du document je nomme `plage` l'objet représentant une absence/présence sur une période donnée. Dans les diagrammes: > - les noms précédés par `?` sont des valeurs optionnelles. > - les noms précédés par `#` sont des clés externes. > - les noms précédés par `$` sont des clés primaires. ___ > dev note *(11/10/22)*: Les types des données ne sont pas forcément les bons, je n'ai pas encore regardé comment était organisée la BDD de ScoDoc ## Représentation d'une assiduité et d'un justificatif > voir l'API ScoDoc -> [ScoDoc9 API](ScoDoc9API.md#api-assiduite) ## Représentation des données (Version 4) ```mermaid classDiagram class assiduites{ $assiduiteid : Integer #etuid : Integer date_debut : DateTime date_fin : DateTime, etat : String #module?: Integer } class justificatifs{ $justifid : Integer #etuid : Integer date_debut : DateTime date_fin : DateTime fichier? : Integer raison? : String #etat : Integer DEFAULT=0 } class etat_justificatif{ $etat_id : Integer desc : String } justificatifs --> etat_justificatif ``` ### Explications de la représentation > - Dans cette version, les objets en base de données suivent la représentation fait en json (dans l'API) > - Le fichier justificatif est toujours stocker sur le serveur et en base il est stocker sous la forme d'un identifiant unique. > - le champs `etat` de la table `justificatif` est une clé étrangère vers la table `etat_justificatif` qui contient les différents états (attente, validé, modifié, en cours . . . ), Cette table permettra aux utilisateurs d'ajouter eux même des états en fonction de leurs besoins. (deux états seront obligatoires : 0[Non Validé] 1[Validé] mais leurs noms pourront être changés.) ## Représentation des données (Version 3) ```mermaid classDiagram class plage{ plage_id : Integer date_debut : DateTime date_fin : DateTime #etuid : Integer type : String ? #module_id : Integer ? #enseignant_id : Integer } class justificatif{ $#etuid : Integer $date_debut : DateTime $date_fin : DateTime attachement : String #etat : Integer DEFAULT=0 } class etat_justificatif{ $etat_id : Integer desc : String } justificatif --> etat_justificatif ``` ### Explications de la représentation > - Dans cette représentation, une plage est complètement dissociée d'une formation / département. Elle repose uniquement sur un étudiant en particulier. On peut néanmoins spécifier l'enseignant et le module concerné par l'absence dans le but de produire des statistiques. > - Du coté des justificatifs, on a désormais un attribut `etat` plutôt qu'un booléen. Cet attribut est une clé étrangère lié à la table `etat_justificatif`. Cela permet alors d'avoir plusieurs états (Validé, Refusé, En Attente, Incomplet...) l'état `0` étant `Pas encore étudié` par exemple. ### Problèmes de la représentation > - On utilise une nouvelle table pour stocker les différents états. A moins que cette table ne puisse être modifiée par les administrateurs de ScoDoc (ajouter des états pour des cas précis par IUT), on créer une table pour enregistrer des données statiques. ### Améliorations potentielles > - A la place d'une table dans la BDD, on pourrait directement hard coder les états de justificatifs. Les états seront plus simple à accéder mais on perd l'aspect modification au cas par cas. ## Représentation des données (Version 2) ```mermaid classDiagram class plage{ id_plage : Integer date_debut : DateTime date_fin : DateTime #id_dept : Integer #formsemestre_id : Integer #etuid : Integer type : String ? #id_module : Integer ? #id_enseignant : Integer } class justificatif{ $#etuid : Integer $date_debut : DateTime $date_fin : DateTime attachement : String valide : bool DEFAULT=False } ``` ### Problèmes liés à la représentation > - L'export de la base de donnée avec les justificatif devient plus complexe (car on doit aller chercher les fichiers du dossier justificatifs) > - Même problème que la version 1 pour les requêtes ## Représentation des données ( Version 1) ```mermaid classDiagram class plage{ id_plage : Integer date_debut : DateTime date_fin : DateTime #id_dept : Integer #formsemestre_id : Integer #etuid : Integer type : String ? #id_module : Integer ? #id_enseignant : Integer } class justificatif{ #$id_plage : Integer attachement : Blob valide : bool DEFAULT=False } ``` ### Problèmes liés à la représentation > - Quasiment l'ensemble des données sont stockées dans un même tuple\ > __Conséquence__ : chaque requête utilisant les données sera longue et lourde pour le gestionnaire de BDD > - Le stockage sour la forme de blob est très lourd pour la bdd ( cf : [Benchmark des différentes méthode de stockage de fichier binaire sur progresql](https://www.cybertec-postgresql.com/en/binary-data-performance-in-postgresql/) ) > - Un justificatif doit être donné pour chaque absence (par exemple un arrêt maladie de plusieurs jours est présent dans la base autant de fois que l'étudiant a été absence à un cours ) ### Avantages liés à la représentation > - Peu ou pas de jointure à faire > - Ensemble des données facilement accessibles > - Une absence (`plage: type=absence`) est justifiée si un justificatif (`justificatifs : idPlage={idAbsence}`) est présent dans la base. Une absence peut être justifiée(par un étudiant par exemple) mais pas forcément validé par le corps enseignant / administratif. (`justificatifs : valide=Faux`) > - l'objet justificatif permet de stocker un fichier / un texte servant de justification (`justificatifs : attachement={Blob}`). L'utilisation d'un __Blob__ permet de stocker virtuellement n'import quel type de fichier dans la bdd. ### Améliorations potentielles > - Stocker les fichiers justificatifs dans un dossier sur le serveur plutôt que dans la base de donnée. On aurait alors une sauvegarde uniquement d'une chaîne de caractères (le chemin du fichier / la justification textuelle) au lieu de __Blob__ prenant beaucoup de place et étant lourds à traiter.\ > __Le problème est qu'on perd la facilité d'accès et les vérifications opérées automatiquement par le gestionnaire de base de donnée.__ > - Définir une durée de validité pour chaque justificatif au lieu de lier le justificatif à une plage. (et donc lier un justificatif à un étudiant)\ > __Le problème est qu'on perd de la simplicité de selection (utilisation de l'id de la plage dans un cas et utilisation de 2 *datetime* dans un autre) Mais au moins on a pas besoin d'entrer plusieurs fois un même justificatif.__