X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Fwot%2FAssuranceForm.java;h=15642403851806c7f204284a41f20fa1a4f74e7f;hb=dd37e9febc793a8ab08ed3647108cbd017c74527;hp=5240fc4cd86187cf39c6740524a8b01119627c04;hpb=36af379666d84138230d9c53b583509514ce5e05;p=gigi.git diff --git a/src/org/cacert/gigi/pages/wot/AssuranceForm.java b/src/org/cacert/gigi/pages/wot/AssuranceForm.java index 5240fc4c..15642403 100644 --- a/src/org/cacert/gigi/pages/wot/AssuranceForm.java +++ b/src/org/cacert/gigi/pages/wot/AssuranceForm.java @@ -1,43 +1,157 @@ package org.cacert.gigi.pages.wot; -import java.io.InputStreamReader; import java.io.PrintWriter; +import java.text.SimpleDateFormat; import java.util.HashMap; +import java.util.Iterator; +import java.util.LinkedList; import java.util.Map; import javax.servlet.http.HttpServletRequest; -import org.cacert.gigi.Language; -import org.cacert.gigi.User; -import org.cacert.gigi.output.Form; -import org.cacert.gigi.output.Template; +import org.cacert.gigi.GigiApiException; +import org.cacert.gigi.dbObjects.Assurance.AssuranceType; +import org.cacert.gigi.dbObjects.Name; +import org.cacert.gigi.dbObjects.User; +import org.cacert.gigi.localisation.Language; +import org.cacert.gigi.output.template.Form; +import org.cacert.gigi.output.template.IterableDataset; +import org.cacert.gigi.output.template.Template; +import org.cacert.gigi.pages.Page; +import org.cacert.gigi.pages.PasswordResetPage; +import org.cacert.gigi.util.DayDate; +import org.cacert.gigi.util.Notary; public class AssuranceForm extends Form { - User assuree; - static final Template templ; - static { - templ = new Template(new InputStreamReader( - AssuranceForm.class.getResourceAsStream("AssuranceForm.templ"))); - } - - public AssuranceForm(int assuree) { - this.assuree = new User(assuree); - } - - @Override - public void output(PrintWriter out, Language l, Map vars) { - HashMap res = new HashMap(); - res.putAll(vars); - res.put("name", assuree.getName()); - templ.output(out, l, res); - } - - @Override - public boolean submit(PrintWriter out, HttpServletRequest req) { - if (!"1".equals(req.getAttribute("certify"))) { - // s - - } - return false; - } + + private User assuree; + + private Name assureeName; + + private DayDate dob; + + private String location = ""; + + private String date = ""; + + private String aword; + + private User assurer; + + private AssuranceType type = AssuranceType.FACE_TO_FACE; + + private static final Template templ; + static { + templ = new Template(AssuranceForm.class.getResource("AssuranceForm.templ")); + } + + public AssuranceForm(HttpServletRequest hsr, User assuree) { + super(hsr); + assurer = Page.getUser(hsr); + this.assuree = assuree; + assureeName = this.assuree.getName(); + dob = this.assuree.getDoB(); + } + + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); + + SimpleDateFormat sdf2 = new SimpleDateFormat("dd. MMM yyyy"); + + @Override + public void outputContent(PrintWriter out, Language l, Map vars) { + HashMap res = new HashMap(); + res.putAll(vars); + res.put("nameExplicit", assuree.getName()); + res.put("name", assuree.getName().toString()); + res.put("maxpoints", assurer.getMaxAssurePoints()); + res.put("dob", sdf.format(assuree.getDoB().toDate())); + res.put("dobFmt2", sdf2.format(assuree.getDoB().toDate())); + res.put("location", location); + res.put("date", date); + res.put("aword", aword); + final LinkedList ats = new LinkedList<>(); + for (AssuranceType at : AssuranceType.values()) { + try { + Notary.may(assurer, assuree, at); + ats.add(at); + } catch (GigiApiException e) { + } + } + res.put("ats", new IterableDataset() { + + Iterator t = ats.iterator(); + + @Override + public boolean next(Language l, Map vars) { + if ( !t.hasNext()) { + return false; + } + AssuranceType t1 = t.next(); + vars.put("type", t1.getDescription()); + vars.put("id", t1.toString()); + vars.put("sel", t1 == type ? " selected" : ""); + return true; + } + }); + templ.output(out, l, res); + } + + @Override + public boolean submit(PrintWriter out, HttpServletRequest req) throws GigiApiException { + location = req.getParameter("location"); + date = req.getParameter("date"); + GigiApiException gae = new GigiApiException(); + if (date == null || location == null) { + gae.mergeInto(new GigiApiException("You need to enter location and date!")); + } + + if ( !"1".equals(req.getParameter("certify")) || !"1".equals(req.getParameter("rules")) || !"1".equals(req.getParameter("tos_agree")) || !"1".equals(req.getParameter("assertion"))) { + gae.mergeInto(new GigiApiException("You failed to check all boxes to validate" + " your adherence to the rules and policies of SomeCA")); + } + if ("1".equals(req.getParameter("passwordReset"))) { + aword = req.getParameter("passwordResetValue"); + if ("".equals(aword)) { + aword = null; + } + } else { + aword = null; + } + String val = req.getParameter("assuranceType"); + if (val != null) { + try { + type = AssuranceType.valueOf(val); + } catch (IllegalArgumentException e) { + gae.mergeInto(new GigiApiException("Assurance Type wrong.")); + } + } + + int pointsI = 0; + String points = req.getParameter("points"); + if (points == null || "".equals(points)) { + gae.mergeInto(new GigiApiException("For an assurance, you need to enter points.")); + } else { + try { + pointsI = Integer.parseInt(points); + } catch (NumberFormatException e) { + gae.mergeInto(new GigiApiException("The points entered were not a number.")); + } + } + + if ( !gae.isEmpty()) { + throw gae; + } + Notary.assure(assurer, assuree, assureeName, dob, pointsI, location, req.getParameter("date"), type); + if (aword != null && !aword.equals("")) { + Language l = Language.getInstance(assuree.getPreferredLocale()); + String method = l.getTranslation("A password reset was triggered. If you did a password reset by assurance, please enter your secret password using this form:"); + String subject = l.getTranslation("Password reset by assurance"); + PasswordResetPage.initPasswordResetProcess(out, assuree, req, aword, l, method, subject); + } + return true; + } + + public User getAssuree() { + return assuree; + } + }