From ece59f8adfbfc6427585ee4e68a6c0a147459efb Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Sat, 12 Jul 2025 16:02:32 +0000
Subject: [PATCH] adding better logging

---
 php/globus-ilias-rest/api.php |  127 +++++++++++++++++++++++++++++++++++-------
 1 files changed, 105 insertions(+), 22 deletions(-)

diff --git a/php/globus-ilias-rest/api.php b/php/globus-ilias-rest/api.php
index 3be9bb7..f79ea9d 100644
--- a/php/globus-ilias-rest/api.php
+++ b/php/globus-ilias-rest/api.php
@@ -21,7 +21,6 @@
     $obj_id = (int) $_GET["obj_id"];
     $dry = $_GET["dry"]; # "0" = false, "1" = true
 
-
     $res = array(
         "method" => $method,
         "command" => $command,
@@ -50,12 +49,23 @@
                     $res["status"] = "ok";
                     break;
                 }
+            //// USER //////////////////////////////////////////////////////////
+            case "getUser":
+                if($method == "GET") {
+                    $usr_id = (int) $_GET["usr_id"];
+                    $res["usr_id"] = $usr_id;
+                    $usr = getUser($usr_id);
+                    $res["data"] = $usr;
+                    $res["status"] = "ok";
+                    break;
+                }
             case "importUser":
                 if ($method == "POST") {
                     $body = file_get_contents('php://input');
                     $data = json_decode($body, true);
                     $res["usr_id"] = importUser($data);
                     $res["status"] = "ok";
+                    $res["msg"] = "User Import OK";
                     break;
                 }
             case "deleteUser":
@@ -64,11 +74,36 @@
                     $res["status"] = "ok";
                     break;
                 }
-            case "deleteTeilnahme":
+            /////// Kurs ////////////////////////////////////////////////////////////////
+            case "createKurs":
+                if ($method == "POST") {
+                    $body = file_get_contents('php://input');
+                    $data = json_decode($body, true);
+                    $res["ref_id"] = createKurs($data);
+                    $res["status"] = "ok";
+                    $res["msg"] = "User Import OK";
+                    break;
+                }
+            //// Anmelden / Abmelden //////////////////////////////////////////////////////////
+            case "anmelden": // params: usr_id, course_id, role
+                if ($method == "POST") {
+                    $usr_id = (int) $_GET["usr_id"];
+                    $course_id = (int) $_GET["course_id"];
+                    $role = (int) $_GET["role"];
+
+                    $res2 = anmelden($usr_id, $course_id, $role);
+                    $res["status"] = "ok";
+                    $res["msg"] = "Anmelden OK";
+                    $res["params"] = array("usr_id"=>$usr_id, "course_id"=>$course_id, "role"=> $role);
+                    $res["res2"] = $res2;
+                    break;
+                }
+            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;
                 }
@@ -92,12 +127,59 @@
 
 ###############################
 
+function getUser($usr_id) {
+    $usr = ilObjectFactory::getInstanceByObjId($usr_id);
+    return $usr;
+}
+
 function importUser($data) {
     $user = new ilObjUser();
     $user->assignData($data);
     $usr_id = $user->create();
+    $user->setTimeLimitUnlimited(true);
+    $user->setActive(true);
     $user->saveAsNew();
+    // udf expects:
+    //      udf: { // ACHTUNG: Die Nummer enspricht der id in der Tabelle udf_definition und kann je nach Reihenfolge anders sein!
+    //         1: "Markt UDF",
+    //         2: "Marktnummer UDF",
+    //         3: "Personal UDF",
+    //      },
+    $user->setUserDefinedData($data["udf"]); // affo12345
+    $user->updateUserDefinedFields();
+
+    // Rolle zuweisen
+    global $DIC;
+    $rbacadmin = $DIC->rbac()->admin();
+    $rbacadmin->assignUser($data["role"], $usr_id);
+
     return $usr_id;
+}
+
+function createKurs($data) {
+// TODO ätzend kompliziert
+// ilSoapCourseAdministration->addCourse()
+// beispile wie Kurs erstellt wird in : ilECSCourseCreationHandler->createParallelCourse
+//     $course = new ilObjCourse();
+//     $course->create();
+    throw new Exception("not implemented");
+}
+
+// ACHTUNG course_id muss obj_id sein!
+// die Rolle muss aus dem Kurs gelesen werden
+function anmelden($usr_id, $course_id) {
+    $course = ilObjectFactory::getInstanceByObjId($course_id);
+    $membersObject = $course->getMembersObject();
+    $membersObject->readParticipants();
+    $role = $membersObject::IL_CRS_MEMBER;
+    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);
+    // TODO auch aus Rolle löschen - wird eigentlich gemacht in ilCourseParticipants->delete()
 }
 
 function deleteUser($obj_id, $dry)
@@ -113,23 +195,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