package de.uhilger.wbx.web; import de.uhilger.wbx.WbxUtils; import de.vogella.rss.model.Feed; import de.vogella.rss.model.FeedMessage; import java.io.File; import java.io.FileReader; import java.io.IOException; import java.io.Reader; 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; import java.util.List; import java.util.Locale; import java.util.logging.Level; import java.util.logging.Logger; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** *
Das FeedServlet erstellt Feeds von Ordnern der WebBox
* *Annahmen:
*wbxFileBase
enthaelt den absoluten Pfad
* zur DateiablagewbxFileBase
http://example.com/[Context]/weitere/pfad/angaben/datei.html
* die Pfadangabe hinter [Context]/
die Inhalte innerhalb von
* wbxFileBase/wbxPubDir
1:1 wiedergibt.Der JNDI-Parameter wbxMaxFeedDepth
regelt, wie viele Ebenen der
* Ordnerstruktur maximal nach Eintraegen durchsucht werden. Dabei haben die
* tiefsten Ebenen Vorrang vor hoeher gelegenen Ebenen, d.h. Dateien auf
* tieferen Ebenen werden vor Dateien auf hoeheren Ebenen in den Feed
* aufgenommen.
Der JNDI-Parameter wbxMaxFeedEntries
regelt, wie viele Beitraege
* maximal im Feed erscheinen. Der Standardwert ist fuenf Beitraege, d.h., die
* ersten fuenf gefundenen Beitraege werden chronologisch absteigend sortiert
* nach ihrem letzten Aenderungsdatum ausgegeben.
Die Datei CATALINA_BASE/conf/context.xml
muss also die
* folgenden Eintraege enthalten:
**/ public class FeedServlet extends HttpServlet { 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 WBX_MAX_FEED_DEPTH = "wbxMaxFeedDepth"; public static final String WBX_MAX_FEED_ENTRIES = "wbxMaxFeedEntries"; public static final String WBX_FEED_TITLE = "wbxFeedTitle"; public static final String WBX_FEED_SUBTITLE = "wbxFeedSubtitle"; public static final String WBX_FEED_COPYRIGHT = "wbxFeedCopyright"; public static final String WBX_FEED_DOMAIN = "wbxFeedDomain"; public static final String WBX_FEED_AUTHOR = "wbxFeedAuthor"; public static final int WBX_DEF_MAX_FEED_DEPTH = 3; public static final int WBX_DEF_MAX_FEED_ENTRIES = 5; @Override protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException { ServletOutputStream out = response.getOutputStream(); response.setContentType("text/xml"); String url = request.getRequestURL().toString(); logger.fine("requestURL: " + url); String contextPath = request.getContextPath(); logger.fine("contextPath: " + contextPath); String zielPfad = url.substring(url.indexOf(contextPath)); logger.fine(zielPfad); WbxUtils wu = new WbxUtils(); String basis = wu.getJNDIParameter(WBX_FILE_BASE, WbxUtils.EMPTY_STRING); logger.fine("basis: " + basis); StringBuffer pfad = new StringBuffer(); pfad.append(basis); pfad.append(zielPfad.replace(contextPath, wu.getJNDIParameter(WBX_PUB_DIR, WbxUtils.EMPTY_STRING))); logger.fine("pfad: " + pfad); String dirStr = pfad.toString().substring(0, pfad.lastIndexOf("/")); logger.fine("dirStr: " + dirStr); File dir = new File(dirStr); if (dir.isDirectory()) { 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); Iterator i = beitraege.iterator(); while (i.hasNext()) { File f = (File) i.next(); logger.fine(f.getAbsolutePath() + " " + f.lastModified()); } writeFeed(wu.getJNDIParameter(WBX_FEED_TITLE, WbxUtils.EMPTY_STRING), wu.getJNDIParameter(WBX_FEED_SUBTITLE, WbxUtils.EMPTY_STRING), out, beitraege, basis, pfad.toString(), contextPath, wu); } else { 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* * * * * * *