From a5dcd68d7f47302abdc6c479269c79edf6d21686 Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Fri, 11 Jul 2025 14:33:28 +0000
Subject: [PATCH] GS-2174

---
 lib/db.js |   40 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 38 insertions(+), 2 deletions(-)

diff --git a/lib/db.js b/lib/db.js
index bee8d63..3bc907c 100644
--- a/lib/db.js
+++ b/lib/db.js
@@ -44,7 +44,9 @@
 
    getUdf,
 
-   getMemberRoleForCourse,
+   getKursTeilnehmerRolle,
+   getKursTeilnehmerByRole,
+   getKursRoles,
 
    setStatus,
 }
@@ -172,6 +174,10 @@
 
 /////// obj_id / ref_id ////////////////////////////////////////////////////////////////
 
+/**
+ * @param refId
+ * @returns {Promise<{ref_id,obj_id}|undefined>}
+ */
 async function getObjIdFromRefId (refId) {
    const pool = await poolP
    const [results] = await pool.query(
@@ -402,7 +408,7 @@
 
 /////// ROLLEN ////////////////////////////////////////////////////////////////
 
-async function getMemberRoleForCourse (obj_id) {
+async function getKursTeilnehmerRolle (obj_id) {
    const pool = await poolP
    const q = `SELECT obj_id, title, description
               from object_data od
@@ -420,6 +426,36 @@
    }
 }
 
+async function getKursTeilnehmerByRole (obj_id) {
+   const pool = await poolP
+   const q = `
+       SELECT obj_id as role_id, ru.usr_id, ud.firstname, ud.lastname
+       FROM ${database}.object_data od
+                INNER JOIN ${database}.rbac_ua ru ON ru.rol_id = od.obj_id
+                INNER JOIN ${database}.usr_data ud ON ud.usr_id = ru.usr_id
+       WHERE type = "role" #AND title LIKE 'il_crs_member_157'
+                AND od.description LIKE 'Member%${obj_id}'
+   `
+   const [results] = await pool.query(q)
+   return results
+}
+
+async function getKursRoles (ref_id) {
+   const pool = await poolP
+   const q = `
+       SELECT pa.rol_id, or2.ref_id, or2.obj_id, od2.type, od2.title, od2.description
+       FROM ${database}.rbac_pa pa
+                INNER JOIN ${database}.object_reference or2 ON or2.ref_id = pa.ref_id
+                INNER JOIN ${database}.object_data od ON od.obj_id = or2.obj_id
+                INNER JOIN ${database}.object_data od2 ON od2.obj_id = pa.rol_id
+       WHERE pa.ref_id = ${ref_id}
+   `
+   const [results] = await pool.query(q)
+   return results
+}
+
+
+
 /////// STATUS ////////////////////////////////////////////////////////////////
 
 /**

--
Gitblit v1.8.0