misc corrections
This commit is contained in:
parent
4c58b40eef
commit
85fdb885cc
@ -7,15 +7,15 @@
|
|||||||
est normalement intégré à votre éditeur (VSCode et PyCharm sont deux choix
|
est normalement intégré à votre éditeur (VSCode et PyCharm sont deux choix
|
||||||
judicieux).
|
judicieux).
|
||||||
- outre Python, les principaux composants logiciels sont:
|
- outre Python, les principaux composants logiciels sont:
|
||||||
- [Flask](https://flask-sqlalchemy.palletsprojects.com/en/2.x/): le
|
- [Flask](https://flask-sqlalchemy.palletsprojects.com/en/2.x/): le
|
||||||
framework Web, dont on utilise notamment:
|
framework Web, dont on utilise notamment:
|
||||||
- l'ORM [SQLAlchemy](https://www.sqlalchemy.org/)
|
- l'ORM [SQLAlchemy](https://www.sqlalchemy.org/)
|
||||||
- les templates [Jinja2](https://jinja.palletsprojects.com/en/3.0.x/)
|
- les templates [Jinja2](https://jinja.palletsprojects.com/en/3.0.x/)
|
||||||
- [Postgresql](https://www.postgresql.org/)
|
- [Postgresql](https://www.postgresql.org/)
|
||||||
- [Redis](https://redis.io/) cache persistant
|
- [Redis](https://redis.io/) cache persistant
|
||||||
- [NGINX](https://www.nginx.com/) serveur Web frontal
|
- [NGINX](https://www.nginx.com/) serveur Web frontal
|
||||||
- [gunicorn](https://gunicorn.org/) WSGI HTTP server
|
- [gunicorn](https://gunicorn.org/) WSGI HTTP server
|
||||||
- et bien sûr Linux (Debian 12 en 2023-2024) et systemd.
|
- et bien sûr Linux (Debian 12 en 2023-2024) et systemd.
|
||||||
|
|
||||||
## Principaux objets
|
## Principaux objets
|
||||||
|
|
||||||
@ -29,9 +29,9 @@ Principales classes (les noms des classes Python sont en `CamelCase`).
|
|||||||
|
|
||||||
- Étudiants (classe `Identite`): nom, codes INE/NIP, etc
|
- Étudiants (classe `Identite`): nom, codes INE/NIP, etc
|
||||||
- Formations: programmes pédagogiques, contenant
|
- Formations: programmes pédagogiques, contenant
|
||||||
- Unités d'Enseignement (`UniteEns`);
|
- Unités d'Enseignement (`UniteEns`);
|
||||||
- Matières et Modules (`Module`, avec son type standard, bonus, ressources
|
- Matières et Modules (`Module`, avec son type standard, bonus, ressources
|
||||||
ou SAÉ).
|
ou SAÉ).
|
||||||
- FormSemestre: instanciation d'une session de formation, avec un programme
|
- FormSemestre: instanciation d'une session de formation, avec un programme
|
||||||
pédagogique donné (Formation), les dates de début et fin, des étudiants
|
pédagogique donné (Formation), les dates de début et fin, des étudiants
|
||||||
inscrits, des responsables, divers codes, et les ModuleImpl mis en œuvre.
|
inscrits, des responsables, divers codes, et les ModuleImpl mis en œuvre.
|
||||||
@ -46,13 +46,13 @@ Principales classes (les noms des classes Python sont en `CamelCase`).
|
|||||||
Une vue ordinaire (Web) pourrait ressembler à cela. Noter la présence de
|
Une vue ordinaire (Web) pourrait ressembler à cela. Noter la présence de
|
||||||
décorateurs:
|
décorateurs:
|
||||||
|
|
||||||
- `@scodoc` récupère le département (présent dans l'URL) et initialise quelques
|
- `@scodoc` récupère le département (présent dans l'URL) et initialise quelques
|
||||||
trucs, notamment `g.scodoc_dept` (l'acronyme du département courant) et
|
trucs, notamment `g.scodoc_dept` (l'acronyme du département courant) et
|
||||||
`g.scodoc_dept_id` (l'id du dépt. courant).
|
`g.scodoc_dept_id` (l'id du dépt. courant).
|
||||||
- `@permission_required`: permet de contrôler l'accès, en se basant sur les
|
- `@permission_required`: permet de contrôler l'accès, en se basant sur les
|
||||||
permissions définies dans la classe `Permission`.
|
permissions définies dans la classe `Permission`.
|
||||||
|
|
||||||
```
|
```py
|
||||||
@bp.route("/un_exemple")
|
@bp.route("/un_exemple")
|
||||||
@scodoc
|
@scodoc
|
||||||
@permission_required(Permission.EditFormation)
|
@permission_required(Permission.EditFormation)
|
||||||
|
@ -88,7 +88,7 @@ On a ici:
|
|||||||
- identifiant du groupe: dans `SUMMARY`, `* - <groupe>`
|
- identifiant du groupe: dans `SUMMARY`, `* - <groupe>`
|
||||||
- identifiant du module: on a le code `VCYR303` à trois endroits: `SUMMARY`,
|
- identifiant du module: on a le code `VCYR303` à trois endroits: `SUMMARY`,
|
||||||
`DESCRIPTION`, `X-ALT-DESC`.
|
`DESCRIPTION`, `X-ALT-DESC`.
|
||||||
- identifiant de l'enseignant: `SUMMARY`, `DESCRIPTION`, `X-ALT-DESC`.
|
- identifiant de l'enseignant: ici `1234`, présent dans `SUMMARY`, `DESCRIPTION` et `X-ALT-DESC`.
|
||||||
|
|
||||||
## Extraction des identifiants: semestres, groupes, modules, enseignants
|
## Extraction des identifiants: semestres, groupes, modules, enseignants
|
||||||
|
|
||||||
|
@ -86,7 +86,7 @@ Au besoin, mémo:
|
|||||||
|
|
||||||
- afficher les clés: `redis-cli KEYS '*'`
|
- afficher les clés: `redis-cli KEYS '*'`
|
||||||
|
|
||||||
- `redis-cli TTL key` affiche le TTL d'un clé, -1 si infini.
|
- `redis-cli TTL key` affiche le TTL d'une clé, -1 si infini.
|
||||||
|
|
||||||
- `redis-cli -r -1 -i 3 KEYS '*_NT_*'` surveille certaines clés (ici _NT_),
|
- `redis-cli -r -1 -i 3 KEYS '*_NT_*'` surveille certaines clés (ici _NT_),
|
||||||
affiche toutes les 3 secondes.
|
affiche toutes les 3 secondes.
|
||||||
|
@ -1042,8 +1042,10 @@ responsable et ses enseignants). La liste des moduleimpl d'un formsemestre peut
|
|||||||
* **Résultat:** Description du moduleimpl.
|
* **Résultat:** Description du moduleimpl.
|
||||||
* **Exemple de résultat:** [moduleimpl.json](samples/sample_moduleimpl.json.md)
|
* **Exemple de résultat:** [moduleimpl.json](samples/sample_moduleimpl.json.md)
|
||||||
|
|
||||||
#### **`moduleimpl-inscriptions`**
|
Note: la liste des `ModuleImpl` d'un `FormSemestre` peut être obtenue via
|
||||||
|
[formsemestre-programme](#formsemestre-programme).
|
||||||
|
|
||||||
|
#### **`moduleimpl-inscriptions`**
|
||||||
|
|
||||||
* **Méthode:** GET
|
* **Méthode:** GET
|
||||||
* **Permission: `ScoView`**
|
* **Permission: `ScoView`**
|
||||||
@ -1053,6 +1055,59 @@ responsable et ses enseignants). La liste des moduleimpl d'un formsemestre peut
|
|||||||
* **Résultat:** Liste des inscriptions à ce moduleimpl.
|
* **Résultat:** Liste des inscriptions à ce moduleimpl.
|
||||||
* **Exemple de résultat:** [moduleimpl.json](samples/sample_moduleimpl_inscriptions.json.md)
|
* **Exemple de résultat:** [moduleimpl.json](samples/sample_moduleimpl_inscriptions.json.md)
|
||||||
|
|
||||||
|
#### **`moduleimpl-evaluations`**
|
||||||
|
|
||||||
|
* **Méthode:** GET
|
||||||
|
* **Permission: `ScoView`**
|
||||||
|
* **Paramètres:** `moduleimpl_id`
|
||||||
|
* **Routes:** `/moduleimpl/<int:moduleimpl_id>/evaluations`
|
||||||
|
* **Exemple d'utilisation:** `/ScoDoc/api/moduleimpl/1/evaluations`
|
||||||
|
* **Résultat:** Liste ordonnée des évaluations dans ce moduleimpl.
|
||||||
|
|
||||||
|
#### **`moduleimpl-notes`**
|
||||||
|
|
||||||
|
* **Méthode:** GET
|
||||||
|
* **Permission: `ScoView`**
|
||||||
|
* **Paramètres:** `moduleimpl_id`
|
||||||
|
* **Routes:** `/moduleimpl/<int:moduleimpl_id>/notes`
|
||||||
|
* **Exemple d'utilisation:** `/ScoDoc/api/moduleimpl/1/notes`
|
||||||
|
* **Résultat:** Liste des notes dans ce moduleimpl.
|
||||||
|
|
||||||
|
Exemple en formation classique:
|
||||||
|
|
||||||
|
```json
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"etudid": 18270,
|
||||||
|
"nom": "Ball",
|
||||||
|
"prenom": "Jane",
|
||||||
|
"38083": 11.0, // Note evaluation d'id 38083
|
||||||
|
"38084": 14.5, // Note evaluation 38084
|
||||||
|
"moymod": 12.75 // Moyenne au module
|
||||||
|
},
|
||||||
|
...
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
|
Exemple de résultat en BUT:
|
||||||
|
|
||||||
|
```json
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"etudid": 17776, // code de l'étudiant
|
||||||
|
"nom": "DUPONT",
|
||||||
|
"prenom": "Luz",
|
||||||
|
"38411": 16.0, // Note dans l'évaluation d'id 38411
|
||||||
|
"38410": 15.0,
|
||||||
|
"moymod": 15.5, // Moyenne INDICATIVE module
|
||||||
|
"moy_ue_2875": 15.5, // Moyenne vers l'UE 2875
|
||||||
|
"moy_ue_2876": 15.5, // Moyenne vers l'UE 2876
|
||||||
|
"moy_ue_2877": 15.5 // Moyenne vers l'UE 2877
|
||||||
|
},
|
||||||
|
...
|
||||||
|
]
|
||||||
|
```
|
||||||
|
|
||||||
### **API Partition**
|
### **API Partition**
|
||||||
|
|
||||||
#### Structure Partition
|
#### Structure Partition
|
||||||
@ -1901,15 +1956,16 @@ Cette API est disponible à partir de ScoDoc 9.6 et remplace les absences.
|
|||||||
|
|
||||||
| attribut | type | commentaire |
|
| attribut | type | commentaire |
|
||||||
| :----------- | :------------- | :------------------------------------------------------------ |
|
| :----------- | :------------- | :------------------------------------------------------------ |
|
||||||
| *justif_id* | int | identifiant unique |
|
| *justif_id* | int | identifiant unique |
|
||||||
| *etudid* | int | identifiant unique de l'étudiant concerné par le justificatif |
|
| *etudid* | int | identifiant unique de l'étudiant concerné par le justificatif |
|
||||||
| *date_debut* | string | date ISO du début de la période du justificatif |
|
| *date_debut* | string | date ISO du début de la période du justificatif |
|
||||||
| *date_fin* | string | date ISO de la fin de la période du justificatif |
|
| *date_fin* | string | date ISO de la fin de la période du justificatif |
|
||||||
| *etat* | string | état du justificatif ( attente, valide, non_valide, modifie) |
|
| *etat* | string | état du justificatif ( attente, valide, non_valide, modifie) |
|
||||||
| *raison* | string ou null | explication du justificatif si présente |
|
| *raison* | string ou null | explication du justificatif si présente |
|
||||||
| *fichier* | string | identifiant de l'archivage des fichiers |
|
| *fichier* | string | identifiant de l'archivage des fichiers |
|
||||||
|*user_id* | int or null | identifiant de l'utilisateur ayant créé le justificatif |
|
| *user_id* | int or null | id de l'utilisateur ayant créé le justificatif |
|
||||||
| *entry_date* | string | date ISO de l'entrée du justificatif |
|
| *user_name* | str ou null | login de l'utilisateur ayant créé le justificatif |
|
||||||
|
| *entry_date* | string | date ISO de l'entrée du justificatif |
|
||||||
|
|
||||||
#### **justificatif**
|
#### **justificatif**
|
||||||
|
|
||||||
|
@ -59,10 +59,10 @@ Par ailleurs, chaque semestre est associé à une étape Apogée (VET), et, en
|
|||||||
option, à un code d'élément annuel et un code d'élément semestre. Pour le
|
option, à un code d'élément annuel et un code d'élément semestre. Pour le
|
||||||
deuxième semestre 5S2) du DUT R&T Villetaneuse, cela donne:
|
deuxième semestre 5S2) du DUT R&T Villetaneuse, cela donne:
|
||||||
|
|
||||||
* Code étape (VET): `V1RT` (l'étape est annuelle)
|
- Code étape (VET): `V1RT` (l'étape est annuelle)
|
||||||
* Code année (ELP): `VRT1A` (cet élément contiendra exactement les mêmes
|
- Code année (ELP): `VRT1A` (cet élément contiendra exactement les mêmes
|
||||||
informations que le VET)
|
informations que le VET)
|
||||||
* Code semestre (ELP): `VRTW2` (la note de ces élément sera la moyenne générale
|
- Code semestre (ELP): `VRTW2` (la note de ces élément sera la moyenne générale
|
||||||
du semestre)
|
du semestre)
|
||||||
|
|
||||||
Notez que la nomenclature est variable et souvent peu prévisible, même au sein
|
Notez que la nomenclature est variable et souvent peu prévisible, même au sein
|
||||||
@ -97,13 +97,13 @@ Apogée.
|
|||||||
|
|
||||||
### Précautions à prendre et remarques diverses
|
### Précautions à prendre et remarques diverses
|
||||||
|
|
||||||
* **Codage des fichiers**: Apogée (du moins à l'Université Paris 13) exporte et
|
- **Codage des fichiers**: Apogée (du moins à l'Université Paris 13) exporte et
|
||||||
importe des fichiers maquettes codés en latin-1 (ISO-8859-1). Les web
|
importe des fichiers maquettes codés en latin-1 (ISO-8859-1). Les web
|
||||||
services (portail Apogée), tout comme ScoDoc, travaillent en utf8. Pour
|
services (portail Apogée), tout comme ScoDoc, travaillent en utf8. Pour
|
||||||
faciliter les échanges, les fichiers maquettes importés et exportés de ScoDoc
|
faciliter les échanges, les fichiers maquettes importés et exportés de ScoDoc
|
||||||
sont en latin-1 (sauf celui reçu du portail Apogée).
|
sont en latin-1 (sauf celui reçu du portail Apogée).
|
||||||
|
|
||||||
* **Format des nombres** (notes): les notes sont calculées par ScoDoc en haute
|
- **Format des nombres** (notes): les notes sont calculées par ScoDoc en haute
|
||||||
précision, mais affichées avec deux chiffres après la virgule dans
|
précision, mais affichées avec deux chiffres après la virgule dans
|
||||||
l'application (ce qui donne 4 chiffres significatifs, par exemple *12,34*,
|
l'application (ce qui donne 4 chiffres significatifs, par exemple *12,34*,
|
||||||
soit une précision de un pour dix mille, ce qui semble plus que suffisant
|
soit une précision de un pour dix mille, ce qui semble plus que suffisant
|
||||||
@ -118,14 +118,15 @@ Apogée.
|
|||||||
|
|
||||||
![Config. précision exports Apogée](screens/apo-precision.png)
|
![Config. précision exports Apogée](screens/apo-precision.png)
|
||||||
|
|
||||||
* **Étudiants démissionnaires**: on note les démissions dans ScoDoc (sur la fiche
|
- **Étudiants démissionnaires**: on note les démissions dans ScoDoc (sur la fiche
|
||||||
de l'étudiant), mais en général pas dans Apogée. Le résultat Apogée sera DEF.
|
de l'étudiant), mais en général pas dans Apogée. Le résultat Apogée sera DEF.
|
||||||
Ne jamais désinscrire du semestre ScoDoc les démissionnaires !
|
Ne jamais désinscrire du semestre ScoDoc les démissionnaires !
|
||||||
|
|
||||||
* Exports à **mi-année** (après jurys de janvier): Si `periode==1` (jury de janvier),
|
- Exports à **mi-année** (après jurys de janvier): Si `periode==1` (jury de janvier),
|
||||||
alors l'étape Apogée (annuelle) n'est pas terminée.
|
alors l'étape Apogée (annuelle) n'est pas terminée.
|
||||||
Donc on ne remplit pas le code annuel (`elt_annee_apo`, comme `VRT1A`) ni le
|
Donc on ne remplit pas le code annuel (`elt_annee_apo`, comme `VRT1A`) ni le
|
||||||
`VET` sauf si l'année est en fait validée grâce à un semestre de l'an
|
`VET` sauf si l'année est en fait validée grâce à un semestre de l'an
|
||||||
précédent: (voir r1525)
|
précédent: (voir r1525)
|
||||||
* jury de fin de S1: si le S2 est validé;
|
|
||||||
* jury de fin de S3: si le S4 est validé.
|
- jury de fin de S1: si le S2 est validé;
|
||||||
|
- jury de fin de S3: si le S4 est validé.
|
||||||
|
@ -121,6 +121,8 @@ l'initialiser et la peupler de données fictives pour les tests.
|
|||||||
flask run --host 0.0.0.0 --debug
|
flask run --host 0.0.0.0 --debug
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Le script `tests/api/start_api_server.sh -p 5555` fait tout cela pour vous !
|
||||||
|
|
||||||
### Configuration du client de test API
|
### Configuration du client de test API
|
||||||
|
|
||||||
1. Copier le fichier `scodoc/tests/api/dotenv_exemple` dans
|
1. Copier le fichier `scodoc/tests/api/dotenv_exemple` dans
|
||||||
|
Loading…
Reference in New Issue
Block a user