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 | 49 +++++++++++++++++++++++++++++++++---------------- 1 files changed, 33 insertions(+), 16 deletions(-) diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java index 80b5214..0806ed9 100644 --- a/src/de/uhilger/avdirektor/handler/PlayHandler.java +++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java @@ -52,25 +52,42 @@ 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.FINE, "RequestURI.getPath: {0}", t.getRequestURI().getPath()); - Map map = getQueryMap(t); - Set keys = map.keySet(); - StringBuffer buf = new StringBuffer(); - buf.append("play"); - buf.append(System.lineSeparator()); - keys.forEach((Object key) -> { - buf.append("key: "); - buf.append(key); - buf.append(System.lineSeparator()); - buf.append("value: "); - buf.append(map.get(key)); - buf.append(System.lineSeparator()); - logger.log(Level.FINE, "key {0} value {1}", new Object[]{key, map.get(key)}); - }); + logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString()); - String response = buf.toString(); + 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 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()); -- Gitblit v1.9.3