]> WPIA git - gigi.git/blob - src/org/cacert/gigi/pages/wot/AssuranceForm.java
UPD: moved getUser up
[gigi.git] / src / org / cacert / gigi / pages / wot / AssuranceForm.java
1 package org.cacert.gigi.pages.wot;
2
3 import java.io.PrintWriter;
4 import java.sql.SQLException;
5 import java.text.ParseException;
6 import java.text.SimpleDateFormat;
7 import java.util.Date;
8 import java.util.HashMap;
9 import java.util.Map;
10
11 import javax.servlet.http.HttpServletRequest;
12
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.Page;
18 import org.cacert.gigi.util.Notary;
19 import org.cacert.gigi.util.Notary.AssuranceResult;
20
21 public class AssuranceForm extends Form {
22
23     User assuree;
24
25     static final Template templ;
26     static {
27         templ = new Template(AssuranceForm.class.getResource("AssuranceForm.templ"));
28     }
29
30     public AssuranceForm(HttpServletRequest hsr, int assuree) {
31         super(hsr);
32         this.assuree = new User(assuree);
33     }
34
35     SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
36
37     @Override
38     public void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
39         HashMap<String, Object> res = new HashMap<String, Object>();
40         res.putAll(vars);
41         res.put("name", assuree.getName());
42         try {
43             res.put("maxpoints", assuree.getMaxAssurePoints());
44         } catch (SQLException e) {
45             e.printStackTrace();
46         }
47         res.put("dob", sdf.format(assuree.getDob()));
48         templ.output(out, l, res);
49     }
50
51     @Override
52     public boolean submit(PrintWriter out, HttpServletRequest req) {
53         out.println("<div class='formError'>");
54         boolean failed = false;
55
56         if ( !"1".equals(req.getParameter("certify")) || !"1".equals(req.getParameter("rules")) || !"1".equals(req.getParameter("CCAAgreed")) || !"1".equals(req.getParameter("assertion"))) {
57             outputError(out, req, "You failed to check all boxes to validate" + " your adherence to the rules and policies of CAcert");
58             failed = true;
59
60         }
61         if (req.getParameter("date") == null || req.getParameter("date").equals("")) {
62             outputError(out, req, "You must enter the date when you met the assuree.");
63             failed = true;
64         } else {
65             try {
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.");
69                     failed = true;
70                 }
71             } catch (ParseException e) {
72                 outputError(out, req, "You must enter the date in this format: YYYY-MM-DD.");
73                 failed = true;
74             }
75         }
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.");
79             failed = true;
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.");
82             failed = true;
83         }
84         // TODO checkPoints
85         String points = req.getParameter("points");
86         if (points == null || "".equals(points)) {
87             // TODO message
88             failed = true;
89         }
90         if (failed) {
91             out.println("</div>");
92             return false;
93         }
94         try {
95             AssuranceResult success = Notary.assure(Page.getUser(req), assuree, Integer.parseInt(req.getParameter("points")), req.getParameter("location"), req.getParameter("date"));
96             if (success != AssuranceResult.ASSURANCE_SUCCEDED) {
97                 outputError(out, req, success.getMessage());
98             }
99             out.println("</div>");
100             return success == AssuranceResult.ASSURANCE_SUCCEDED;
101         } catch (SQLException e) {
102             e.printStackTrace();
103         }
104
105         out.println("</div>");
106         return false;
107     }
108
109 }