From 275b2136b8c8eee4efaa7e9d325d9e283a8687ed Mon Sep 17 00:00:00 2001
From: ulrich
Date: Wed, 21 Apr 2021 16:55:18 +0000
Subject: [PATCH] Fehler in Breadcrumb-Links berichtigt
---
src/de/uhilger/mediaz/Server.java | 62 ++++++++++++-------------------
1 files changed, 24 insertions(+), 38 deletions(-)
diff --git a/src/de/uhilger/mediaz/Server.java b/src/de/uhilger/mediaz/Server.java
index 4a3c97c..a3f1b1c 100644
--- a/src/de/uhilger/mediaz/Server.java
+++ b/src/de/uhilger/mediaz/Server.java
@@ -18,11 +18,13 @@
package de.uhilger.mediaz;
import com.sun.net.httpserver.HttpServer;
-import de.uhilger.mediaz.api.AblageTestHandler;
import de.uhilger.mediaz.api.FileHandler;
+import de.uhilger.mediaz.api.GeraetSteuerung;
+import de.uhilger.mediaz.api.ListFileHandler;
+import de.uhilger.mediaz.api.ListHandler;
+import de.uhilger.mediaz.api.MediaSteuerung;
import de.uhilger.mediaz.api.StopServerHandler;
import de.uhilger.mediaz.api.StorageHandler;
-import de.uhilger.mediaz.api.StoreTestHandler;
import de.uhilger.mediaz.store.FileStorage;
import de.uhilger.mediaz.entity.Ablageort;
import java.io.File;
@@ -49,11 +51,14 @@
public static final String RB_SERVER_START_MSG = "msgServerStart";
public static final String RB_WEBROOT = "webroot";
public static final String RB_STORE = "store";
+ public static final String RB_STRG = "strg";
+ public static final String RB_GSTRG = "gstrg";
+ public static final String RB_ALIST= "alist";
//public static final String RB_UI_ROOT = "uiroot";
public static final String RB_STOP_SERVER = "stopServer";
- public static final String RB_ABLAGE_TEST = "testAblage";
- public static final String RB_STORE_TEST = "testStore";
- public static final String RB_SLASH = "slash";
+ //public static final String RB_ABLAGE_TEST = "testAblage";
+ //public static final String RB_STORE_TEST = "testStore";
+ public static final String SLASH = "/";
private int port;
@@ -84,16 +89,15 @@
* @param ctxName Name des Kontexts, unter dem der Server aufrufbar sein soll
*/
public void setContextName(String ctxName) {
- String slash = App.getRs(RB_SLASH);
- if (!ctxName.startsWith(slash)) {
- this.ctx = slash + ctxName;
+ if (!ctxName.startsWith(SLASH)) {
+ this.ctx = SLASH + ctxName;
} else {
this.ctx = ctxName;
}
}
/**
- * Die Endpunkte ('Context'e) einrichten, unter denen die Dienste dieses
+ * Die Endpunkte einrichten, unter denen die Dienste dieses
* Servers erreichbar sein sollen und den Server starten
*
* @throws IOException wenn etwas schief geht, finden sich Angaben in diesem
@@ -105,23 +109,21 @@
String wwwData = App.getInitParameter(App.getRs(App.RB_AP_WWW_DATA));
File wwwDir = new File(wwwData);
- //String ui = App.getInitParameter(App.getRs(App.RB_AP_UI));
- //File uiDir = new File(ui);
HttpServer server = HttpServer.create(new InetSocketAddress(port), 0);
- server.createContext(ctx + App.getRs(RB_WEBROOT),
- new FileHandler(wwwDir.getAbsolutePath()));
+ server.createContext(ctx + App.getRs(RB_WEBROOT), new FileHandler(wwwDir.getAbsolutePath()));
ablageorteEinklinken(server);
server.createContext(ctx + App.getRs(RB_STORE), new StorageHandler());
- //server.createContext(ctx + App.getRs(RB_UI_ROOT), new FileHandler(uiDir.getAbsolutePath()));
+ server.createContext(ctx + App.getRs(RB_STRG), new MediaSteuerung());
+ server.createContext(ctx + App.getRs(RB_GSTRG), new GeraetSteuerung());
+ server.createContext(ctx + App.getRs(RB_ALIST), new ListHandler());
server.createContext(ctx + App.getRs(RB_STOP_SERVER), new StopServerHandler());
- server.createContext(ctx + App.getRs(RB_ABLAGE_TEST), new AblageTestHandler());
- server.createContext(ctx + App.getRs(RB_STORE_TEST), new StoreTestHandler());
server.setExecutor(Executors.newFixedThreadPool(20));
server.start();
}
- private void ablageorteEinklinken(HttpServer server) throws ClassNotFoundException, IOException {
+ private void ablageorteEinklinken(HttpServer server)
+ throws ClassNotFoundException, IOException {
String typ = Ablageort.class.getSimpleName();
FileStorage store = new FileStorage(App.getInitParameter(App.getRs(App.RB_AP_CONF)));
List<String> orte = store.list(typ);
@@ -130,28 +132,12 @@
String ortName = i.next();
Entity e = store.read(typ, ortName);
if(e instanceof Ablageort) {
- Ablageort ort = (Ablageort) e;
- Ablageort ablageort = (Ablageort) e;
- server.createContext(ctx + ablageort.getUrl(),
- new FileHandler(new File(ablageort.getOrt()).getAbsolutePath()));
+ Ablageort ablageort = (Ablageort) e;
+ logger.log(Level.FINE, "{0}{1}", new Object[]{ctx, ablageort.getUrl()});
+ logger.fine(ablageort.getOrt());
+ server.createContext(ctx + ablageort.getUrl(),
+ new ListFileHandler(new File(ablageort.getOrt()).getAbsolutePath()));
}
}
-
- /*
- String conf = App.getInitParameter(App.getRs(App.RB_AP_CONF));
- File ablageortDir = new File(conf, Ablageort.class.getSimpleName());
- File[] orte = ablageortDir.listFiles();
- if (orte != null) {
- for (File ort : orte) {
- Entity elem = store.readFromFile(ort);
- if (elem instanceof Ablageort) {
- Ablageort ablageort = (Ablageort) elem;
- server.createContext(ctx + ablageort.getUrl(),
- new FileHandler(new File(ablageort.getOrt()).getAbsolutePath()));
- }
- }
- }
- */
}
-
}
--
Gitblit v1.9.3