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 |  169 +++++++++++++++++++++++++++++++-------------------------
 1 files changed, 94 insertions(+), 75 deletions(-)

diff --git a/src/de/uhilger/wbx/WbxUtils.java b/src/de/uhilger/wbx/WbxUtils.java
index 384c1ad..9705fce 100644
--- a/src/de/uhilger/wbx/WbxUtils.java
+++ b/src/de/uhilger/wbx/WbxUtils.java
@@ -19,12 +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.naming.Context;
 import javax.naming.InitialContext;
 import javax.naming.NamingException;
-import javax.servlet.ServletContext;
 
 /**
  *
@@ -38,9 +42,95 @@
   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 FILE_BASE = "filebase";
-  //public static final String DATENABLAGE = "datenAblage";  
+  
+  public static final String WBX_PUB_DIR_NAME = "wbxPubDirName";
+  public static final String WBX_DEFAULT_PUB_DIR_NAME = "/www";
+  
+  /**
+   * 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 
+   */
+  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));
@@ -70,75 +160,4 @@
       return defaultVal;
     }
   }  
-  
-  /**
-   * 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 static File getWbxDataDir(ServletContext ctx) {
-    File file = getWbxDir(ctx);    
-    file = new File(file, "daten/");
-    logger.fine("WebBox Datenbasis: " + file.getAbsolutePath());
-    return file;
-  }
-  
-  public static File getWbxDir(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();    
-    logger.fine("WebBox: " + file.getAbsolutePath());
-    return file;
-  }
-  */
-  
-  /**
-   * Die Dateiablage wird entweder auf einen absoluten Pfad gesetzt, 
-   * der im Deployment Descriptor hinterlegt werden kann oder, wenn 
-   * dort nichts eingetragen ist, auf den hart kodierten Pfad 
-   * der WebBox.
-   * 
-   * @param ctx der ServletContext, in den die Angabe eingetragen wird. Dort 
-   * ist anschliessend die Angabe unter Initialiser.FILE_BASE abrufbar
-   */
-  /*
-  public static void ablageErmitteln(ServletContext ctx) {
-    Object o = ctx.getInitParameter(DATENABLAGE);
-    try {
-      if(o instanceof String) {
-        String pfad = o.toString();
-        if(pfad.trim().length() > 0) {
-          ctx.setAttribute(FILE_BASE, pfad);
-          logger.fine("Basis: " + pfad);
-        } else {
-          ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath());  
-        }
-      } else {
-        ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath());      
-      }    
-    } catch(Exception ex) {
-      ctx.setAttribute(FILE_BASE, WbxUtils.getWbxDataDir(ctx).getAbsolutePath());
-    }
-  } 
-  */
-
 }

--
Gitblit v1.9.3