From 15ed25a13d5f8340dfecef50d23173aef45af125 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Wed, 31 Mar 2021 19:34:01 +0000
Subject: [PATCH] OMXPlayer Log (in Arbeit)

---
 src/de/uhilger/avdirektor/handler/PlayHandler.java |  129 +++++++++++++++++++-----------------------
 1 files changed, 59 insertions(+), 70 deletions(-)

diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java
index 5ceda70..aa32fcd 100644
--- a/src/de/uhilger/avdirektor/handler/PlayHandler.java
+++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java
@@ -1,88 +1,77 @@
+/*
+    AV-Direktor - Control OMXPlayer on Raspberry Pi via HTTP
+    Copyright (C) 2021  Ulrich Hilger
+
+    This program is free software: you can redistribute it and/or modify
+    it under the terms of the GNU Affero General Public License as
+    published by the Free Software Foundation, either version 3 of the
+    License, or (at your option) any later version.
+
+    This program is distributed in the hope that it will be useful,
+    but WITHOUT ANY WARRANTY; without even the implied warranty of
+    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+    GNU Affero General Public License for more details.
+
+    You should have received a copy of the GNU Affero General Public License
+    along with this program.  If not, see <https://www.gnu.org/licenses/>.
+*/
+
 package de.uhilger.avdirektor.handler;
 
 import com.sun.net.httpserver.HttpExchange;
-import com.sun.net.httpserver.HttpHandler;
-import java.io.IOException;
-import java.io.OutputStream;
-import java.util.HashMap;
-import java.util.Set;
+import de.uhilger.avdirektor.App;
 import java.util.logging.Level;
 import java.util.logging.Logger;
 
 /**
- * Es koennen mehrere Varianten beim Abspielen verwendet werden.
+ * Play
  * 
- * Abspielen eines Titels
- * abspielenMitParameternUndRueckmeldung(urlStr, null, null, 1)
+ * rpi4-az:9090/avd/play?titel=/Filme/S/sound_city.m4v&th=60&ti=60&o=local
  * 
- * Abspielen eines Titels mit Rueckmeldung (z.B. fuer Playlisten)
- * abspielenMitParameternUndRueckmeldung(urlStr, null, meldeUrlStr, 1)
- * 
- * Abspielen mit Parametern
- * abspielenMitParameternUndRueckmeldung(urlStr, parameter, null, 1)
- * 
- * Abspielen mit Parametern und Rueckmeldung
- * abspielenMitParameternUndRueckmeldung(urlStr, parameter, meldeUrlStr, 1)
- * 
- * Token wird zur Zeit nicht genutzt, hier kann einfach eine beliebige
- * Zahl uebergeben werden.
- * 
- * Die drei Parameter t, p, r werden als Query im URL erwartet. Beispiele:
- * t = titel
- * p = parameter
- * r = url fuer rueckmeldung
- * 
- * 
- * /avd/play?t=/Pfad/zum/Titel.mp3
- * /avd/play?t=/Pfad/zum/Titel.mp3&p=-o=local%20-timeout=60
- * /avd/play?t=/Pfad/zum/Titel.mp3&r=http:/uhilger.de/rueckmelde/pfad
- * /avd/play?t=/Pfad/zum/Titel.mp3&p=-o=local%20-timeout=60&r=http:/uhilger.de/rueckmelde/pfad
- * 
- * String urlStr, String parameter, String meldeUrlStr, String token
- * 
- * 
- * 
- * 
+ *  OMXPlayer.abspielenMitParameternUndRueckmeldung(
+ *    String urlStr, String parameter, String meldeUrlStr, String token)
  *
+ *  Parameter des Aufrufs play als query (th threshold, ti timeout)
+ *
+ *  ?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
+ * 
  * @author ulrich
  */
-public class PlayHandler extends OMXPlayer implements HttpHandler {
+public class PlayHandler extends CmdHandler {
   
   private static final Logger logger = Logger.getLogger(PlayHandler.class.getName());
 
-  @Override
-  public void handle(HttpExchange t) throws IOException {
-    logger.log(Level.INFO, "RequestURI.getPath: {0}", t.getRequestURI().getPath());
-    
-    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));
-    });
-    
-        
-    String response = "play";
-    t.sendResponseHeaders(200, response.length());
-    OutputStream os = t.getResponseBody();
-    os.write(response.getBytes());
-    os.close();    
-    
+  public PlayHandler(String cmd) {
+    super(cmd);
   }
 
+  @Override
+  protected String process(HttpExchange t, String params) {
+    String antwort = App.getPlayer().abspielen( 
+            getParam(map, "titel"), params, getParam(map, "r"), "1");    
+    logger.log(Level.FINE, antwort);
+    return antwort;
+  }
+
+  protected StringBuilder buildParams(HttpExchange t) {
+    StringBuilder params = super.buildParams(t);
+    params.append("-b -o ");
+    params.append(getParam(map, "o"));
+    params.append(" --threshold ");
+    params.append(getParam(map, "th"));
+    params.append(" --timeout ");
+    params.append(getParam(map, "ti"));
+    String log = getParam(map, "log");
+    if(log != null && log.equalsIgnoreCase("true")) {
+      params.append(" --genlog");
+    }
+    return params;
+  }
+  
 }

--
Gitblit v1.9.3