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 |   77 +++++++++++++++++++++++++++++++++-----
 1 files changed, 67 insertions(+), 10 deletions(-)

diff --git a/src/de/uhilger/tango/api/ListHandler.java b/src/de/uhilger/tango/api/ListHandler.java
index efb5d4e..490fd4c 100644
--- a/src/de/uhilger/tango/api/ListHandler.java
+++ b/src/de/uhilger/tango/api/ListHandler.java
@@ -18,6 +18,7 @@
 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;
@@ -31,13 +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
- * 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
@@ -62,10 +66,46 @@
   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) {
+        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(Server.NEWLINE);
+      }
+    }
+    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