From 9297f199f384b8f257a80c6254d335724705d995 Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Thu, 23 Oct 2025 15:38:26 +0000
Subject: [PATCH] GS-2375

---
 lib/libIlias.js |  111 +++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 95 insertions(+), 16 deletions(-)

diff --git a/lib/libIlias.js b/lib/libIlias.js
index 0681f29..64fe2ea 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -9,15 +9,48 @@
 /////////////////////////////////////////////////////////////////////////
 
 module.exports = {
+   ping,
+
+   getUser,
+
    importIliasUser,
+
+   createKurs,
+
+   anmelden,
+   abmelden,
 
    deleteUser,
    deleteAllUsers,
-   deleteTeilnahme,
+   // deleteTeilnahme,
+
+
 }
 
 /////////////////////////////////////////////////////////////////////////
 
+async function ping() {
+   const sp = new URLSearchParams({
+      command: "ping",
+      token: iliastoken,
+   })
+   let url2 = `${url}?${sp.toString()}`
+   console.log("pinging url", url2)
+   const res = await fetch(url2, {method: "GET"})
+   return await res.json() //
+}
+
+/////// GET USER ////////////////////////////////////////////////////////////////
+async function getUser (usr_id) {
+   const sp = new URLSearchParams({
+      command: "getUser",
+      usr_id,
+      token: iliastoken,
+   })
+   let url2 = `${url}?${sp.toString()}`
+   const res = await fetch(url2, {method: "GET"})
+   return await res.json() //
+}
 
 /////// USER IMPORT ////////////////////////////////////////////////////////////////
 
@@ -108,24 +141,70 @@
    return res
 }
 
-async function deleteTeilnahme (ref_id, usr_id, dry = false) {
-   const {obj_id} = await getObjIdFromRefId(ref_id)
+// async function deleteTeilnahme (ref_id, usr_id, dry = false) {
+//    const {obj_id} = await getObjIdFromRefId(ref_id)
+//    const sp = new URLSearchParams({
+//       command: "deleteTeilnahme",
+//       course_id: obj_id,
+//       usr_id,
+//       dry: dry ? "1" : "0",
+//       token: iliastoken,
+//    })
+//    let url2 = `${url}?${sp.toString()}`
+//    console.log("libIlias.deleteTeilnahme >>>", url2)
+//    let res
+//    try {
+//       res = await fetch(url2, {method: "DELETE"})
+//       return await res.json()
+//    } catch (ex) {
+//       console.error(ex)
+//       throw ex
+//    }
+// }
+
+/////// KURS ////////////////////////////////////////////////////////////////
+
+async function createKurs(kurs) {
    const sp = new URLSearchParams({
-      command: "deleteTeilnahme",
-      obj_id,
-      usr_id,
-      dry: dry ? "1" : "0",
+      command: "createKurs",
       token: iliastoken,
    })
    let url2 = `${url}?${sp.toString()}`
-   console.log("libIlias.deleteTeilnahme >>>", url2)
-   let res
-   try {
-      res = await fetch(url2, {method: "DELETE"})
-      return await res.json()
-   } catch (ex) {
-      console.error(ex)
-      throw ex
-   }
+   const res = await fetch(url2, {
+      method: "POST",
+      body: JSON.stringify(kurs),
+   })
+   return await res.json()
 }
 
+
+/////// Anmelden / Abmelden ////////////////////////////////////////////////////////////////
+
+async function anmelden (usr_id, course_id) {
+   // const role = await db.getMemberRoleForCourse(course_id) // nein es wird relative id gebraucht, siehe php
+   const sp = new URLSearchParams({
+      command: "anmelden",
+      usr_id,
+      course_id,
+      token: iliastoken,
+   })
+   let url2 = `${url}?${sp.toString()}`
+   console.log(url2)
+   const res = await fetch(url2, {method: "POST"})
+   return await res.json()
+}
+
+async function abmelden (usr_id, course_id) {
+   const sp = new URLSearchParams({
+      command: "abmelden",
+      usr_id,
+      course_id,
+      token: iliastoken,
+   })
+   let url2 = `${url}?${sp.toString()}`
+   console.log(url2)
+   const res = await fetch(url2, {method: "DELETE"})
+   return await res.json()
+}
+
+

--
Gitblit v1.8.0