From 8d33fafb3224360f49f6ebc9e1b98f4fbdc1d1ad Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Wed, 25 Jun 2025 07:09:10 +0000
Subject: [PATCH] GS-2169

---
 lib/libIlias.js |  105 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 99 insertions(+), 6 deletions(-)

diff --git a/lib/libIlias.js b/lib/libIlias.js
index df87347..cf06e73 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,19 +1,92 @@
 /* Lib for interacting with customized ILIAS php */
+const _ = require("lodash")
+const settings = require("../settings")
+const {getObjIdFromRefId} = require("./db")
+const db = require("./db")
+const {url, iliastoken} = settings.ilias
+const search = require("./search")
+
+/////////////////////////////////////////////////////////////////////////
 
 module.exports = {
+   getUser,
+
+   importIliasUser,
+   anmelden,
+
    deleteUser,
    deleteAllUsers,
    deleteTeilnahme,
+
+
 }
 
 /////////////////////////////////////////////////////////////////////////
 
-const settings = require("../settings")
-const {getObjIdFromRefId} = require("./db")
-const db = require("./db")
-const {url} = settings.ilias
+/////// 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 ////////////////////////////////////////////////////////////////
+
+/**
+ * Format in POPCORN für SOAP; ausprobieren ob das hier auch funktioniert, v.a. die user-defined-fields
+ *   const user = {
+ *       login: "123456789",
+ *       passwd: "123456789",
+ *       passwd_type: "plain",
+ *       firstname: "Adolfo",
+ *       lastname: "de la Cruz",
+ *       email: "alex@gorillaeis.com",
+ *       gender: "m",
+ *       department: "Bananenpflücker",
+ *       institution: "Globus Budapest",
+ *       role: 4, // assigned global role id
+ *       udf: {
+ *          "Markt": "Markt UDF 2",
+ *          "Marktnummer": "Marktnummer UDF 2",
+ *          "Personalnummer": "Personal UDF 2",
+ *       },
+ *    }
+ * @param user
+ * @returns {Promise<any>}
+ */
+async function importIliasUser (user) {
+   const sp = new URLSearchParams({
+      command: "importUser",
+      token: iliastoken,
+   })
+   let url2 = `${url}?${sp.toString()}`
+
+   const udfDef = await db.getUdf()
+   const udfMap = _.keyBy(udfDef, "field_name")
+   user.udf = _.mapKeys(user.udf, function (value, key) {
+      return udfMap[key].field_id
+   })
+
+   const res = await fetch(url2, {
+      method: "POST",
+      body: JSON.stringify(user)
+   })
+   const text = await res.text()
+   try {
+      return JSON.parse(text)
+   } catch (ex) {
+      console.error(ex.message)
+      console.log(text)
+      throw ex
+   }
+}
+
+/////// USER DELETE ////////////////////////////////////////////////////////////////
 
 async function deleteUser (obj_id, dry = false) {
    const sp = new URLSearchParams({
@@ -21,15 +94,17 @@
       obj_id,
       // dry: "1",
       dry: dry ? "1" : "0",
+      token: iliastoken,
    })
    let url2 = `${url}?${sp.toString()}`
    const res = await fetch(url2, {method: "DELETE"})
    const data = await res.json()
+   // TODO update search index
    return data //
 }
 
 async function deleteAllUsers () {
-   const users = await db.getUsers()
+   const {data: users} = await db.getUsers(0, 100000)
    const res = {
       command: "deleteAllUsers",
       start: new Date(),
@@ -45,6 +120,7 @@
    }
    res.end = new Date()
    res.duration = res.end - res.start
+   // TODO update search index
    return res
 }
 
@@ -55,6 +131,7 @@
       obj_id,
       usr_id,
       dry: dry ? "1" : "0",
+      token: iliastoken,
    })
    let url2 = `${url}?${sp.toString()}`
    console.log("libIlias.deleteTeilnahme >>>", url2)
@@ -67,3 +144,19 @@
       throw ex
    }
 }
+
+/////// Anmelden ////////////////////////////////////////////////////////////////
+
+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()
+}

--
Gitblit v1.8.0