summaryrefslogtreecommitdiff
path: root/alarm/node_modules/pronote-api/src/fetch/pronote/contents.js
diff options
context:
space:
mode:
Diffstat (limited to 'alarm/node_modules/pronote-api/src/fetch/pronote/contents.js')
-rw-r--r--alarm/node_modules/pronote-api/src/fetch/pronote/contents.js60
1 files changed, 60 insertions, 0 deletions
diff --git a/alarm/node_modules/pronote-api/src/fetch/pronote/contents.js b/alarm/node_modules/pronote-api/src/fetch/pronote/contents.js
new file mode 100644
index 0000000..7525e3d
--- /dev/null
+++ b/alarm/node_modules/pronote-api/src/fetch/pronote/contents.js
@@ -0,0 +1,60 @@
+const parse = require('../../data/types');
+const { fromPronote } = require('../../data/objects');
+
+const navigate = require('./navigate');
+
+const PAGE_NAME = 'PageCahierDeTexte';
+const TAB_ID = 89;
+const ACCOUNTS = ['student', 'parent'];
+
+async function getContents(session, user, fromWeek = 1, toWeek = null)
+{
+ if (!toWeek || toWeek < fromWeek) {
+ toWeek = fromWeek;
+ }
+
+ const contents = await navigate(session, user, PAGE_NAME, TAB_ID, ACCOUNTS, {
+ domaine: {
+ _T: 8,
+ V: `[${fromWeek}..${toWeek}]`
+ }
+ });
+
+ if (!contents) {
+ return null;
+ }
+
+ return {
+ lessons: parse(contents.ListeCahierDeTextes, ({
+ cours, verrouille, listeGroupes, Matiere, CouleurFond, listeProfesseurs, Date, DateFin,
+ listeContenus, listeElementsProgrammeCDT
+ }) => ({
+ lesson: parse(cours),
+ locked: verrouille,
+ groups: parse(listeGroupes), // TODO: Check values
+ subject: parse(Matiere),
+ color: CouleurFond,
+ teachers: parse(listeProfesseurs),
+ from: parse(Date),
+ to: parse(DateFin),
+ content: parse(listeContenus, ({
+ descriptif, categorie, parcoursEducatif, ListePieceJointe, training
+ }) => ({
+ description: parse(descriptif),
+ category: parse(categorie),
+ path: parcoursEducatif,
+ files: parse(ListePieceJointe),
+ training: parse(training).ListeExecutionsQCM.map(o => fromPronote(o)) // TODO: Check values
+ })),
+ skills: parse(listeElementsProgrammeCDT)
+ })),
+ resources: (({ listeRessources, listeMatieres }) => ({
+ resources: parse(listeRessources), // TODO: Check values
+ subjects: parse(listeMatieres) // TODO: Check values
+ }))(parse(contents.ListeRessourcesPedagogiques)),
+ // TODO: Check values
+ numericalResources: parse(parse(contents.ListeRessourcesNumeriques).listeRessources)
+ };
+}
+
+module.exports = getContents;