From f2a70357272c7a2e61f724385e23b4c4fa2e69cb Mon Sep 17 00:00:00 2001
From: ulrich
Date: Thu, 23 Jul 2020 13:09:13 +0000
Subject: [PATCH] In Arbeit: PDF Theme

---
 src/de/uhilger/wbx/WbxUtils.java |   70 ++++++++++++++++++++++++++++++++++-
 1 files changed, 68 insertions(+), 2 deletions(-)

diff --git a/src/de/uhilger/wbx/WbxUtils.java b/src/de/uhilger/wbx/WbxUtils.java
index 963b5bf..dc023e7 100644
--- a/src/de/uhilger/wbx/WbxUtils.java
+++ b/src/de/uhilger/wbx/WbxUtils.java
@@ -20,6 +20,7 @@
 
 import de.uhilger.wbx.data.Inhalt;
 import java.io.File;
+import java.io.FileReader;
 import java.util.ArrayList;
 import java.util.Collections;
 import java.util.Comparator;
@@ -30,6 +31,7 @@
 import javax.naming.Context;
 import javax.naming.InitialContext;
 import javax.naming.NamingException;
+import javax.servlet.ServletContext;
 
 /**
  *
@@ -52,12 +54,50 @@
   public static final String WBX_PUB_URL_NAME = "wbxPubUrlName";
   public static final String WBX_DEFAULT_PUB_URL_NAME = "/data";
   
+  /**
+   * Bei der WebBox ist das Datenverzeichnis relativ zum Verzeichnis 
+   * $CATALINA_BASE/webapps untergebracht. 
+   * Die Abfrage ServletContext.getRealPath 
+   * liefert das Verzeichnis des Context dieser Webanwendung, also 
+   * $CATALINA_BASE/webapps/file-cms
+   * oder
+   * $WBX/sys/base/webapps/file-cms
+   * 
+   * Unter Windows z.B.
+   * C:\Users\fred\Documents\srv\wbx\sys\base\webapps\file-cms
+   * Unter Linux oder Mac OS z.B.
+   * /home/fred/srv/wbx/sys/base/webapps/file-cms
+   * 
+   * Das Datenverzeichis liegt dann auf 
+   * $WBX/daten
+   * 
+   * Mit dem Verzeichnis des Context dieser Webanwendung ist das 
+   * Datenverzeichnis der WebBox hart kodierbar mit dieser Methode
+   * 
+   * @return Verzeichnis 'daten' der WebBox
+   */
+  public File getWbxDataDir() {
+    File file = getWbxDir();    
+    file = new File(file, "daten/");
+    logger.fine("WebBox Datenbasis: " + file.getAbsolutePath());
+    return file;
+  }
+  
+  public File getWbxDir() {
+    logger.fine("Catalina Base: " + System.getProperty("catalina.base"));
+    File catalinaBase = new File(System.getProperty("catalina.base"));
+    File wbxDir = catalinaBase.getParentFile().getParentFile();
+    return wbxDir;
+  }
   
   public List<Inhalt> collectFiles(String requestUrl, String contextPath, 
-          String relativePath, int maxTiefe, int maxAnzahl) {
+          String relativePath, int maxTiefe, int maxAnzahl, int length) {
     Bild bild = new Bild();
     //WbxUtils wu = new WbxUtils();
     String basis = getJNDIParameter(WBX_FILE_BASE, WbxUtils.EMPTY_STRING);
+    if(basis.equals(WbxUtils.EMPTY_STRING)) {
+      basis = getWbxDataDir().getAbsolutePath();
+    }    
     String pubDirName = getJNDIParameter(WbxUtils.WBX_PUB_DIR_NAME, WbxUtils.WBX_DEFAULT_PUB_DIR_NAME);
     String pubUrlName = getJNDIParameter(WbxUtils.WBX_PUB_URL_NAME, WbxUtils.WBX_DEFAULT_PUB_URL_NAME);
     String relPath = relativePath.replace(pubUrlName, pubDirName);
@@ -76,6 +116,9 @@
       cont.setIsHidden(beitrag.isHidden());
       cont.setLastModified(beitrag.lastModified());
       cont.setLength(beitrag.length());
+      if(length > 0) {
+        cont.setAbst(getFileContent(beitrag, length));
+      }
       
       /*
         den 'https://..'-Teil bis vor dem 
@@ -105,6 +148,28 @@
     return files;
   } 
   
+  private String getFileContent(File file, int len) {
+    try {
+      StringBuffer readBuffer = new StringBuffer();
+      char[] buf = new char[1];
+      FileReader fr = new FileReader(file);
+      int bytesRead = fr.read(buf);
+      int read = 0;
+      while(bytesRead > -1 && read < len) {
+        read += bytesRead;
+        readBuffer.append(buf);
+        bytesRead = fr.read(buf);
+      }
+      readBuffer.append(buf);
+      fr.close();
+      logger.fine("read: " + read + ", readBuffer.len: " + readBuffer.length());
+      return readBuffer.toString();
+    } catch (Exception ex) {
+      logger.log(Level.SEVERE, ex.getMessage(), ex);
+      return EMPTY_STRING;
+    }
+  }
+  
   
   /**
    * Diese Methode funktioniert nur, wenn entweder ein Ordner uebergeben 
@@ -130,6 +195,7 @@
    * @param dateizaehler 
    */
   public void collectFiles(File dir, int tiefe, List beitraege, int maxTiefe, int maxBeitraege) {
+    logger.fine(dir.getAbsolutePath());
     List dirs = new ArrayList();
     List beitraegeHier = new ArrayList();
     File[] files = dir.listFiles();
@@ -183,7 +249,7 @@
         String nm = bf.getName().toLowerCase();
         if(nm.endsWith(".htmi") || nm.endsWith(".html") || nm.endsWith(".htm") || 
            nm.endsWith(".jpg") || nm.endsWith(".jpeg") || nm.endsWith(".png") || 
-           nm.endsWith(".txt")) {
+           nm.endsWith(".txt") || nm.endsWith(".md")) {
           beitraege.add(bf);
         }
       }

--
Gitblit v1.9.3