From 7a2f304888c58f61cfd0a918ae9ea573a8d729ba Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Thu, 19 Jun 2025 14:43:01 +0000
Subject: [PATCH] GS-2156

---
 lib/libIlias.js               |   72 ++++++++++++++++++++++++
 php/globus-ilias-rest/api.php |   16 +++++
 settings.default.json         |    2 
 test/testImportIliasUser.js   |   47 +++++++++++++++
 4 files changed, 136 insertions(+), 1 deletions(-)

diff --git a/lib/libIlias.js b/lib/libIlias.js
index 3badcb9..22481aa 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -1,6 +1,8 @@
 /* Lib for interacting with customized ILIAS php */
 
 module.exports = {
+   importIliasUser,
+
    deleteUser,
    deleteAllUsers,
    deleteTeilnahme,
@@ -14,6 +16,75 @@
 const {url, iliastoken} = 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({
@@ -71,3 +142,4 @@
       throw ex
    }
 }
+
diff --git a/php/globus-ilias-rest/api.php b/php/globus-ilias-rest/api.php
index b340e2c..3be9bb7 100644
--- a/php/globus-ilias-rest/api.php
+++ b/php/globus-ilias-rest/api.php
@@ -50,6 +50,14 @@
                     $res["status"] = "ok";
                     break;
                 }
+            case "importUser":
+                if ($method == "POST") {
+                    $body = file_get_contents('php://input');
+                    $data = json_decode($body, true);
+                    $res["usr_id"] = importUser($data);
+                    $res["status"] = "ok";
+                    break;
+                }
             case "deleteUser":
                 if ($method == "DELETE") {
                     $res["msg"] = deleteUser($obj_id, $dry);
@@ -84,6 +92,14 @@
 
 ###############################
 
+function importUser($data) {
+    $user = new ilObjUser();
+    $user->assignData($data);
+    $usr_id = $user->create();
+    $user->saveAsNew();
+    return $usr_id;
+}
+
 function deleteUser($obj_id, $dry)
 {
     $usr = ilObjectFactory::getInstanceByObjId($obj_id);
diff --git a/settings.default.json b/settings.default.json
index 3f2f582..91b35bc 100644
--- a/settings.default.json
+++ b/settings.default.json
@@ -14,7 +14,7 @@
    },
    "ilias": {
       "urlDoc": "Url of custom ILIAS PHP file",
-      "url": "http://192.168.178.84:8060/alex.php",
+      "url": "http://192.168.178.84:8060/globus-ilias-rest/api.php",
       "iliastoken": "jkhHKhui899HUKHBzGHtgoiedko2393490"
    }
 }
diff --git a/test/testImportIliasUser.js b/test/testImportIliasUser.js
new file mode 100644
index 0000000..19c2ea7
--- /dev/null
+++ b/test/testImportIliasUser.js
@@ -0,0 +1,47 @@
+const expect = require("chai").expect
+
+const settings = require("../settings")
+const libIlias = require("../lib/libIlias")
+
+/////////////////////////////////////////////////////////////////////////
+
+describe("the function importIliasUser", function () {
+
+   const user = {
+      // Action: "Insert",
+      login: "affoReloaded",
+      passwd: "test1234",
+      passwd_type: "plain",
+      firstname: "Adolfo",
+      lastname: "de la Cruz",
+      email: "alex@gorillaeis.com",
+      gender: "m",
+      department: "Bananenpflücker",
+      institution: "Globus Budapest",
+      roleIdGlobal: 4,
+      userDefinedField: [
+         {
+            name: "Markt",
+            value: "Markt UDF",
+         },
+         {
+            name: "Marktnummer",
+            value: "Marktnummer UDF",
+         },
+         {
+            name: "Personalnummer",
+            value: "Personalnummer UDF",
+         },
+      ],
+   }
+
+   it("should import a new user to ILIAS", async function () {
+      const res = await libIlias.importIliasUser(user)
+      console.dir(res, {depth:null})
+      // expect(res.method).to.equal("DELETE")
+      // expect(res.command).to.equal("deleteUser")
+      // expect(res.obj_id).to.equal(obj_id)
+      // expect(res.status).to.equal("ok")
+   })
+
+})

--
Gitblit v1.8.0