X-Git-Url: https://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=war%2Fsrc%2Fmain%2Fjava%2Fpnews%2Fservlet%2FPnews.java;h=57ea4be6accb90f0553dece7ec464dc53a0a1702;hb=6f411daf8bfd05580744e3c46a8c1497e8cd7898;hp=79ee9f6fa02914999aa14d6de0b547cb5a015b4f;hpb=7b8a970adb62ec5d1c5ca07b5bbbb5750f0cdd62;p=pnews.git diff --git a/war/src/main/java/pnews/servlet/Pnews.java b/war/src/main/java/pnews/servlet/Pnews.java index 79ee9f6..57ea4be 100644 --- a/war/src/main/java/pnews/servlet/Pnews.java +++ b/war/src/main/java/pnews/servlet/Pnews.java @@ -24,28 +24,34 @@ import pnews.Article; import pnews.Category; public class Pnews extends HttpServlet { + private static final String CLASS_NAME = Pnews.class.getName(); private static final Logger LOG = Logger.getLogger(Pnews.class.getName()); private static final long serialVersionUID = 1L; - private static final ArticleProvider provider = ArticleProvider.singleton; + private ArticleProvider provider; + private Config config; private static String getQueryParameter(HttpServletRequest rq, String key) throws UnsupportedEncodingException { + final String METHOD_NAME="getQueryParameter"; String[] params; int idx; String q; + + + LOG.entering(CLASS_NAME, METHOD_NAME, new Object[] { rq, key} ); q = rq.getQueryString(); if (q == null) return null; - params = URLDecoder.decode(q, "UTF-8").split("&"); + params = q.split("&"); for (String p: params) { idx = p.indexOf('='); if (idx > 1 && p.substring(0, idx).equals(key)) - return p.substring(idx + 1); + return URLDecoder.decode(p.substring(idx + 1), "UTF-8"); } return null; @@ -55,7 +61,7 @@ public class Pnews extends HttpServlet { String redirectURL; Article a; - LOG.entering(Pnews.class.getName(), "redirect"); + LOG.entering(Pnews.class.getName(), "redirect", new Object[] { rq, rp }); try { redirectURL = getQueryParameter(rq, "url"); @@ -84,12 +90,17 @@ public class Pnews extends HttpServlet { LOG.exiting(Pnews.class.getName(), "redirect"); } + + private static void doTemporaryRedirect(String newURL, HttpServletResponse rp) { + rp.setHeader("Location", newURL); + rp.setStatus(HttpServletResponse.SC_TEMPORARY_REDIRECT); + } private void writeStats(HttpServletResponse rp) throws IOException { rp.setContentType("application/json;charset=utf-8"); rp.setCharacterEncoding("utf-8"); - rp.getWriter().write(JSON.getStats()); + rp.getWriter().write(JSON.getStats(provider, config)); } @@ -100,13 +111,13 @@ public class Pnews extends HttpServlet { try { articles = provider.getArticles(cat); if (articles != null) { - html = HTML.toHTML(articles, cat); + html = HTML.toHTML(articles, cat, config.getCategories()); rp.setContentType("text/html;charset=utf-8"); rp.getWriter().write(html); rp.setCharacterEncoding("utf-8"); } else { LOG.severe("writeArticles cannot retrieve any articles"); - html = HTML.toHTML(new ArrayList
(), cat); + html = HTML.toHTML(new ArrayList
(), cat, config.getCategories()); rp.setContentType("text/html"); rp.getWriter().write(html); } @@ -162,23 +173,29 @@ public class Pnews extends HttpServlet { } if (path.equals("/")) { - writeArticles(Category.TOP, resp); + writeArticles(config.getDefaultCategory(), resp); return ; } try { - if (path.equals("/stats")) { writeStats(resp); return ; } - for (Category cat: Category.values()) { - if (path.equals('/' + cat.getId())) { + for (Category cat: config.getCategories()) { + if (path.equals(cat.getURL())) { writeArticles(cat, resp); return ; } } + + for (String l: config.getLanguages()) { + if (path.equals("/" + l) || path.equals("/" + l + "/")) { + doTemporaryRedirect(config.getDefaultCategory().getURL(), resp); + return ; + } + } resp.getWriter().write("Not found " + req.getPathInfo()); resp.setStatus(HttpServletResponse.SC_NOT_FOUND); @@ -189,8 +206,16 @@ public class Pnews extends HttpServlet { } @Override - public void init(ServletConfig config) throws ServletException { - LOG.info("Pnews servlet init " + config.getServletContext().getContextPath()); - + public void init(ServletConfig cfg) throws ServletException { + LOG.info("Pnews servlet init " + cfg.getServletContext().getContextPath()); + + config = new Config(); + try { + config.loadConfig(); + } catch (UnsupportedEncodingException e) { + throw new ServletException(e); + } + + provider = new ArticleProvider(config); } }