From d87115324de76811165e7a5071cf6340a00ca00e Mon Sep 17 00:00:00 2001
From: alex <alex@alexloehr.net>
Date: Thu, 18 Sep 2025 14:47:28 +0000
Subject: [PATCH] GS-2317

---
 vue/src/lib/api.js |   79 ++++++++++++++++++++++++++++++++++++---
 1 files changed, 73 insertions(+), 6 deletions(-)

diff --git a/vue/src/lib/api.js b/vue/src/lib/api.js
index 3a88ee8..35959cf 100644
--- a/vue/src/lib/api.js
+++ b/vue/src/lib/api.js
@@ -1,19 +1,86 @@
-const apiToken = "jiuGfr432898D90290kjfsldkfn3hh8F"
-export const apiBase = "/api/"
-export const iliasBase = "http://localhost:8060"
+import {computed, ref} from "vue"
+import {useSessionStorage} from "@vueuse/core"
+
+/////// API TOKEN ////////////////////////////////////////////////////////////////
+
+let apiToken = useSessionStorage("apiToken", "")
+export const apiTokenValid = computed(() => apiToken.value !== null && apiToken.value !== "")
+
+export function setApiToken (token) {
+   apiToken.value = token
+}
+
+export function deleteApiToken () {
+   apiToken.value = null
+}
+
+/////// CONSTANTS ////////////////////////////////////////////////////////////////
+
+export const apiBase = import.meta.env.VITE_API_BASE
+export const iliasBase = import.meta.env.VITE_ILIAS_BASE
+export const popcornBase = import.meta.env.VITE_POPCORN_BASE2
+export const routerBase = import.meta.env.VITE_ROUTER_BASE
+
+/////// KURS ////////////////////////////////////////////////////////////////
+
+export async function getKurse () {
+   let resKurs = await fetch(`${apiBase}/kurs?token=${apiToken.value}`)
+   return await resKurs.json()
+}
 
 export async function getKurs (kursId) {
-   let resKurs = await fetch(`${apiBase}/kurs/${kursId}?token=${apiToken}`)
+   let resKurs = await fetch(`${apiBase}/kurs/${kursId}?token=${apiToken.value}`)
    return await resKurs.json()
 }
 
 export async function getKursItems (kursId) {
-   let resKurs = await fetch(`${apiBase}/kurs/items/${kursId}?token=${apiToken}`)
+   let resKurs = await fetch(`${apiBase}/kurs/items/${kursId}?token=${apiToken.value}`)
    return await resKurs.json()
 }
 
 export async function getKursTn (kursId) {
-   let resKurs = await fetch(`${apiBase}/kurs/teilnehmer/${kursId}?token=${apiToken}`)
+   let resKurs = await fetch(`${apiBase}/kurs/${kursId}/teilnehmer?token=${apiToken.value}`)
    return await resKurs.json()
 }
 
+export async function getKursTnByRole (kursId) {
+   let resKurs = await fetch(`${apiBase}/kurs/${kursId}/teilnehmerByRole?token=${apiToken.value}`)
+   return await resKurs.json()
+}
+
+export async function getKursRoles (kursId) {
+   let resKurs = await fetch(`${apiBase}/kurs/${kursId}/roles?token=${apiToken.value}`)
+   return await resKurs.json()
+}
+
+/////// USER ////////////////////////////////////////////////////////////////
+
+export async function getUsers (offset, limit, search) {
+   const res = await fetch(`${apiBase}/user?offset=${offset}&limit=${limit}&search=${search}&token=${apiToken.value}`)
+   return res.json()
+}
+
+export async function getUser (userId) {
+   const res = await fetch(`${apiBase}/user/userid/${userId}?token=${apiToken.value}`)
+   return await res.json()
+}
+
+export async function getUserTeilnahmen (userId) {
+   const res = await fetch(`${apiBase}/user/teilnahmen/${userId}?token=${apiToken.value}`)
+   return await res.json()
+}
+
+/////// SEARCH ////////////////////////////////////////////////////////////////
+
+export async function searchUsers (query) {
+   const res = await fetch(`${apiBase}/search/user?search=${query}&token=${apiToken.value}`)
+   return await res.json()
+}
+
+export async function reindex () {
+   let url = `${apiBase}/search/reindex?token=${apiToken.value}`
+   const res = await fetch(url, {method: "POST"})
+   const data = await res.json()
+   console.log(data)
+   return data
+}

--
Gitblit v1.8.0