From 081606e391a352d8117210d731d252dfb43c4b84 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Mon, 05 Apr 2021 10:00:45 +0000
Subject: [PATCH] FileStorage und Interface Storage

---
 src/de/uhilger/mediaz/Server.java |   30 ++++++++++++++++++++++++------
 1 files changed, 24 insertions(+), 6 deletions(-)

diff --git a/src/de/uhilger/mediaz/Server.java b/src/de/uhilger/mediaz/Server.java
index 375d7af..4a3c97c 100644
--- a/src/de/uhilger/mediaz/Server.java
+++ b/src/de/uhilger/mediaz/Server.java
@@ -21,17 +21,19 @@
 import de.uhilger.mediaz.api.AblageTestHandler;
 import de.uhilger.mediaz.api.FileHandler;
 import de.uhilger.mediaz.api.StopServerHandler;
-import de.uhilger.mediaz.api.StoreHandler;
+import de.uhilger.mediaz.api.StorageHandler;
 import de.uhilger.mediaz.api.StoreTestHandler;
-import de.uhilger.mediaz.conf.Store;
+import de.uhilger.mediaz.store.FileStorage;
 import de.uhilger.mediaz.entity.Ablageort;
-import de.uhilger.mediaz.entity.ConfigurationElement;
 import java.io.File;
 import java.io.IOException;
 import java.util.logging.Logger;
 import java.net.InetSocketAddress;
 import java.util.concurrent.Executors;
 import java.util.logging.Level;
+import de.uhilger.mediaz.entity.Entity;
+import java.util.Iterator;
+import java.util.List;
 
 /**
  * Die Klasse Server stellt Methoden zur Ausführung eines HTTP-Servers
@@ -110,7 +112,7 @@
     server.createContext(ctx + App.getRs(RB_WEBROOT), 
             new FileHandler(wwwDir.getAbsolutePath()));
     ablageorteEinklinken(server);
-    server.createContext(ctx + App.getRs(RB_STORE), new StoreHandler());
+    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_STOP_SERVER), new StopServerHandler());
     server.createContext(ctx + App.getRs(RB_ABLAGE_TEST), new AblageTestHandler());
@@ -120,13 +122,28 @@
   }
 
   private void ablageorteEinklinken(HttpServer server) throws ClassNotFoundException, IOException {
-    Store store = new Store();
+    String typ = Ablageort.class.getSimpleName();
+    FileStorage store = new FileStorage(App.getInitParameter(App.getRs(App.RB_AP_CONF)));
+    List<String> orte = store.list(typ);
+    Iterator<String> i = orte.iterator();
+    while(i.hasNext()) {
+      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()));
+      }
+    }
+    
+    /*
     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) {
-        ConfigurationElement elem = store.readFromFile(ort);
+        Entity elem = store.readFromFile(ort);
         if (elem instanceof Ablageort) {
           Ablageort ablageort = (Ablageort) elem;
           server.createContext(ctx + ablageort.getUrl(), 
@@ -134,6 +151,7 @@
         }
       }
     }
+    */
   }
 
 }

--
Gitblit v1.9.3