From a7f0a18275d394ff92e44fcce55a511a54535787 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Mon, 22 Mar 2021 11:57:53 +0000
Subject: [PATCH] Play/Stop erste fertige Fassung

---
 src/de/uhilger/avdirektor/handler/PlayHandler.java |   60 ++++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 34 insertions(+), 26 deletions(-)

diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java
index 5ceda70..0806ed9 100644
--- a/src/de/uhilger/avdirektor/handler/PlayHandler.java
+++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java
@@ -5,7 +5,9 @@
 import java.io.IOException;
 import java.io.OutputStream;
 import java.util.HashMap;
+import java.util.Map;
 import java.util.Set;
+import java.util.function.Consumer;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 
@@ -50,39 +52,45 @@
   
   private static final Logger logger = Logger.getLogger(PlayHandler.class.getName());
 
+  /*
+  rpi4-az:9090/avd/play?titel=/Filme/S/sound_city.m4v&to=60&ti=60&o=local
+  
+    OMXPlayer.abspielenMitParameternUndRueckmeldung(
+      String urlStr, String parameter, String meldeUrlStr, String token)
+  
+    Parameter des Aufrufs play als query
+  
+    ?titel=/Filme/S/sound_city.m4v
+    &ti=60
+    &th=60
+    &o=local|hdmi|both
+    &r=http://uhilger.de/mc/api/usw
+  
+    r muss ganz wegbleiben, wenn keine Rueckmeldung gewuescht ist
+
+  */
+  
+  
   @Override
   public void handle(HttpExchange t) throws IOException {
-    logger.log(Level.INFO, "RequestURI.getPath: {0}", t.getRequestURI().getPath());
+    logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString());
     
-    String path = t.getRequestURI().getPath();
-    String[] parts = path.split("/");
-    for (String part : parts) {
-      logger.log(Level.INFO, "part: {0}", part);
-    }
-    //logger.log(Level.INFO, "query: {0}", t.getRequestURI().getQuery());
-
-    HashMap map = new HashMap();
-    String query = t.getRequestURI().getQuery();
-    if(query != null && query.length() > 0) {
-      String qParts[] = query.split("&");
-      for(String qPart : qParts) {
-        //logger.info("qPart: " + qPart);
-        String pParts[] = qPart.split("=");
-        map.put(pParts[0], pParts[1]);
-      }
-    }
-    Set keys = map.keySet();
-    keys.forEach(key -> {
-      logger.info("key " + key + " value " + map.get(key));
-    });
+    Map map = getQueryMap(t);
+    StringBuilder params = new StringBuilder();
+    params.append("-o ");
+    params.append(getParam(map, "o"));
+    params.append(" --threshold ");
+    params.append(getParam(map, "th"));
+    params.append(" --timeout ");
+    params.append(getParam(map, "ti"));
     
-        
-    String response = "play";
+    String antwort = abspielenMitParameternUndRueckmeldung( 
+            getParam(map, "titel"), params.toString(), getParam(map, "r"), "1");    
+    
+    String response = getResponseString(map, "play", antwort);
     t.sendResponseHeaders(200, response.length());
     OutputStream os = t.getResponseBody();
     os.write(response.getBytes());
     os.close();    
-    
   }
-
 }

--
Gitblit v1.9.3