REST Service for POPCORN - ILIAS
alex
2025-06-25 8d33fafb3224360f49f6ebc9e1b98f4fbdc1d1ad
lib/libIlias.js
@@ -1,4 +1,5 @@
/* Lib for interacting with customized ILIAS php */
const _ = require("lodash")
const settings = require("../settings")
const {getObjIdFromRefId} = require("./db")
const db = require("./db")
@@ -8,47 +9,53 @@
/////////////////////////////////////////////////////////////////////////
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
 * {
 *         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>}
 */
@@ -58,30 +65,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
   }
}
@@ -144,3 +145,18 @@
   }
}
/////// 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()
}