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 | 107 +++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 98 insertions(+), 9 deletions(-)
diff --git a/lib/libIlias.js b/lib/libIlias.js
index 3badcb9..cf06e73 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,19 +1,92 @@
/* Lib for interacting with customized ILIAS php */
-
-module.exports = {
- deleteUser,
- deleteAllUsers,
- deleteTeilnahme,
-}
-
-/////////////////////////////////////////////////////////////////////////
-
+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,
+
+
+}
+
+/////////////////////////////////////////////////////////////////////////
+
+/////// 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({
@@ -71,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