From 8f37d4c717f0ff348ee4d23fb75ca6e017705603 Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Fri, 20 Jun 2025 09:43:47 +0000
Subject: [PATCH] GS-2156
---
lib/libIlias.js | 85 ++++++++++++++++++++++++++++++++++++++++--
1 files changed, 80 insertions(+), 5 deletions(-)
diff --git a/lib/libIlias.js b/lib/libIlias.js
index b3d02a9..5dd90ab 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,6 +1,15 @@
/* Lib for interacting with customized ILIAS php */
+const settings = require("../settings")
+const {getObjIdFromRefId} = require("./db")
+const db = require("./db")
+const {url, iliastoken} = settings.ilias
+const search = require("./search")
+
+/////////////////////////////////////////////////////////////////////////
module.exports = {
+ importIliasUser,
+
deleteUser,
deleteAllUsers,
deleteTeilnahme,
@@ -8,12 +17,75 @@
/////////////////////////////////////////////////////////////////////////
-const settings = require("../settings")
-const {getObjIdFromRefId} = require("./db")
-const db = require("./db")
-const {url} = settings.ilias
-/////////////////////////////////////////////////////////////////////////
+/////// 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),
+ * },
+ * ],
+ * }
+ * @param user
+ * @returns {Promise<any>}
+ */
+async function importIliasUser (user) {
+ const sp = new URLSearchParams({
+ command: "importUser",
+ token: iliastoken,
+ })
+ let url2 = `${url}?${sp.toString()}`
+ console.log(url2)
+ 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
+ } 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
+ }
+}
+
+/////// USER DELETE ////////////////////////////////////////////////////////////////
async function deleteUser (obj_id, dry = false) {
const sp = new URLSearchParams({
@@ -21,6 +93,7 @@
obj_id,
// dry: "1",
dry: dry ? "1" : "0",
+ token: iliastoken,
})
let url2 = `${url}?${sp.toString()}`
const res = await fetch(url2, {method: "DELETE"})
@@ -57,6 +130,7 @@
obj_id,
usr_id,
dry: dry ? "1" : "0",
+ token: iliastoken,
})
let url2 = `${url}?${sp.toString()}`
console.log("libIlias.deleteTeilnahme >>>", url2)
@@ -69,3 +143,4 @@
throw ex
}
}
+
--
Gitblit v1.8.0