From 438c31692792fcd4045eb6c437eac1a086713460 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Thu, 22 Apr 2021 15:39:33 +0000
Subject: [PATCH] Option -b des omxplayer entfernt
---
src/de/uhilger/avdirektor/handler/PlayHandler.java | 163 +++++++++++++++++++++++++++++++----------------------
1 files changed, 95 insertions(+), 68 deletions(-)
diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java
index 5ceda70..3cbcd0e 100644
--- a/src/de/uhilger/avdirektor/handler/PlayHandler.java
+++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java
@@ -1,88 +1,115 @@
+/*
+ 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 de.uhilger.avdirektor.App;
import java.io.IOException;
-import java.io.OutputStream;
-import java.util.HashMap;
-import java.util.Set;
+import java.nio.file.FileSystem;
+import java.nio.file.FileSystems;
+import java.nio.file.FileVisitResult;
+import java.nio.file.Files;
+import java.nio.file.Path;
+import java.nio.file.SimpleFileVisitor;
+import java.nio.file.attribute.BasicFileAttributes;
import java.util.logging.Level;
import java.util.logging.Logger;
/**
- * Es koennen mehrere Varianten beim Abspielen verwendet werden.
- *
- * Abspielen eines Titels
- * abspielenMitParameternUndRueckmeldung(urlStr, null, null, 1)
- *
- * 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
- *
- *
- *
- *
+ * Play
+ *
+ * rpi4-az:9090/avd/play?titel=/Filme/S/sound_city.m4v&th=60&ti=60&o=local
+ *
+ * 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());
+ public PlayHandler(String cmd) {
+ super(cmd);
+ }
- 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]);
+ protected StringBuilder buildParams(HttpExchange t) {
+ StringBuilder params = super.buildParams(t);
+ 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 log = getParam(map, "log");
+ if (log != null && log.equalsIgnoreCase("true")) {
+ params.append(" --genlog");
+ }
+ return params;
+ }
+
+ @Override
+ protected String process(HttpExchange t, String params) {
+ if (cmd.equalsIgnoreCase(OMXPlayer.F_PLAY)) {
+ try {
+ //FileUtils.deleteDirectory(new File(System.getProperty("omx.wd"), "omx-logs"));
+ FileSystem fs = FileSystems.getDefault();
+ Path path = fs.getPath(System.getProperty("omx.wd"), "omx-logs");
+ deleteDirectory(path);
+ //Files.delete(path);
+ } catch (IOException ex) {
+ logger.log(Level.SEVERE, null, ex);
}
}
- Set keys = map.keySet();
- keys.forEach(key -> {
- logger.info("key " + key + " value " + map.get(key));
+ String antwort = App.getPlayer().abspielen(
+ getParam(map, "titel"), params, getParam(map, "r"), "1");
+ logger.log(Level.FINE, antwort);
+ return antwort;
+ }
+
+ protected void deleteDirectory(Path start) throws IOException {
+ Files.walkFileTree(start, new SimpleFileVisitor<Path>() {
+ @Override
+ public FileVisitResult visitFile(Path file, BasicFileAttributes attrs)
+ throws IOException {
+ Files.delete(file);
+ return FileVisitResult.CONTINUE;
+ }
+
+ @Override
+ public FileVisitResult postVisitDirectory(Path dir, IOException e)
+ throws IOException {
+ if (e == null) {
+ Files.delete(dir);
+ return FileVisitResult.CONTINUE;
+ } else {
+ // directory iteration failed
+ throw e;
+ }
+ }
});
-
-
- String response = "play";
- t.sendResponseHeaders(200, response.length());
- OutputStream os = t.getResponseBody();
- os.write(response.getBytes());
- os.close();
-
}
}
--
Gitblit v1.9.3