App zur Steuerung des mpv Mediaplayers auf einem Raspberry Pi über HTTP
ulrich
2021-03-21 8e20383acd0ab64b0b54ffb94508db13cc056269
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
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 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
 * 
 * 
 * 
 * 
 *
 * @author ulrich
 */
public class PlayHandler extends OMXPlayer implements HttpHandler {
  
  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();    
    
  }
 
}