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