From 96d8cfc0368d09ee25b846d4aa47f1ff0d9e8ae1 Mon Sep 17 00:00:00 2001
From: ulrich <undisclosed>
Date: Tue, 03 Apr 2018 16:39:04 +0000
Subject: [PATCH] collectFiles nach WbxUtils verschoben

---
 src/de/uhilger/wbx/WbxUtils.java |  155 ++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 127 insertions(+), 28 deletions(-)

diff --git a/src/de/uhilger/wbx/WbxUtils.java b/src/de/uhilger/wbx/WbxUtils.java
index 4bf0bd8..9705fce 100644
--- a/src/de/uhilger/wbx/WbxUtils.java
+++ b/src/de/uhilger/wbx/WbxUtils.java
@@ -19,8 +19,16 @@
 package de.uhilger.wbx;
 
 import java.io.File;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.Iterator;
+import java.util.List;
+import java.util.logging.Level;
 import java.util.logging.Logger;
-import javax.servlet.ServletContext;
+import javax.naming.Context;
+import javax.naming.InitialContext;
+import javax.naming.NamingException;
 
 /**
  *
@@ -29,36 +37,127 @@
   
   private static final Logger logger = Logger.getLogger(WbxUtils.class.getName());
   
+  public static final String JNDI_CTX_NAME = "java:comp/env";
+  
+  public static final String NOT_FOUND = " nicht gefunden";
+  public static final String NO_STRING = " ist kein String";  
+  public static final String EMPTY_STRING = "";
+  
+  public static final String WBX_PUB_DIR_NAME = "wbxPubDirName";
+  public static final String WBX_DEFAULT_PUB_DIR_NAME = "/www";
+  
   /**
-   * 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
+   * 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.
    * 
-   * 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
+   * @param out
+   * @param dir
+   * @param tiefe
+   * @param dateizaehler 
    */
-  public static File getWbxDataDir(ServletContext ctx) {
-    String path = ctx.getRealPath("/");
-    logger.fine("getRealPath: " + path); // file-cms in webapps
-    File file = new File(path);
-    file = file.getParentFile().getParentFile().getParentFile().getParentFile();    
-    file = new File(file, "daten/");
-    logger.fine("Basis: " + file.getAbsolutePath());
-    return file;
+  public 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 int getJNDIInt(String paramName, int defaultVal) {
+    String jndiStr = getJNDIParameter(paramName, Integer.toString(defaultVal));
+    try {
+      return Integer.parseInt(jndiStr);
+    } catch(NumberFormatException ex) {
+      logger.log(Level.FINE, ex.getMessage());
+      return defaultVal;
+    }
+  }
+  
+  public String getJNDIParameter(String pname, String defaultVal) {
+    try {
+      // unseren environment naming context ermitteln
+      Context initCtx = new InitialContext();
+      Context envCtx = (Context) initCtx.lookup(JNDI_CTX_NAME);
+      
+      // unseren Parameter lesen
+      Object o = envCtx.lookup(pname);
+      if(o instanceof String) {
+        return o.toString();      
+      } else {
+        return defaultVal;
+      }
+    } catch (NamingException ex) {
+      logger.log(Level.FINE, ex.getMessage());
+      return defaultVal;
+    }
+  }  
 }

--
Gitblit v1.9.3