REST Service for POPCORN - ILIAS
alex
2025-06-20 8f37d4c717f0ff348ee4d23fb75ca6e017705603
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,15 +93,17 @@
      obj_id,
      // dry: "1",
      dry: dry ? "1" : "0",
      token: iliastoken,
   })
   let url2 = `${url}?${sp.toString()}`
   const res = await fetch(url2, {method: "DELETE"})
   const data = await res.json()
   // TODO update search index
   return data //
}
async function deleteAllUsers () {
   const users = await db.getUsers()
   const {data: users} = await db.getUsers(0, 100000)
   const res = {
      command: "deleteAllUsers",
      start: new Date(),
@@ -45,6 +119,7 @@
   }
   res.end = new Date()
   res.duration = res.end - res.start
   // TODO update search index
   return res
}
@@ -55,6 +130,7 @@
      obj_id,
      usr_id,
      dry: dry ? "1" : "0",
      token: iliastoken,
   })
   let url2 = `${url}?${sp.toString()}`
   console.log("libIlias.deleteTeilnahme >>>", url2)
@@ -67,3 +143,4 @@
      throw ex
   }
}