X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;ds=sidebyside;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Fwot%2FAssuranceForm.java;h=5819eb4d8b508a40e3c27b7aca9186cecc4df705;hb=70ac38c2e844e293d9815b8703341b94b029977a;hp=809743d61b5d7b38f392b2fa398fbb44a20f7060;hpb=41277f3156ec60c230d670b7f0b18b5646019522;p=gigi.git diff --git a/src/org/cacert/gigi/pages/wot/AssuranceForm.java b/src/org/cacert/gigi/pages/wot/AssuranceForm.java index 809743d6..5819eb4d 100644 --- a/src/org/cacert/gigi/pages/wot/AssuranceForm.java +++ b/src/org/cacert/gigi/pages/wot/AssuranceForm.java @@ -2,16 +2,23 @@ package org.cacert.gigi.pages.wot; import java.io.InputStreamReader; 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 javax.servlet.http.HttpServletRequest; + import org.cacert.gigi.Language; import org.cacert.gigi.User; -import org.cacert.gigi.output.Outputable; +import org.cacert.gigi.output.Form; import org.cacert.gigi.output.Template; -import org.cacert.gigi.util.HTMLEncoder; +import org.cacert.gigi.pages.LoginPage; +import org.cacert.gigi.util.Notary; -public class AssuranceForm implements Outputable { +public class AssuranceForm extends Form { User assuree; static final Template templ; static { @@ -22,19 +29,92 @@ public class AssuranceForm implements Outputable { public AssuranceForm(int assuree) { this.assuree = new User(assuree); } + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); @Override - public void output(PrintWriter out, Language l, Map vars) { + public void outputContent(PrintWriter out, Language l, + Map vars) { HashMap res = new HashMap(); res.putAll(vars); - res.put("fname", HTMLEncoder.encodeHTML(assuree.getFname())); - res.put("mname", - assuree.getMname() == null ? "" : HTMLEncoder - .encodeHTML(assuree.getMname())); - res.put("lname", HTMLEncoder.encodeHTML(assuree.getLname())); - res.put("suffix", - assuree.getSuffix() == null ? "" : HTMLEncoder - .encodeHTML(assuree.getSuffix())); + res.put("name", assuree.getName()); + try { + res.put("maxpoints", assuree.getMaxAssurePoints()); + } catch (SQLException e) { + e.printStackTrace(); + } + res.put("dob", sdf.format(assuree.getDob())); templ.output(out, l, res); } + + @Override + public boolean submit(PrintWriter out, HttpServletRequest req) { + out.println("
"); + boolean failed = false; + + 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"); + failed = true; + + } + if (req.getParameter("date") == null + || req.getParameter("date").equals("")) { + outputError(out, req, + "You must enter the date when you met the assuree."); + failed = true; + } 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."); + failed = true; + } + } catch (ParseException e) { + outputError(out, req, + "You must enter the date in this format: YYYY-MM-DD."); + failed = true; + } + } + // 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."); + failed = true; + } else if (req.getParameter("location").length() <= 2) { + outputError(out, req, + "You must enter a location with at least 3 characters eg town and country."); + failed = true; + } + // TODO checkPoints + String points = req.getParameter("points"); + if (points == null || "".equals(points)) { + // TODO message + failed = true; + } + if (failed) { + out.println("
"); + return false; + } + try { + boolean success = Notary.assure(LoginPage.getUser(req), assuree, + Integer.parseInt(req.getParameter("points")), + req.getParameter("location"), req.getParameter("date")); + if (!success) { + outputError(out, req, + "Assurance failed. Maybe user data changed."); + } + out.println(""); + return success; + } catch (SQLException e) { + e.printStackTrace(); + } + + out.println(""); + return false; + } }