import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
+import org.cacert.gigi.output.Form;
import org.cacert.gigi.pages.Page;
public class RegisterPage extends Page {
}
@Override
- public void doGet(HttpServletRequest req, HttpServletResponse resp)
- throws IOException {
- PrintWriter out = resp.getWriter();
- getDefaultTemplate().output(out, getLanguage(req),
- new HashMap<String, Object>());
- Signup s = getForm(req);
- s.writeForm(out, getLanguage(req));
+ public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+ Signup s = new Signup(req);
+ outputGet(req, resp, s);
}
- public Signup getForm(HttpServletRequest req) {
- HttpSession hs = req.getSession();
- Signup s = (Signup) hs.getAttribute(SIGNUP_PROCESS);
- if (s == null) {
- s = new Signup();
- hs.setAttribute(SIGNUP_PROCESS, s);
- }
- return s;
+ private void outputGet(HttpServletRequest req, HttpServletResponse resp, Signup s) throws IOException {
+ PrintWriter out = resp.getWriter();
+ HashMap<String, Object> vars = new HashMap<String, Object>();
+ getDefaultTemplate().output(out, getLanguage(req), vars);
+ s.output(out, getLanguage(req), vars);
}
+
@Override
- public void doPost(HttpServletRequest req, HttpServletResponse resp)
- throws IOException {
- Signup s = getForm(req);
- if (s.submit(resp.getWriter(), req)) {
+ public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+ Signup s = Form.getForm(req, Signup.class);
+ if (s == null) {
+ resp.getWriter().println(translate(req, "CSRF token check failed."));
+ } else if (s.submit(resp.getWriter(), req)) {
HttpSession hs = req.getSession();
hs.setAttribute(SIGNUP_PROCESS, null);
- resp.getWriter()
- .println(
- translate(
- req,
- "Your information has been submitted"
- + " into our system. You will now be sent an email with a web link,"
- + " you need to open that link in your web browser within 24 hours"
- + " or your information will be removed from our system!"));
+ resp.getWriter().println(
+ translate(req, "Your information has been submitted"
+ + " into our system. You will now be sent an email with a web link,"
+ + " you need to open that link in your web browser within 24 hours"
+ + " or your information will be removed from our system!"));
return;
}
- super.doPost(req, resp);
+ outputGet(req, resp, s);
}
+
@Override
public boolean needsLogin() {
return false;