1 package org.cacert.gigi.pages.wot;
3 import java.io.PrintWriter;
4 import java.sql.SQLException;
5 import java.text.ParseException;
6 import java.text.SimpleDateFormat;
8 import java.util.HashMap;
11 import javax.servlet.http.HttpServletRequest;
13 import org.cacert.gigi.Language;
14 import org.cacert.gigi.User;
15 import org.cacert.gigi.output.Form;
16 import org.cacert.gigi.output.template.Template;
17 import org.cacert.gigi.pages.LoginPage;
18 import org.cacert.gigi.util.Notary;
19 import org.cacert.gigi.util.Notary.AssuranceResult;
21 public class AssuranceForm extends Form {
23 static final Template templ;
25 templ = new Template(AssuranceForm.class.getResource("AssuranceForm.templ"));
28 public AssuranceForm(HttpServletRequest hsr, int assuree) {
30 this.assuree = new User(assuree);
33 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
36 public void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
37 HashMap<String, Object> res = new HashMap<String, Object>();
39 res.put("name", assuree.getName());
41 res.put("maxpoints", assuree.getMaxAssurePoints());
42 } catch (SQLException e) {
45 res.put("dob", sdf.format(assuree.getDob()));
46 templ.output(out, l, res);
50 public boolean submit(PrintWriter out, HttpServletRequest req) {
51 out.println("<div class='formError'>");
52 boolean failed = false;
54 if (!"1".equals(req.getParameter("certify")) || !"1".equals(req.getParameter("rules"))
55 || !"1".equals(req.getParameter("CCAAgreed")) || !"1".equals(req.getParameter("assertion"))) {
56 outputError(out, req, "You failed to check all boxes to validate"
57 + " your adherence to the rules and policies of CAcert");
61 if (req.getParameter("date") == null || req.getParameter("date").equals("")) {
62 outputError(out, req, "You must enter the date when you met the assuree.");
66 Date d = sdf.parse(req.getParameter("date"));
67 if (d.getTime() > System.currentTimeMillis()) {
68 outputError(out, req, "You must not enter a date in the future.");
71 } catch (ParseException e) {
72 outputError(out, req, "You must enter the date in this format: YYYY-MM-DD.");
76 // check location, min 3 characters
77 if (req.getParameter("location") == null || req.getParameter("location").equals("")) {
78 outputError(out, req, "You failed to enter a location of your meeting.");
80 } else if (req.getParameter("location").length() <= 2) {
81 outputError(out, req, "You must enter a location with at least 3 characters eg town and country.");
85 String points = req.getParameter("points");
86 if (points == null || "".equals(points)) {
91 out.println("</div>");
95 AssuranceResult success = Notary.assure(LoginPage.getUser(req), assuree,
96 Integer.parseInt(req.getParameter("points")), req.getParameter("location"), req.getParameter("date"));
97 if (success != AssuranceResult.ASSURANCE_SUCCEDED) {
98 outputError(out, req, success.getMessage());
100 out.println("</div>");
101 return success == AssuranceResult.ASSURANCE_SUCCEDED;
102 } catch (SQLException e) {
106 out.println("</div>");