]> WPIA git - gigi.git/blobdiff - src/org/cacert/gigi/pages/wot/AssuranceForm.java
Move the "dbObject"s to their own package.
[gigi.git] / src / org / cacert / gigi / pages / wot / AssuranceForm.java
index 28a1ddfbd0a3dc935fb79f571448d9c066bb7374..3df399426afb2411fd15b3e4fd8e3e1375e8773a 100644 (file)
 package org.cacert.gigi.pages.wot;
 
 import java.io.PrintWriter;
+import java.sql.SQLException;
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.Date;
+import java.util.HashMap;
 import java.util.Map;
 
-import org.cacert.gigi.Language;
-import org.cacert.gigi.output.Outputable;
+import javax.servlet.http.HttpServletRequest;
 
-public class AssuranceForm implements Outputable {
+import org.cacert.gigi.dbObjects.User;
+import org.cacert.gigi.localisation.Language;
+import org.cacert.gigi.output.Form;
+import org.cacert.gigi.output.template.Template;
+import org.cacert.gigi.pages.Page;
+import org.cacert.gigi.util.Notary;
+import org.cacert.gigi.util.Notary.AssuranceResult;
 
-       @Override
-       public void output(PrintWriter out, Language l, Map<String, Object> vars) {
+public class AssuranceForm extends Form {
 
-       }
+    private User assuree;
+
+    private static final Template templ;
+    static {
+        templ = new Template(AssuranceForm.class.getResource("AssuranceForm.templ"));
+    }
+
+    public AssuranceForm(HttpServletRequest hsr, int assuree) {
+        super(hsr);
+        this.assuree = new User(assuree);
+    }
+
+    SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
+
+    SimpleDateFormat sdf2 = new SimpleDateFormat("dd. MMM yyyy");
+
+    @Override
+    public void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
+        HashMap<String, Object> res = new HashMap<String, Object>();
+        res.putAll(vars);
+        res.put("nameExplicit", assuree.getName());
+        res.put("name", assuree.getName().toString());
+        try {
+            res.put("maxpoints", assuree.getMaxAssurePoints());
+        } catch (SQLException e) {
+            e.printStackTrace();
+        }
+        res.put("dob", sdf.format(assuree.getDob()));
+        res.put("dobFmt2", sdf2.format(assuree.getDob()));
+        templ.output(out, l, res);
+    }
+
+    @Override
+    public boolean submit(PrintWriter out, HttpServletRequest req) {
+        if ( !"1".equals(req.getParameter("certify")) || !"1".equals(req.getParameter("rules")) || !"1".equals(req.getParameter("CCAAgreed")) || !"1".equals(req.getParameter("assertion"))) {
+            outputError(out, req, "You failed to check all boxes to validate" + " your adherence to the rules and policies of CAcert");
+
+        }
+        if (req.getParameter("date") == null || req.getParameter("date").equals("")) {
+            outputError(out, req, "You must enter the date when you met the assuree.");
+        } else {
+            try {
+                Date d = sdf.parse(req.getParameter("date"));
+                if (d.getTime() > System.currentTimeMillis()) {
+                    outputError(out, req, "You must not enter a date in the future.");
+                }
+            } catch (ParseException e) {
+                outputError(out, req, "You must enter the date in this format: YYYY-MM-DD.");
+            }
+        }
+        // check location, min 3 characters
+        if (req.getParameter("location") == null || req.getParameter("location").equals("")) {
+            outputError(out, req, "You failed to enter a location of your meeting.");
+        } else if (req.getParameter("location").length() <= 2) {
+            outputError(out, req, "You must enter a location with at least 3 characters eg town and country.");
+        }
+        // TODO checkPoints
+        String points = req.getParameter("points");
+        if (points == null || "".equals(points)) {
+            outputError(out, req, "For an assurance, you need to enter points.");
+        }
+        if (isFailed(out)) {
+            return false;
+        }
+        try {
+            AssuranceResult success = Notary.assure(Page.getUser(req), assuree, Integer.parseInt(req.getParameter("points")), req.getParameter("location"), req.getParameter("date"));
+            if (success != AssuranceResult.ASSURANCE_SUCCEDED) {
+                outputError(out, req, success.getMessage());
+            }
+            return success == AssuranceResult.ASSURANCE_SUCCEDED;
+        } catch (SQLException e) {
+            e.printStackTrace();
+        }
+
+        return false;
+    }
+
+    public User getAssuree() {
+        return assuree;
+    }
 
 }