From 7a62193da9c9bb8f66c1e26cd1cecfc7925d6de0 Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Wed, 25 Jun 2025 06:59:23 +0000
Subject: [PATCH] GS-2169

---
 lib/libIlias.js |   98 ++++++++++++++++++++++++++++--------------------
 1 files changed, 57 insertions(+), 41 deletions(-)

diff --git a/lib/libIlias.js b/lib/libIlias.js
index 5dd90ab..cf06e73 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,4 +1,5 @@
 /* Lib for interacting with customized ILIAS php */
+const _ = require("lodash")
 const settings = require("../settings")
 const {getObjIdFromRefId} = require("./db")
 const db = require("./db")
@@ -8,47 +9,53 @@
 /////////////////////////////////////////////////////////////////////////
 
 module.exports = {
+   getUser,
+
    importIliasUser,
+   anmelden,
 
    deleteUser,
    deleteAllUsers,
    deleteTeilnahme,
+
+
 }
 
 /////////////////////////////////////////////////////////////////////////
 
+/////// 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
- * {
- *         Action: "Insert",
- *         login: formatSapNr(dbMa.sapNr),
- *         password: passGen(12),
- *         firstname: dbMa.vorname,
- *         lastname: dbMa.nachname,
- *         email: email,
- *         gender: mapSex[dbMa.geschlecht],
- *         // GS-1894: Azubis wird der Ausbildungsberuf auch als Abteilung angezeigt
- *         department: getDepartment(dbMa),
- *         institution: dbMa.markt.markt,
- *         roleIdGlobal: 4,
- *         userDefinedField: [
- *             {
- *                 name: "Markt",
- *                 value: dbMa.markt.markt,
- *             },
- *             {
- *                 name: "Marktnummer",
- *                 value: dbMa.markt.nr,
- *             },
- *             {
- *                 name: "Personalnummer",
- *                 value: formatSapNr(dbMa.sapNr),
- *             },
- *         ],
- *     }
+ *   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>}
  */
@@ -58,30 +65,24 @@
       token: iliastoken,
    })
    let url2 = `${url}?${sp.toString()}`
-   console.log(url2)
+
+   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 data = await res.json()
-   // return data
-
    const text = await res.text()
    try {
-      const json = JSON.parse(text)
-      return json
+      return JSON.parse(text)
    } catch (ex) {
       console.error(ex.message)
       console.log(text)
       throw ex
-   }
-   try {
-      return data
-   } catch (ex) {
-      const text = await res.text()
-      console.error(text)
-      return false
    }
 }
 
@@ -144,3 +145,18 @@
    }
 }
 
+/////// 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