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