From 56c4f060543542692accdbfab7cb1fff82a7f40f Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Sun, 22 Jun 2025 16:47:10 +0000
Subject: [PATCH] GS-2156
---
lib/libIlias.js | 94 +++++++++++++++++++++++-----------------------
1 files changed, 47 insertions(+), 47 deletions(-)
diff --git a/lib/libIlias.js b/lib/libIlias.js
index 1016beb..88a2004 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,7 +1,18 @@
/* 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,
+
deleteUser,
deleteAllUsers,
@@ -10,44 +21,39 @@
/////////////////////////////////////////////////////////////////////////
-const settings = require("../settings")
-const {getObjIdFromRefId} = require("./db")
-const db = require("./db")
-const {url, iliastoken} = 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
- * {
- * 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>}
*/
@@ -57,30 +63,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
}
}
--
Gitblit v1.8.0