From 1ef98569623b58f8b4e2b5863cea02bfb1e91a98 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Thu, 21 Nov 2024 22:38:22 +0000
Subject: [PATCH] 'Hier spielen' berichtigt

---
 src/de/uhilger/tango/api/ListHandler.java |   73 ++++++++++++++++++++++++++++++------
 1 files changed, 60 insertions(+), 13 deletions(-)

diff --git a/src/de/uhilger/tango/api/ListHandler.java b/src/de/uhilger/tango/api/ListHandler.java
index 0cd7b3b..341456c 100644
--- a/src/de/uhilger/tango/api/ListHandler.java
+++ b/src/de/uhilger/tango/api/ListHandler.java
@@ -20,27 +20,31 @@
 import com.google.gson.Gson;
 import com.sun.net.httpserver.Headers;
 import com.sun.net.httpserver.HttpExchange;
+import de.uhilger.tango.PlaylistListener;
 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.ArrayList;
+import java.util.Iterator;
 import java.util.List;
 import java.util.logging.Logger;
 
 /**
  * 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
@@ -57,8 +61,11 @@
   
   private String conf;
   
+  private List<PlaylistListener> listeners;
+  
   public ListHandler(String conf) {
     this.conf = conf;
+    listeners = new ArrayList();
   }
 
   @Override
@@ -71,7 +78,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 +102,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();
@@ -120,6 +133,23 @@
         break;
     }
     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;    
   }
   
   /**
@@ -218,7 +248,9 @@
       if(titelStr.equalsIgnoreCase(ALLE_TITEL)) {
         liste.getTitel().clear();
       } else {
-        liste.getTitel().remove(Integer.parseInt(elems[elems.length-1]));
+        int idx = Integer.parseInt(elems[elems.length-1]);
+        liste.getTitel().remove(idx);
+        sendRemovalInfo(liste.getName(), idx);
       }
       fs.write(liste, true);
       return true;
@@ -227,4 +259,19 @@
     }
   }
   
+  private void sendRemovalInfo(String listName, int titleIndex) {
+    Iterator<PlaylistListener> i = listeners.iterator();
+    while(i.hasNext()) {
+      PlaylistListener l = i.next();
+      l.titleRemoved(listName, titleIndex);
+    }
+  }
+  
+  public void addPlaylistListener(PlaylistListener listener) {
+    this.listeners.add(listener);
+  }
+  
+  public void removePlaylistListener(PlaylistListener listener) {
+    this.listeners.remove(listener);
+  }
 }

--
Gitblit v1.9.3