X-Git-Url: https://code.wpia.club/?p=gigi.git;a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2FPage.java;h=054a1e52020bf1172a095ea26a82ce5c3b4595dd;hp=54d7d45d72e32b22be1b15dfecd8980bb63ad624;hb=17a15662212d973d12ed4cea3f5eaa9c0d1169ed;hpb=9f1f1f1618da6b3361952f50555db5c891ed7e73 diff --git a/src/org/cacert/gigi/pages/Page.java b/src/org/cacert/gigi/pages/Page.java index 54d7d45d..054a1e52 100644 --- a/src/org/cacert/gigi/pages/Page.java +++ b/src/org/cacert/gigi/pages/Page.java @@ -2,15 +2,19 @@ package org.cacert.gigi.pages; import java.io.IOException; import java.net.URL; +import java.util.Enumeration; +import java.util.Locale; import javax.servlet.ServletRequest; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; +import javax.servlet.http.HttpSession; import org.cacert.gigi.PermissionCheckable; -import org.cacert.gigi.User; +import org.cacert.gigi.dbObjects.User; import org.cacert.gigi.localisation.Language; import org.cacert.gigi.output.template.Template; +import org.cacert.gigi.util.AuthorizationContext; /** * This class encapsulates a sub page of Gigi. A template residing nearby this @@ -54,6 +58,29 @@ public abstract class Page implements PermissionCheckable { * if output goes wrong. */ public boolean beforeTemplate(HttpServletRequest req, HttpServletResponse resp) throws IOException { + if (req.getMethod().equals("POST")) { + return beforePost(req, resp); + } + return false; + } + + /** + * This method can be overridden to execute code and do stuff before the + * default template is applied when the request is a post request and the + * default implementation of + * {@link #beforeTemplate(HttpServletRequest, HttpServletResponse)} is + * called. + * + * @param req + * the request to handle. + * @param resp + * the response to write to + * @return true, if the request is consumed and the default template should + * not be applied. + * @throws IOException + * if output goes wrong. + */ + public boolean beforePost(HttpServletRequest req, HttpServletResponse resp) throws IOException { return false; } @@ -99,12 +126,29 @@ public abstract class Page implements PermissionCheckable { return title; } - public void setTitle(String title) { - this.title = title; - } - public static Language getLanguage(ServletRequest req) { - return Language.getInstance("de"); + HttpSession session = ((HttpServletRequest) req).getSession(); + synchronized (session) { + + Locale sessval = (Locale) session.getAttribute(Language.SESSION_ATTRIB_NAME); + if (sessval != null) { + Language l = Language.getInstance(sessval); + if (l != null) { + return l; + } + } + Enumeration langs = req.getLocales(); + while (langs.hasMoreElements()) { + Locale c = langs.nextElement(); + Language l = Language.getInstance(c); + if (l != null) { + session.setAttribute(Language.SESSION_ATTRIB_NAME, l.getLocale()); + return l; + } + } + session.setAttribute(Language.SESSION_ATTRIB_NAME, Locale.ENGLISH); + return Language.getInstance(Locale.ENGLISH); + } } public static String translate(ServletRequest req, String string) { @@ -117,8 +161,8 @@ public abstract class Page implements PermissionCheckable { } @Override - public boolean isPermitted(User u) { - return !needsLogin() || u != null; + public boolean isPermitted(AuthorizationContext ac) { + return !needsLogin() || ac != null; } }