X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Faccount%2Fmail%2FMailOverview.java;h=ef98a091238c35bc1e76ae7e0687cbfcce2c65bf;hb=bdb770e853028d8510a941c936a290ab69cf675c;hp=da3befd581b214c57a284431de6e9b2d7d11d522;hpb=bc51ef4b743b32a7cd3f917a65a2884155b589bb;p=gigi.git diff --git a/src/org/cacert/gigi/pages/account/mail/MailOverview.java b/src/org/cacert/gigi/pages/account/mail/MailOverview.java index da3befd5..ef98a091 100644 --- a/src/org/cacert/gigi/pages/account/mail/MailOverview.java +++ b/src/org/cacert/gigi/pages/account/mail/MailOverview.java @@ -1,7 +1,6 @@ package org.cacert.gigi.pages.account.mail; import java.io.IOException; -import java.io.PrintWriter; import java.util.HashMap; import javax.servlet.http.HttpServletRequest; @@ -10,10 +9,12 @@ import javax.servlet.http.HttpServletResponse; import org.cacert.gigi.dbObjects.User; import org.cacert.gigi.localisation.Language; import org.cacert.gigi.output.template.Form; +import org.cacert.gigi.output.template.Form.CSRFException; +import org.cacert.gigi.pages.ManagedMultiFormPage; import org.cacert.gigi.pages.Page; import org.cacert.gigi.util.AuthorizationContext; -public class MailOverview extends Page { +public class MailOverview extends ManagedMultiFormPage { public static final String DEFAULT_PATH = "/account/mails"; @@ -23,33 +24,43 @@ public class MailOverview extends Page { @Override public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException { - final User us = getUser(req); + User user = getUser(req); + output(req, resp, new MailAddForm(req, user), new MailManagementForm(req, user)); + } + + private void output(HttpServletRequest req, HttpServletResponse resp, MailAddForm addForm, MailManagementForm mgmtForm) throws IOException { Language lang = Page.getLanguage(req); HashMap vars = new HashMap<>(); - vars.put("addForm", new MailAddForm(req, us)); - vars.put("manForm", new MailManagementForm(req, us)); + vars.put("addForm", addForm); + vars.put("manForm", mgmtForm); getDefaultTemplate().output(resp.getWriter(), lang, vars); } @Override public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException { - PrintWriter out = resp.getWriter(); - if (req.getParameter("addmail") != null) { - MailAddForm f = Form.getForm(req, MailAddForm.class); - if (f.submit(out, req)) { - resp.sendRedirect(MailOverview.DEFAULT_PATH); + Form current = getForm(req); + if (Form.printFormErrors(req, resp.getWriter())) { + User user = getUser(req); + if (current instanceof MailAddForm) { + output(req, resp, (MailAddForm) current, new MailManagementForm(req, user)); + } else { + output(req, resp, new MailAddForm(req, user), (MailManagementForm) current); } + } + } + + @Override + public Form getForm(HttpServletRequest req) throws CSRFException { + if (req.getParameter("addmail") != null) { + return Form.getForm(req, MailAddForm.class); } else { - MailManagementForm f = Form.getForm(req, MailManagementForm.class); - if (f.submit(out, req)) { - resp.sendRedirect(MailOverview.DEFAULT_PATH); - } + return Form.getForm(req, MailManagementForm.class); } - super.doPost(req, resp); } @Override public boolean isPermitted(AuthorizationContext ac) { return ac != null && ac.getTarget() instanceof User; } + }