From 0b0a4bb1f5b6814525e82b5e684a6968e9e9120c Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Wed, 25 Jun 2025 07:55:22 +0000
Subject: [PATCH] GS-2169

---
 php/globus-ilias-rest/api.php |   51 ++++++++++++++++++++++++++++++---------------------
 1 files changed, 30 insertions(+), 21 deletions(-)

diff --git a/php/globus-ilias-rest/api.php b/php/globus-ilias-rest/api.php
index aa6a546..d2b1b45 100644
--- a/php/globus-ilias-rest/api.php
+++ b/php/globus-ilias-rest/api.php
@@ -87,11 +87,13 @@
                     $res["status"] = "ok";
                     break;
                 }
-            case "deleteTeilnahme":
+//             case "deleteTeilnahme":
+            case "abmelden":
                 if ($method == "DELETE") {
                     $usr_id = (int) $_GET["usr_id"];
-                    $res["usr_id"] = $usr_id;
-                    $res["msg"] = deleteTeilnahme($obj_id, $usr_id, $dry);
+                    $res["usr_id"] = (int) $usr_id;
+                    $course_id = (int) $_GET["course_id"];
+                    $res["msg"] = abmelden($usr_id, $course_id);
                     $res["status"] = "ok";
                     break;
                 }
@@ -153,6 +155,12 @@
     return $membersObject->add($usr_id, $role);
 }
 
+function abmelden($usr_id, $course_id) {
+    $course = ilObjectFactory::getInstanceByObjId($course_id);
+    $membersObject = $course->getMembersObject();
+    return $membersObject->delete($usr_id);
+}
+
 function deleteUser($obj_id, $dry)
 {
     $usr = ilObjectFactory::getInstanceByObjId($obj_id);
@@ -166,23 +174,24 @@
     }
 }
 
-function deleteTeilnahme($obj_id, $usr_id, $dry) {
-    # beim Löschen durch den Kurs wird zwar die Teilnahme gelöscht, aber nicht die Rollenzugehörigkeit
-//     $course = ilObjectFactory::getInstanceByObjId($obj_id);
-
-    $parti = ilCourseParticipant::_getInstanceByObjId($obj_id, $usr_id); ## Achtung die usr_id hier ist Admin id??
-    #return "parti.isParticipant() = {$parti->isParticipant()}";
-
-    $msg = "deleted user({$usr_id}) teilnahme for course '{$course->getTitle()}' ({$obj_id})";
-    if ($dry == "0") {
-        #$course->_deleteUser($usr_id);
-        #$course->deleteUser($usr_id); ## undefined
-        $parti->delete($usr_id);
-        return $msg;
-    } else {
-        $msg = "DRY:: ".$msg;
-        return $msg;
-    }
-}
+// ACHTUNG Funktion "abmelden" benutzen
+// function deleteTeilnahme($obj_id, $usr_id, $dry) {
+//     # beim Löschen durch den Kurs wird zwar die Teilnahme gelöscht, aber nicht die Rollenzugehörigkeit
+// //     $course = ilObjectFactory::getInstanceByObjId($obj_id);
+//
+//     $parti = ilCourseParticipant::_getInstanceByObjId($obj_id, $usr_id); ## Achtung die usr_id hier ist Admin id??
+//     #return "parti.isParticipant() = {$parti->isParticipant()}";
+//
+//     $msg = "deleted user({$usr_id}) teilnahme for course '{$course->getTitle()}' ({$obj_id})";
+//     if ($dry == "0") {
+//         #$course->_deleteUser($usr_id);
+//         #$course->deleteUser($usr_id); ## undefined
+//         $parti->delete($usr_id);
+//         return $msg;
+//     } else {
+//         $msg = "DRY:: ".$msg;
+//         return $msg;
+//     }
+// }
 
 ?>

--
Gitblit v1.8.0