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.User;
14 import org.cacert.gigi.localisation.Language;
15 import org.cacert.gigi.output.Form;
16 import org.cacert.gigi.output.template.Template;
17 import org.cacert.gigi.pages.Page;
18 import org.cacert.gigi.util.Notary;
19 import org.cacert.gigi.util.Notary.AssuranceResult;
21 public class AssuranceForm extends Form {
25 static final Template templ;
27 templ = new Template(AssuranceForm.class.getResource("AssuranceForm.templ"));
30 public AssuranceForm(HttpServletRequest hsr, int assuree) {
32 this.assuree = new User(assuree);
35 SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
38 public void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
39 HashMap<String, Object> res = new HashMap<String, Object>();
41 res.put("name", assuree.getName());
43 res.put("maxpoints", assuree.getMaxAssurePoints());
44 } catch (SQLException e) {
47 res.put("dob", sdf.format(assuree.getDob()));
48 templ.output(out, l, res);
52 public boolean submit(PrintWriter out, HttpServletRequest req) {
53 if ( !"1".equals(req.getParameter("certify")) || !"1".equals(req.getParameter("rules")) || !"1".equals(req.getParameter("CCAAgreed")) || !"1".equals(req.getParameter("assertion"))) {
54 outputError(out, req, "You failed to check all boxes to validate" + " your adherence to the rules and policies of CAcert");
57 if (req.getParameter("date") == null || req.getParameter("date").equals("")) {
58 outputError(out, req, "You must enter the date when you met the assuree.");
61 Date d = sdf.parse(req.getParameter("date"));
62 if (d.getTime() > System.currentTimeMillis()) {
63 outputError(out, req, "You must not enter a date in the future.");
65 } catch (ParseException e) {
66 outputError(out, req, "You must enter the date in this format: YYYY-MM-DD.");
69 // check location, min 3 characters
70 if (req.getParameter("location") == null || req.getParameter("location").equals("")) {
71 outputError(out, req, "You failed to enter a location of your meeting.");
72 } else if (req.getParameter("location").length() <= 2) {
73 outputError(out, req, "You must enter a location with at least 3 characters eg town and country.");
76 String points = req.getParameter("points");
77 if (points == null || "".equals(points)) {
78 outputError(out, req, "For an assurance, you need to enter points.");
84 AssuranceResult success = Notary.assure(Page.getUser(req), assuree, Integer.parseInt(req.getParameter("points")), req.getParameter("location"), req.getParameter("date"));
85 if (success != AssuranceResult.ASSURANCE_SUCCEDED) {
86 outputError(out, req, success.getMessage());
88 return success == AssuranceResult.ASSURANCE_SUCCEDED;
89 } catch (SQLException e) {