From a6081c2b65b0463fdc640875833527f41fa9ded6 Mon Sep 17 00:00:00 2001 From: undisclosed Date: Sun, 22 Jan 2023 16:11:12 +0000 Subject: [PATCH] Erste Version fertig: JavaScript-Player fuer 'hier spielen' bei Abspiellisten --- src/de/uhilger/tango/api/ListHandler.java | 65 ++++++++++++++++++++++++++++++-- 1 files changed, 61 insertions(+), 4 deletions(-) diff --git a/src/de/uhilger/tango/api/ListHandler.java b/src/de/uhilger/tango/api/ListHandler.java index efb5d4e..c3ab471 100644 --- a/src/de/uhilger/tango/api/ListHandler.java +++ b/src/de/uhilger/tango/api/ListHandler.java @@ -18,12 +18,14 @@ package de.uhilger.tango.api; import com.google.gson.Gson; +import com.sun.net.httpserver.Headers; import com.sun.net.httpserver.HttpExchange; import de.uhilger.tango.Server; import de.uhilger.tango.entity.Abspielliste; 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; @@ -32,6 +34,9 @@ * Der ListHandler bearbeitet HTTP-Anfragen zu Abspiellisten * * GET /mz/api/alist/[pl-name] die Titel-Objekte der Liste [pl-name] liefern + * GET /mz/api/alist/[pl-name]/m3u eine einfache Playlist im M3U-Format ausgeben + * GET /mz/api/alist/[pl-name]/[nr] den Titel mit der Nummer [nr] abrufen + * * 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 @@ -62,10 +67,45 @@ protected String get(HttpExchange e) { String path = e.getRequestURI().toString(); String[] elems = path.split(Server.SLASH); - String plname = elems[elems.length - 1]; - FileStorage fs = new FileStorage(conf); - String json = fs.readJson(FileStorage.ST_ABSPIELLISTE, plname); - return embedInCustomType(json, FileStorage.ST_ABSPIELLISTE); + if(elems.length > 5) { + if(elems[5].endsWith("m3u")) { + Headers headers = e.getResponseHeaders(); + headers.add("Content-Type", "application/m3u"); + return getM3u(e, elems[4]); + } else { + try { + int index = Integer.parseInt(elems[5]); + return getTitel(elems[4], index); + } catch(NumberFormatException ex) { + return "ungueltig"; + } + } + } else { + String plname = elems[elems.length - 1]; + FileStorage fs = new FileStorage(conf); + String json = fs.readJson(FileStorage.ST_ABSPIELLISTE, plname); + return embedInCustomType(json, FileStorage.ST_ABSPIELLISTE); + } + } + + private String getM3u(HttpExchange e, String plname) { + StringBuilder sb = new StringBuilder(); + FileStorage fs = new FileStorage(conf); + Entity entity = fs.read(FileStorage.ST_ABSPIELLISTE, plname); + if (entity instanceof Abspielliste) { + Abspielliste liste = (Abspielliste) entity; + List<Titel> titelListe = liste.getTitel(); + + for(Titel titel : titelListe) { + + sb.append("http://hsrv:9090/tango"); + sb.append(titel.getKatalogUrl()); + sb.append(titel.getPfad()); + sb.append(titel.getName()); + sb.append("\n"); + } + } + return sb.toString(); } @Override @@ -89,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