From 50e53e791b318e29a9deb9228a6d1b615b8a9053 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Sat, 10 Apr 2021 17:46:18 +0000
Subject: [PATCH] UI-Anpassungen
---
src/de/uhilger/mediaz/api/MediaSteuerung.java | 32 ++++++++++++++++++++++++++++++--
1 files changed, 30 insertions(+), 2 deletions(-)
diff --git a/src/de/uhilger/mediaz/api/MediaSteuerung.java b/src/de/uhilger/mediaz/api/MediaSteuerung.java
index 2384012..edd5fb3 100644
--- a/src/de/uhilger/mediaz/api/MediaSteuerung.java
+++ b/src/de/uhilger/mediaz/api/MediaSteuerung.java
@@ -46,8 +46,9 @@
*
* HTTP GET /mz/api/strg/abspieler/play/[url]
*
- * HTTP GET /mz/api/strg/abspieler/pause HTTP GET /mz/api/strg/abspieler/stop HTTP GET
- * /mz/api/strg/abspieler/weiter
+ * HTTP GET /mz/api/strg/abspieler/pause
+ * HTTP GET /mz/api/strg/abspieler/stop
+ * HTTP GET /mz/api/strg/abspieler/weiter
*
* Faustregel: Anzahl Elemente eines URL plus 1 ist die Anzahl der Elemente des
* Ergebnisses von String.split.
@@ -65,6 +66,12 @@
public static final String PL_PARAM_RUECK = "&r=";
public static final String PL_API_STRG = "/api/strg/";
public static final String PL_CMD_ENDE = "ende";
+ public static final String PL_CMD_STOP = "stop";
+ public static final String PL_CMD_PAUSE = "pause";
+ public static final String PL_CMD_PLAYON = "playon";
+ public static final String PL_CMD_AVD_STOP = "avd/stop";
+ public static final String PL_CMD_AVD_PAUSE = "avd/pause";
+ public static final String PL_CMD_AVD_PLAYON = "avd/playon";
public static final String DEFAULT_HOST = "http://localhost:9090";
private final Map spielt = new HashMap();
@@ -75,6 +82,7 @@
String path = e.getRequestURI().toString();
String[] elems = path.split(Server.SLASH);
FileStorage fs = new FileStorage(App.getInitParameter(App.getRs(App.RB_AP_CONF)));
+ logger.fine(path);
// Faustregel: Anzahl Elemente eines URL plus 1 ist die Anzahl der Elemente des
// Ergebnisses von String.split.
@@ -82,6 +90,12 @@
case 6:
if (elems[5].equalsIgnoreCase(PL_CMD_ENDE)) {
response = naechsterTitel(fs, elems[4]);
+ } else if(elems[5].equalsIgnoreCase(PL_CMD_STOP)) {
+ response = kommandoSenden(fs, elems[4], PL_CMD_AVD_STOP);
+ } else if(elems[5].equalsIgnoreCase(PL_CMD_PAUSE)) {
+ response = kommandoSenden(fs, elems[4], PL_CMD_AVD_PAUSE);
+ } else if(elems[5].equalsIgnoreCase(PL_CMD_PLAYON)) {
+ response = kommandoSenden(fs, elems[4], PL_CMD_AVD_PLAYON);
} else {
response = meldung("Ungueltiges Kommando: " + elems[5], AbstractHandler.RTC_NOT_FOUND);
}
@@ -94,6 +108,19 @@
break;
}
return response;
+ }
+
+ private String kommandoSenden(Storage s, String aName, String kommando) {
+ Entity entity = s.read(FileStorage.ST_ABSPIELER, aName);
+ if (entity instanceof Abspieler) {
+ Abspieler abspieler = (Abspieler) entity;
+ StringBuilder kmd = new StringBuilder();
+ kmd.append(abspieler.getUrl());
+ kmd.append(kommando);
+ return kommando + " gesendet.";
+ } else {
+ return meldung("Abspielliste nicht gefunden.", AbstractHandler.RTC_NOT_FOUND);
+ }
}
private String ersterTitel(Storage s, String aName, String lName) {
@@ -121,6 +148,7 @@
response = listentitelSpielen(s, abspielerName, liste, titelNr);
} else {
response = "Liste " + liste.getName() + " ist zuende gespielt.";
+ logger.info(response);
}
} else {
response = meldung("Abspielliste nicht gefunden.", AbstractHandler.RTC_NOT_FOUND);
--
Gitblit v1.9.3