From 320c6e7085128d2196edb552c2076c72af789443 Mon Sep 17 00:00:00 2001 From: ulrich <undisclosed> Date: Sun, 01 Apr 2018 13:30:30 +0000 Subject: [PATCH] Alle veraenderlichen Teile eines Feeds im Feed-Servlet mit JNDI-Parametern veraenderlich gestaltet --- src/de/uhilger/wbx/web/FeedServlet.java | 120 +++++++++++++++++++++++++++++++++++++---------------------- 1 files changed, 75 insertions(+), 45 deletions(-) diff --git a/src/de/uhilger/wbx/web/FeedServlet.java b/src/de/uhilger/wbx/web/FeedServlet.java index 07d132a..fcab375 100644 --- a/src/de/uhilger/wbx/web/FeedServlet.java +++ b/src/de/uhilger/wbx/web/FeedServlet.java @@ -1,7 +1,6 @@ package de.uhilger.wbx.web; -import de.uhilger.wbx.web.FeedStreamWriter; import de.vogella.rss.model.Feed; import de.vogella.rss.model.FeedMessage; import java.io.File; @@ -23,7 +22,6 @@ import javax.naming.Context; import javax.naming.InitialContext; import javax.naming.NamingException; -import javax.servlet.ServletContext; import javax.servlet.ServletException; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServlet; @@ -31,11 +29,43 @@ import javax.servlet.http.HttpServletResponse; /** - * Das FeedServlet erstellt Feeds von Ordnern der WebBox + * <p>Das FeedServlet erstellt Feeds von Ordnern der WebBox</p> * - * Eine Maximaltiefe als Parameter soll regeln, wie viele Ordner tief - * Dateien gesucht werden + * <p>Annahmen:</p> + * <ul> + * <li>Der JNDI-Parameter <code>wbxFileBase</code> enthaelt den absoluten Pfad + * zur Dateiablage</li> + * <li>Der Parameter 'wbxPubDir' enthaelt den Namen des Ordners mit + * oeffentlichen Inhalten und dieser Ordner liegt direkt unterhalb von + * <code>wbxFileBase</code></li> + * <li>Der Ordner mit dem oeffentlichen Inhalt wird von Tomcat als Context + * 1:1 ausgeliefert sodass bei einem URL wie + * <code>http://example.com/[Context]/weitere/pfad/angaben/datei.html</code> + * die Pfadangabe hinter <code>[Context]/</code> die Inhalte innerhalb von + * <code>wbxFileBase/wbxPubDir</code> 1:1 wiedergibt.</li> * + * <p>Der JNDI-Parameter <code>wbxMaxFeedDepth</code> 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.</p> + * + * <p>Der JNDI-Parameter <code>wbxMaxFeedEntries</code> 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.</p> + * + * <p>Die Datei <code>CATALINA_BASE/conf/context.xml</code> muss also die + * 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="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" /> + * <Environment name="wbxFeedDomain" type="java.lang.String" value="http://example.com" override="false" /> + * <Environment name="wbxFeedAuthor" type="java.lang.String" value="Name des Autors" override="false" /> + * </pre> */ public class FeedServlet extends HttpServlet { @@ -43,8 +73,14 @@ 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; @@ -58,39 +94,35 @@ response.setContentType("text/xml"); String url = request.getRequestURL().toString(); logger.fine("requestURL: " + url); - String dataUrl = url.replace("feed/", "data/"); - logger.fine("dataUrl: " + dataUrl); - int pos = dataUrl.indexOf("data/"); - String zielPfad = dataUrl.substring(pos); + String contextPath = request.getContextPath(); + logger.fine("contextPath: " + contextPath); + String zielPfad = url.substring(url.indexOf(contextPath)); logger.fine(zielPfad); - //ServletContext ctx = request.getServletContext(); - //Object o = ctx.getAttribute(FILE_BASE); String basis = getJNDIParameter(WBX_FILE_BASE); - //if(o instanceof String) { - //String basis = o.toString(); - logger.fine("basis: " + basis); - StringBuffer pfad = new StringBuffer(); - pfad.append(basis); - pfad.append(zielPfad.replace("data/", "/www/")); - 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 = getJNDIInt(WBX_MAX_FEED_ENTRIES, WBX_DEF_MAX_FEED_ENTRIES); - int maxTiefe = 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("Newsfeed", "Neueste Inhalte von Ulrich Hilger", out, beitraege, basis, pfad.toString()); - } else { - logger.fine(dir.getAbsolutePath() + " ist kein Ordner."); + logger.fine("basis: " + basis); + StringBuffer pfad = new StringBuffer(); + pfad.append(basis); + pfad.append(zielPfad.replace(contextPath, getJNDIParameter(WBX_PUB_DIR))); + 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 = getJNDIInt(WBX_MAX_FEED_ENTRIES, WBX_DEF_MAX_FEED_ENTRIES); + int maxTiefe = 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(getJNDIParameter(WBX_FEED_TITLE), + getJNDIParameter(WBX_FEED_SUBTITLE), out, beitraege, + basis, pfad.toString(), contextPath); + } else { + logger.fine(dir.getAbsolutePath() + " ist kein Ordner."); + } } /** @@ -178,12 +210,14 @@ } } - public void writeFeed(String feedTitel, String beschr, ServletOutputStream s, List beitraege, String basis, String pfad) { - String copyright = "Copyright (c) 2018 Ulrich Hilger"; + public void writeFeed(String feedTitel, String beschr, ServletOutputStream s, + List beitraege, String basis, String pfad, String contextPath) { + String copyright = getJNDIParameter(WBX_FEED_COPYRIGHT); + String domain = getJNDIParameter(WBX_FEED_DOMAIN); String title = feedTitel; String description = beschr; String language = "de"; - String link = "https://www.uhilger.de"; + String link = domain; Calendar cal = new GregorianCalendar(); Date creationDate = cal.getTime(); SimpleDateFormat date_format = new SimpleDateFormat( @@ -198,11 +232,11 @@ FeedMessage feedEintrag = new FeedMessage(); feedEintrag.setTitle(f.getName()); //feedEintrag.setDescription("Beschreibung hier"); - feedEintrag.setAuthor("ulrich Punkt hilger bei web Punkt de (Ulrich Hilger)"); + feedEintrag.setAuthor(getJNDIParameter(WBX_FEED_AUTHOR)); String urlStr = f.getAbsolutePath(); - urlStr = urlStr.replace(basis, "https://uhilger.de"); - urlStr = urlStr.replace("www/", "data/"); + urlStr = urlStr.replace(basis, domain); + urlStr = urlStr.replace(getJNDIParameter(WBX_PUB_DIR), contextPath); logger.fine(urlStr); @@ -214,12 +248,8 @@ } FeedStreamWriter writer = new FeedStreamWriter(rssFeed, s); - //RSSFeedWriter writer = new RSSFeedWriter(rssFeed, pfad + "/articles.rss"); - //ByteArrayOutputStream bs = new ByteArrayOutputStream(); - //RSSByteFeedWriter wr = new RSSByteFeedWriter(rssFeed, bs); try { writer.write(); - //s.print(bs.toString()); } catch (Exception e) { logger.log(Level.SEVERE, e.getMessage(), e); } -- Gitblit v1.9.3