From 2d56dc168ebe5cadbbef53b3b8853d87bc2cfbba Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Wed, 18 Jun 2025 18:25:48 +0000
Subject: [PATCH] GS-2166

---
 lib/libIlias.js |   28 +++++++++++++++++++++++++++-
 1 files changed, 27 insertions(+), 1 deletions(-)

diff --git a/lib/libIlias.js b/lib/libIlias.js
index d20ec5e..3badcb9 100644
--- a/lib/libIlias.js
+++ b/lib/libIlias.js
@@ -2,6 +2,7 @@
 
 module.exports = {
    deleteUser,
+   deleteAllUsers,
    deleteTeilnahme,
 }
 
@@ -9,7 +10,8 @@
 
 const settings = require("../settings")
 const {getObjIdFromRefId} = require("./db")
-const {url} = settings.ilias
+const db = require("./db")
+const {url, iliastoken} = settings.ilias
 
 /////////////////////////////////////////////////////////////////////////
 
@@ -19,11 +21,34 @@
       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 {data: users} = await db.getUsers(0, 100000)
+   const res = {
+      command: "deleteAllUsers",
+      start: new Date(),
+      end: new Date(),
+      duration: null,
+      count: 0,
+      userIds: [],
+   }
+   for (const user of users) {
+      await deleteUser(user.usr_id)
+      res.count += 1
+      res.userIds.push(user.usr_id)
+   }
+   res.end = new Date()
+   res.duration = res.end - res.start
+   // TODO update search index
+   return res
 }
 
 async function deleteTeilnahme (ref_id, usr_id, dry = false) {
@@ -33,6 +58,7 @@
       obj_id,
       usr_id,
       dry: dry ? "1" : "0",
+      token: iliastoken,
    })
    let url2 = `${url}?${sp.toString()}`
    console.log("libIlias.deleteTeilnahme >>>", url2)

--
Gitblit v1.8.0