From 2dd7a5b331b57db5c7aa5bef9540e3e198848060 Mon Sep 17 00:00:00 2001 From: ulrich Date: Thu, 01 Apr 2021 14:04:54 +0000 Subject: [PATCH] weiterspielen (erste Fassung fertig) --- src/de/uhilger/avdirektor/handler/PlayHandler.java | 131 +++++++++++++++++++++---------------------- 1 files changed, 65 insertions(+), 66 deletions(-) diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java index 5ceda70..ce37932 100644 --- a/src/de/uhilger/avdirektor/handler/PlayHandler.java +++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java @@ -1,88 +1,87 @@ +/* + 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.File; import java.io.IOException; -import java.io.OutputStream; -import java.util.HashMap; -import java.util.Set; import java.util.logging.Level; import java.util.logging.Logger; +import org.apache.commons.io.FileUtils; /** - * 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()); + 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("-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; + } + + @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")); + } 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 response = "play"; - t.sendResponseHeaders(200, response.length()); - OutputStream os = t.getResponseBody(); - os.write(response.getBytes()); - os.close(); - + String antwort = App.getPlayer().abspielen( + getParam(map, "titel"), params, getParam(map, "r"), "1"); + logger.log(Level.FINE, antwort); + return antwort; } } -- Gitblit v1.9.3