From 183d3e0c669aa8882c994c8ef756e1ac1d61fd7d Mon Sep 17 00:00:00 2001 From: undisclosed Date: Sun, 29 Jan 2023 16:01:40 +0000 Subject: [PATCH] Funktion 'naechster Titel' beim Abspielen von Abspiellisten eingebaut --- src/de/uhilger/tango/api/ListHandler.java | 48 ++++++++++++++++++++++++++++++++++++------------ 1 files changed, 36 insertions(+), 12 deletions(-) diff --git a/src/de/uhilger/tango/api/ListHandler.java b/src/de/uhilger/tango/api/ListHandler.java index 0cd7b3b..490fd4c 100644 --- a/src/de/uhilger/tango/api/ListHandler.java +++ b/src/de/uhilger/tango/api/ListHandler.java @@ -25,7 +25,6 @@ import de.uhilger.tango.entity.Entity; import de.uhilger.tango.entity.Titel; import de.uhilger.tango.store.FileStorage; -import java.io.File; import java.io.IOException; import java.util.List; import java.util.logging.Logger; @@ -33,14 +32,16 @@ /** * Der ListHandler bearbeitet HTTP-Anfragen zu Abspiellisten * - * GET /mz/api/alist/[pl-name] die Titel-Objekte der Liste [pl-name] liefern - * PUT /mz/api/alist/[pl-name] den Titel im Body anfuegen an die Liste [pl-name] - * PUT /mz/api/alist/[pl-name]/[nr] an der Position nr der Liste [pl-name] den Titel im Body einfuegen - * PUT /mz/api/alist/[pl-name]/[nrVon]/[nrNach] den Titel von seiner aktuellen Position an eine + * GET /tango/api/alist/[pl-name] die Titel-Objekte der Liste [pl-name] liefern + * GET /tango/api/alist/[pl-name]/m3u eine einfache Playlist im M3U-Format ausgeben + * GET /tango/api/alist/[pl-name]/[nr] den Titel mit der Nummer [nr] abrufen + * + * PUT /tango/api/alist/[pl-name] den Titel im Body anfuegen an die Liste [pl-name] + * PUT /tango/api/alist/[pl-name]/[nr] an der Position nr der Liste [pl-name] den Titel im Body einfuegen + * PUT /tango/api/alist/[pl-name]/[nrVon]/[nrNach] den Titel von seiner aktuellen Position an eine * andere Position der Liste [pl-name] verschieben - * GET /mz/api/alist/[pl-name]/m3u - * DELETE /mz/api/alist/[pl-name]/[nr] den Titel an der Position [nr] aus der Liste [pl-name] entfernen - * DELETE /mz/api/alist/[pl-name]/alle alle Titel aus der Liste [pl-name] entfernen + * DELETE /tango/api/alist/[pl-name]/[nr] den Titel an der Position [nr] aus der Liste [pl-name] entfernen + * DELETE /tango/api/alist/[pl-name]/alle alle Titel aus der Liste [pl-name] entfernen * * TODO (2.1.2023): * - Liste ab Titel spielen @@ -71,7 +72,12 @@ headers.add("Content-Type", "application/m3u"); return getM3u(e, elems[4]); } else { - return "ungueltig"; + try { + int index = Integer.parseInt(elems[5]); + return getTitel(elems[4], index); + } catch(NumberFormatException ex) { + return "ungueltig"; + } } } else { String plname = elems[elems.length - 1]; @@ -90,12 +96,13 @@ List<Titel> titelListe = liste.getTitel(); for(Titel titel : titelListe) { - - sb.append("http://hsrv:9090/tango"); + String server = getEinstellung(fs, + getResString(MediaSteuerung.RB_HOST), MediaSteuerung.DEFAULT_HOST); + sb.append(server); sb.append(titel.getKatalogUrl()); sb.append(titel.getPfad()); sb.append(titel.getName()); - sb.append("\n"); + sb.append(Server.NEWLINE); } } return sb.toString(); @@ -122,6 +129,23 @@ return response; } + private String getTitel(String plname, int index) { + FileStorage fs = new FileStorage(conf); + Entity entity = fs.read(FileStorage.ST_ABSPIELLISTE, plname); + String response = "eom"; + if(entity instanceof Abspielliste) { + Abspielliste aliste = (Abspielliste) entity; + //String titelJson = bodyLesen(e); + List<Titel> titelListe = aliste.getTitel(); + if(index < titelListe.size()) { + Titel titel = aliste.getTitel().get(index); + Gson gson = new Gson(); + response = gson.toJson(titel); + } + } + return response; + } + /** * Den Titel im Body von seiner aktuellen Position an die angegebene * Position setzen. Der Titel an der angegebenen Position rueckt nach -- Gitblit v1.9.3