| | |
| | | /* |
| | | * To change this license header, choose License Headers in Project Properties. |
| | | * To change this template file, choose Tools | Templates |
| | | * and open the template in the editor. |
| | | */ |
| | | package de.uhilger.avdirektor.handler; |
| | | |
| | | import com.sun.net.httpserver.HttpExchange; |
| | | import de.uhilger.avdirektor.App; |
| | | import de.uhilger.avdirektor.MeldeThread; |
| | | import de.uhilger.avdirektor.ProzessLauscher; |
| | |
| | | import java.io.Writer; |
| | | import java.net.HttpURLConnection; |
| | | import java.net.URL; |
| | | import java.util.HashMap; |
| | | import java.util.Map; |
| | | import java.util.Set; |
| | | import java.util.logging.Level; |
| | | import java.util.logging.Logger; |
| | | |
| | | /** |
| | | * Methoden zur Ausfuehrung des Programmes omxplayer des Raspberry Pi |
| | | * sowie zum Senden von Kommandos an eine laufende Instanz des |
| | | * omxplayer. |
| | | * |
| | | * Die Klasse OMXPlayer stellt als abstrakte Basisklasse ihre Methoden |
| | | * den Handler-Klassen zur Verfuegung. |
| | | * |
| | | * @author ulrich |
| | | */ |
| | |
| | | |
| | | private static final Logger logger = Logger.getLogger(OMXPlayer.class.getName()); |
| | | |
| | | protected String getParam(Map map, String key) { |
| | | Object o = map.get(key); |
| | | if(o != null) { |
| | | return o.toString(); |
| | | } else { |
| | | return null; |
| | | } |
| | | } |
| | | |
| | | /* |
| | | |
| | | bei etwas wie |
| | | http://rpi4-az:9090/avd/play?t=/Filme/S/sound_city.m4v&p=--timeout=60%20--threshold=60 |
| | | |
| | | sind = nicht nur nach dem Query-Parameter sondern auch in dessen Wert |
| | | |
| | | also erstmal nach & zerlegen: |
| | | t=/Filme/S/sound_city.m4v |
| | | p=--timeout=60%20--threshold=60 |
| | | |
| | | dann die Position beim ersten = von links abschneiden |
| | | |
| | | */ |
| | | protected Map getQueryMap(HttpExchange t) { |
| | | HashMap map = new HashMap(); |
| | | String query = t.getRequestURI().getQuery(); |
| | | if(query != null && query.length() > 0) { |
| | | String qParts[] = query.split("&"); |
| | | for(String qPart : qParts) { |
| | | logger.finer("qPart: " + qPart); |
| | | String pParts[] = qPart.split("="); |
| | | map.put(pParts[0], pParts[1]); |
| | | logger.finer("pParts[0]: " + pParts[0] + ", pParts[1]: " + pParts[1]); |
| | | /* |
| | | if(qPart.contains(" ")) { |
| | | String pParts[] = qPart.split(" "); |
| | | for(String pPart : pParts) { |
| | | String ppParts[] = pPart.split("="); |
| | | map.put(ppParts[0], ppParts[1]); |
| | | logger.finer("ppParts[0]: " + ppParts[0] + ", ppParts[1]: " + ppParts[1]); |
| | | } |
| | | } else { |
| | | String pParts[] = qPart.split("="); |
| | | map.put(pParts[0], pParts[1]); |
| | | logger.finer("pParts[0]: " + pParts[0] + ", pParts[1]: " + pParts[1]); |
| | | } |
| | | */ |
| | | /* |
| | | String pParts[] = qPart.split("="); |
| | | for(String pPart : pParts) { |
| | | logger.finer("pPart: " + pPart); |
| | | } |
| | | */ |
| | | } |
| | | } |
| | | return map; |
| | | } |
| | | |
| | | protected String getResponseString(Map map, String cmd, String antwort) { |
| | | Set keys = map.keySet(); |
| | | StringBuilder buf = new StringBuilder(); |
| | | 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)}); |
| | | }); |
| | | buf.append(antwort); |
| | | return buf.toString(); |
| | | } |
| | | |
| | | /** |
| | | * Einen Prozess zum Abspielen mit dem omxplayer starten |
| | | * @param t |
| | | * @param urlStr URL der Quelle, die abgespielt werden soll |
| | | * @param token |
| | | * @return Antwort des Servers |
| | | */ |
| | | /* |
| | | public String abspielen(String urlStr, String token) { |
| | | return abspielenMitParametern(urlStr, null, token); |
| | | } |
| | | */ |
| | | |
| | | /* |
| | | public String abspielenMitRueckmeldung(String urlStr, String meldeUrlStr, String token) { |
| | | return abspielenMitParameternUndRueckmeldung(urlStr, null, meldeUrlStr, token); |
| | | } |
| | | */ |
| | | |
| | | /** |
| | | * Einen Prozess zum Abspielen mit dem omxplayer starten |
| | |
| | | <a href="https://github.com/huceke/omxplayer/blob/master/README.md"target="_blank">Aufstellung der Parameter</a>.Die Zeichenkette parameter enthaelt Eintraege wie z.B. |
| | | * App.OPT_LOCAL_AUDIO oder App.OPT_HDMI_AUDIO. |
| | | Mehrere Parameter werden mit App.BLANK getrennt. |
| | | * @param t |
| | | * @param urlStr der URL der Quelle, die abgespielt werden soll |
| | | * @param parameter die Parameter, die vom omxplayer angewendet werden sollen |
| | | * @param token |
| | | * @return Antwort des Servers |
| | | */ |
| | | /* |
| | | public String abspielenMitParametern(String urlStr, String parameter, String token) { |
| | | return abspielenMitParameternUndRueckmeldung(urlStr, parameter, null, token); |
| | | } |
| | | */ |
| | | |
| | | public String abspielenMitParameternUndRueckmeldung(String urlStr, String parameter, String meldeUrlStr, String token) { |
| | | public String abspielen(String urlStr, String parameter, String meldeUrlStr, String token) { |
| | | String antwort;// = null; |
| | | try { |
| | | //Object o = t.getAttribute(App.PI_PLAYER); |
| | |
| | | entfernen und gibt so das Objekt wieder frei fuer die Ausfuehrung |
| | | weiterer Kommandos. |
| | | * |
| | | * @param t |
| | | * @return die Antwort des Servers |
| | | */ |
| | | public String tilgen() { |
| | |
| | | |
| | | /** |
| | | * Dem laufenden Abspielprozess ein Kommando uebermitteln |
| | | * @param t |
| | | * @param k das Kommando laut |
| | | * <a href="https://github.com/huceke/omxplayer/blob/master/README.md" target="_blank">Liste der Kommandos</a> |
| | | * @return die Antwort des Servers |