From 1d695f99b80503bd6efbf181e6b8733ba3d1fb25 Mon Sep 17 00:00:00 2001
From: ulrich
Date: Sun, 09 Jan 2022 14:26:06 +0000
Subject: [PATCH] Logging entfernt

---
 src/de/uhilger/httpserver/adoc/AdocHandler.java |   52 +++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 35 insertions(+), 17 deletions(-)

diff --git a/src/de/uhilger/httpserver/adoc/AdocHandler.java b/src/de/uhilger/httpserver/adoc/AdocHandler.java
index dc20617..8a6cab5 100644
--- a/src/de/uhilger/httpserver/adoc/AdocHandler.java
+++ b/src/de/uhilger/httpserver/adoc/AdocHandler.java
@@ -18,39 +18,57 @@
 package de.uhilger.httpserver.adoc;
 
 import com.sun.net.httpserver.HttpExchange;
+import com.sun.net.httpserver.HttpHandler;
 import de.uhilger.httpserver.base.handler.FileHandler;
 import java.io.IOException;
+import java.net.URI;
 import java.util.logging.Logger;
 
 /**
- * Der AdocHandler verwendet den FileHandler zur Auslieferung statischer 
- * Inhalte und einen AdocFilter, um vorab zu pruefen, ob fuer eine 
- * Asciidoctor-Quelldatei bereits eine HTML-Version vorliegt. Wenn nicht,
- * verwendet der AdocFilter den AdocActor, um eine HTML-Version zu erzeugen, 
- * die dann vom AdocHandler mit Hilfe der Methoden des FileHandler 
- * ausgeliefert werden kann.
+ * Der AdocHandler liefert die HTML-Version einer Asciidoc-Quelldatei aus.
+ * 
+ * Dazu muss ein AdocHandler mit dem PatternDelegator an einen Pfad 
+ * geknuepft werden, der Dateien mit der Endung adoc bezeichnet.
+ * 
+ * Ein dafuer geeigneter regulaerer Ausdruck ist z.B. 
+ * <pre>
+ * .+\\.adoc
+ * </pre>
+ * 
+ * Zum Ausliefern der HTML-Version delegiert der AdocHandler an eine 
+ * Instanz des AdocActors.
+ * 
+ * Zum Erzeugen der HTML-Version muss ein AdocFilter mit dem HttpContext 
+ * verbunden sein, an den der AdocHandler gebunden ist.
+ * 
+ * Benoetigt das Attribut
+ * FileHandler.ATTR_FILE_BASE
  * 
  * @author Ulrich Hilger
  * @version 1, 16.06.2021
  */
-public class AdocHandler extends FileHandler {
+public class AdocHandler implements HttpHandler {
         
   private static final Logger logger = Logger.getLogger(AdocHandler.class.getName());        
   
-  public AdocHandler(String absoluteDirectoryPathAndName) {
-    super(absoluteDirectoryPathAndName);
-  }
-
   @Override
   public void handle(HttpExchange e) throws IOException {
-    logger.fine(e.getRequestURI().toString());
-    // hier ggf. noch etwas eigenes machen...
-    super.handle(e); // zu FileHandler delegieren
+    URI uri = e.getRequestURI();
+    logger.fine(uri.toString());
+    
+    String ctxPath = e.getHttpContext().getPath();
+    String uriPath = e.getRequestURI().getPath();
+    String fName = uriPath.substring(ctxPath.length());
+        
+    AdocActor actor = new AdocActor();
+    String query = uri.getQuery();
+    if(query != null && query.equalsIgnoreCase("pdf=true")) {
+      actor.handle(e, e.getHttpContext().getAttributes().get(FileHandler.ATTR_FILE_BASE).toString(), fName, true);
+    } else {
+      actor.handle(e, e.getHttpContext().getAttributes().get(FileHandler.ATTR_FILE_BASE).toString(), fName, false);
+    }
   }
   
-  public String getFileBase() {
-    return this.fileBase;
-  }
   
   
 }

--
Gitblit v1.9.3