From 63b7111015c9c83702a8704556aceac5204dfd41 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Mon, 22 Mar 2021 18:55:35 +0000
Subject: [PATCH] Handler Objekthierarchie in Arbeit

---
 src/de/uhilger/avdirektor/handler/CmdHandler.java  |   46 ++++++++++-----
 src/de/uhilger/avdirektor/handler/SeekHandler.java |   56 ++++++++++++++++++
 src/de/uhilger/avdirektor/Server.java              |    3 
 src/de/uhilger/avdirektor/handler/PlayHandler.java |   39 ++++++++----
 4 files changed, 114 insertions(+), 30 deletions(-)

diff --git a/src/de/uhilger/avdirektor/Server.java b/src/de/uhilger/avdirektor/Server.java
index 70f330b..e810fd0 100644
--- a/src/de/uhilger/avdirektor/Server.java
+++ b/src/de/uhilger/avdirektor/Server.java
@@ -32,8 +32,9 @@
     logger.info("Server starting on port " + port);
 
     HttpServer server = HttpServer.create(new InetSocketAddress(port), 0);
-    server.createContext("/avd/play", new PlayHandler());
+    server.createContext("/avd/play", new PlayHandler("play"));
     server.createContext("/avd/stop", new CmdHandler(App.CMD_STOP));
+    server.createContext("/avd/pause", new CmdHandler(App.CMD_PAUSE_RESUME));
     server.createContext("/avd/ping", new PingHandler());
     server.createContext("/avd/server/stop", new StopServerHandler());
     server.setExecutor(null); // creates a default executor
diff --git a/src/de/uhilger/avdirektor/handler/CmdHandler.java b/src/de/uhilger/avdirektor/handler/CmdHandler.java
index 1ea0ec5..7e3193e 100644
--- a/src/de/uhilger/avdirektor/handler/CmdHandler.java
+++ b/src/de/uhilger/avdirektor/handler/CmdHandler.java
@@ -16,10 +16,39 @@
 
   private static final Logger logger = Logger.getLogger(CmdHandler.class.getName());
   
-  private String cmd;
+  protected String cmd;
+  protected Map map;
   
   public CmdHandler(String cmd) {
     this.cmd = cmd;
+  }
+  
+  @Override
+  public void handle(HttpExchange t) throws IOException {
+    logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString());
+    StringBuilder params = buildParams(t);
+    String antwort = process(t, params.toString());
+    sendResponse(t, cmd, antwort);
+  }
+  
+  protected String process(HttpExchange t, String params) {
+    String antwort = this.kommando(cmd);
+    logger.log(Level.FINE, antwort);
+    return antwort;
+  }
+  
+  protected StringBuilder buildParams(HttpExchange t) {
+    map = getQueryMap(t);
+    StringBuilder params = new StringBuilder();
+    return params;
+  }
+  
+  protected void sendResponse(HttpExchange t, String cmd, String antwort) throws IOException {
+    String response = getResponseString(map, cmd, antwort);
+    t.sendResponseHeaders(200, response.length());
+    OutputStream os = t.getResponseBody();
+    os.write(response.getBytes());
+    os.close();    
   }
   
   public void setCmd(String cmd) {
@@ -30,19 +59,4 @@
     return this.cmd;
   }
 
-  @Override
-  public void handle(HttpExchange t) throws IOException {
-    logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString());
-    Map map = getQueryMap(t);
-    
-    String antwort = this.kommando(cmd);
-    logger.log(Level.FINE, antwort);
-    
-    String response = getResponseString(map, cmd, antwort);
-    t.sendResponseHeaders(200, response.length());
-    OutputStream os = t.getResponseBody();
-    os.write(response.getBytes());
-    os.close();    
-  }
-  
 }
diff --git a/src/de/uhilger/avdirektor/handler/PlayHandler.java b/src/de/uhilger/avdirektor/handler/PlayHandler.java
index 7cdb127..62d3f14 100644
--- a/src/de/uhilger/avdirektor/handler/PlayHandler.java
+++ b/src/de/uhilger/avdirektor/handler/PlayHandler.java
@@ -12,9 +12,13 @@
  * 
  * @author ulrich
  */
-public class PlayHandler extends OMXPlayer implements HttpHandler {
+public class PlayHandler extends CmdHandler {
   
   private static final Logger logger = Logger.getLogger(PlayHandler.class.getName());
+
+  public PlayHandler(String cmd) {
+    super(cmd);
+  }
 
   /*
     rpi4-az:9090/avd/play?titel=/Filme/S/sound_city.m4v&th=60&ti=60&o=local
@@ -33,28 +37,37 @@
     r muss ganz wegbleiben, wenn keine Rueckmeldung gewuescht ist
 
   */
+  /*
   @Override
   public void handle(HttpExchange t) throws IOException {
     logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString());
     
-    Map map = getQueryMap(t);
-    StringBuilder params = new StringBuilder();
+    StringBuilder params = buildParams(t);
+    
+    String antwort = abspielenMitParameternUndRueckmeldung( 
+            getParam(map, "titel"), params.toString(), getParam(map, "r"), "1");    
+    
+    sendResponse(t, "play", antwort);
+  }
+  */
+
+  @Override
+  protected String process(HttpExchange t, String params) {
+    String antwort = abspielenMitParameternUndRueckmeldung( 
+            getParam(map, "titel"), params, getParam(map, "r"), "1");    
+    logger.log(Level.FINE, antwort);
+    return antwort;
+  }
+
+  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 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());
-    os.close();    
+    return params;
   }
-  
   
 }
diff --git a/src/de/uhilger/avdirektor/handler/SeekHandler.java b/src/de/uhilger/avdirektor/handler/SeekHandler.java
new file mode 100644
index 0000000..74247b1
--- /dev/null
+++ b/src/de/uhilger/avdirektor/handler/SeekHandler.java
@@ -0,0 +1,56 @@
+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.Map;
+import java.util.logging.Level;
+import java.util.logging.Logger;
+
+/**
+ *
+ * @author ulrich
+ */
+public class SeekHandler extends PlayHandler  {
+  
+  private static final Logger logger = Logger.getLogger(SeekHandler.class.getName());
+
+  public SeekHandler(String cmd) {
+    super(cmd);
+  }
+
+  @Override
+  public void handle(HttpExchange t) throws IOException {
+    logger.log(Level.FINE, "RequestURI: {0}", t.getRequestURI().toString());
+    
+    StringBuilder params = super.buildParams(t);
+    params.append(" --pos ");
+    params.append(getParam(map, "p"));
+    
+    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());
+    os.close();    
+  }
+  
+  @Override
+  protected String process(HttpExchange t, String params) {
+    String antwort = abspielenMitParameternUndRueckmeldung( 
+            getParam(map, "titel"), params, getParam(map, "r"), "1");    
+    logger.log(Level.FINE, antwort);
+    return antwort;
+  }
+
+  protected StringBuilder buildParams(HttpExchange t) {
+    StringBuilder params = super.buildParams(t);
+    params.append(" --pos ");
+    params.append(getParam(map, "p"));
+    return params;
+  }  
+  
+}

--
Gitblit v1.9.3