From 38929aa1f4f4a017be4d2e93c32165b9e51f635d Mon Sep 17 00:00:00 2001
From: ulrich
Date: Tue, 21 Jul 2020 13:21:17 +0000
Subject: [PATCH] In Arbeit: PDF Theme

---
 src/de/uhilger/wbx/web/FeedServlet.java |  108 ++++++------------------------------------------------
 1 files changed, 12 insertions(+), 96 deletions(-)

diff --git a/src/de/uhilger/wbx/web/FeedServlet.java b/src/de/uhilger/wbx/web/FeedServlet.java
index 16a3ef7..83129c9 100644
--- a/src/de/uhilger/wbx/web/FeedServlet.java
+++ b/src/de/uhilger/wbx/web/FeedServlet.java
@@ -11,8 +11,6 @@
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
 import java.util.Calendar;
-import java.util.Collections;
-import java.util.Comparator;
 import java.util.Date;
 import java.util.GregorianCalendar;
 import java.util.Iterator;
@@ -57,7 +55,7 @@
  * folgenden Eintraege enthalten:</p>
  * <pre>
  * <Environment name="wbxFileBase" type="java.lang.String" value="absoluter/pfad/zur/dateiablage" override="false" />
- * <Environment name="wbxPubDir" type="java.lang.String" value="/www" override="false" />
+ * <Environment name="wbxPubDirName" type="java.lang.String" value="/www" override="false" />
  * <Environment name="wbxFeedTitle" type="java.lang.String" value="Newsfeed" override="false" />
  * <Environment name="wbxFeedSubtitle" type="java.lang.String" value="Text des Untertitels" override="false" />
  * <Environment name="wbxFeedCopyright" type="java.lang.String" value="Text des Copyright-Hinweises" override="false" />
@@ -69,9 +67,9 @@
   
   private static final Logger logger = Logger.getLogger(FeedServlet.class.getName());
   
-  public static final String JNDI_CTX_NAME = "java:comp/env";
-  public static final String WBX_FILE_BASE = "wbxFileBase";
-  public static final String WBX_PUB_DIR = "wbxPubDir";
+  //public static final String JNDI_CTX_NAME = "java:comp/env";
+  //public static final String WBX_FILE_BASE = "wbxFileBase";
+  //public static final String WBX_PUB_DIR = "wbxPubDir";
   public static final String WBX_MAX_FEED_DEPTH = "wbxMaxFeedDepth";
   public static final String WBX_MAX_FEED_ENTRIES = "wbxMaxFeedEntries";
   public static final String WBX_FEED_TITLE = "wbxFeedTitle";
@@ -94,11 +92,14 @@
     String zielPfad = url.substring(url.indexOf(contextPath));
     logger.fine(zielPfad);
     WbxUtils wu = new WbxUtils();
-    String basis = wu.getJNDIParameter(WBX_FILE_BASE, WbxUtils.EMPTY_STRING);
+    String basis = wu.getJNDIParameter(WbxUtils.WBX_FILE_BASE, WbxUtils.EMPTY_STRING);
     logger.fine("basis: " + basis);
+    if(basis.equals(WbxUtils.EMPTY_STRING)) {
+      basis = wu.getWbxDataDir().getAbsolutePath();
+    }
     StringBuffer pfad = new StringBuffer();
     pfad.append(basis);
-    pfad.append(zielPfad.replace(contextPath, wu.getJNDIParameter(WBX_PUB_DIR, WbxUtils.EMPTY_STRING)));
+    pfad.append(zielPfad.replace(contextPath, wu.getJNDIParameter(WbxUtils.WBX_PUB_DIR_NAME, WbxUtils.WBX_DEFAULT_PUB_DIR_NAME)));
     logger.fine("pfad: " + pfad);
     String dirStr = pfad.toString().substring(0, pfad.lastIndexOf("/"));
     logger.fine("dirStr: " + dirStr);
@@ -107,7 +108,7 @@
       List beitraege = new ArrayList();
       int maxBeitraege = wu.getJNDIInt(WBX_MAX_FEED_ENTRIES, WBX_DEF_MAX_FEED_ENTRIES);
       int maxTiefe = wu.getJNDIInt(WBX_MAX_FEED_DEPTH, WBX_DEF_MAX_FEED_DEPTH);
-      collectFiles(dir, 0, beitraege, maxTiefe, maxBeitraege);
+      wu.collectFiles(dir, 0, beitraege, maxTiefe, maxBeitraege);
       Iterator i = beitraege.iterator();
       while (i.hasNext()) {
         File f = (File) i.next();
@@ -120,92 +121,7 @@
       logger.fine(dir.getAbsolutePath() + " ist kein Ordner.");
     }
   }
-  
-  /**
-   * Diese Methode funktioniert nur, wenn entweder ein Ordner uebergeben 
-   * wird, der keine Unterordner enthaelt wie zum Beispiel der Ordner 'neu' 
-   * der Bildersammlung oder ein Ordner, dessen Unterordner 
-   * nach dem Schema Jahr, Monat benannt sind wie bei einem Journal, das 
-   * die Beitraege wie folgt enthaelt:
-   * Journal-Ordner
-   *   2018
-   *     12
-   *     11
-   *     10
-   *     usw.
-   *   2017
-   *     12
-   *     11
-   *     10
-   *     usw.
-   * 
-   * @param out
-   * @param dir
-   * @param tiefe
-   * @param dateizaehler 
-   */
-  private void collectFiles(File dir, int tiefe, List beitraege, int maxTiefe, int maxBeitraege) {
-    List dirs = new ArrayList();
-    List beitraegeHier = new ArrayList();
-    File[] files = dir.listFiles();
-    for(int i = 0; i < files.length; i++) {
-      if(files[i].isDirectory()) {
-        if(tiefe < maxTiefe) {
-          dirs.add(files[i]);
-        }
-      } else {
-        beitraegeHier.add(files[i]);
-      }
-    }
-      
-    if(dirs.size() > 0) {
-      // hier zuvor die Verzeichnissse absteigend nach Name sortieren      
-      Collections.sort(dirs, new Comparator<File>() {
-        @Override
-        public int compare(File o1, File o2) {
-          return o2.getName().compareTo(o1.getName());
-        }
-      });
-      
-      Iterator i = dirs.iterator();
-      while(i.hasNext() && beitraege.size() < maxBeitraege) {
-        collectFiles((File) i.next(), tiefe+1, beitraege, maxTiefe, maxBeitraege);
-      }
-    } 
-    if(beitraegeHier.size() > 0) {
-      // hier zuvor die Liste der Beitraege dieses Ordners nach lastModified absteigend sortieren
-      // dann die neuesten in beitraege aufnehmen, bis die maximale Zahl gesuchter 
-      // neuer Beitraege erreicht ist.
-      
-      Collections.sort(beitraegeHier, new Comparator<File>() {
-        @Override
-        public int compare(File o1, File o2) {
-          int ergebnis;
-          if(o1.lastModified() > o2.lastModified()) {
-            ergebnis = -1;
-          } else if(o2.lastModified() > o1.lastModified()) {
-            ergebnis = 1;
-          } else {
-            ergebnis = 0;
-          }
-          return ergebnis;
-        }
-      });
-      
-      Iterator i = beitraegeHier.iterator();
-      while(i.hasNext() && beitraege.size() < maxBeitraege) {
-        File bf = (File) i.next();
-        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")) {
-          beitraege.add(bf);
-        }
-      }
-      
-    }
-  }
-  
+    
   public void writeFeed(String feedTitel, String beschr, ServletOutputStream s, 
           List beitraege, String basis, String pfad, String contextPath, WbxUtils wu) {
     
@@ -238,7 +154,7 @@
 
       String urlStr = f.getAbsolutePath();
       urlStr = urlStr.replace(basis, domain);
-      urlStr = urlStr.replace(wu.getJNDIParameter(WBX_PUB_DIR, WbxUtils.EMPTY_STRING), contextPath);
+      urlStr = urlStr.replace(wu.getJNDIParameter(WbxUtils.WBX_PUB_DIR_NAME, WbxUtils.WBX_DEFAULT_PUB_DIR_NAME), contextPath);
 
       logger.fine(urlStr);
 

--
Gitblit v1.9.3