X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Fadmin%2Fsupport%2FSupportUserDetailsForm.java;h=21c2183beb596fe22f3c5f8313a7b8ca3ff7240c;hb=39bf8d9363076e87bab590b9dec48cea36a2b872;hp=af5272aa221f205aaab7d08ef81d34dd3180a379;hpb=c4e4a54f12c4eff9958ae0c2b9408be70ac9e605;p=gigi.git diff --git a/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsForm.java b/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsForm.java index af5272aa..21c2183b 100644 --- a/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsForm.java +++ b/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsForm.java @@ -7,49 +7,77 @@ import javax.servlet.http.HttpServletRequest; import org.cacert.gigi.GigiApiException; import org.cacert.gigi.dbObjects.Group; +import org.cacert.gigi.dbObjects.Name; +import org.cacert.gigi.dbObjects.SupportedUser; import org.cacert.gigi.dbObjects.User; import org.cacert.gigi.localisation.Language; import org.cacert.gigi.output.DateSelector; import org.cacert.gigi.output.template.Form; import org.cacert.gigi.output.template.Template; +import sun.security.pkcs11.Secmod.DbMode; + public class SupportUserDetailsForm extends Form { private static Template t; - private User user; + private SupportedUser user; + + private DateSelector dobSelector; static { t = new Template(FindDomainForm.class.getResource("SupportUserDetailsForm.templ")); } - public SupportUserDetailsForm(HttpServletRequest hsr, User user) { + public SupportUserDetailsForm(HttpServletRequest hsr, SupportedUser user) { super(hsr); this.user = user; + dobSelector = new DateSelector("dobd", "dobm", "doby", user.getTargetUser().getDoB()); } @Override public boolean submit(PrintWriter out, HttpServletRequest req) throws GigiApiException { - return false; + if (user.getTicket() == null) { + return false; + } + dobSelector.update(req); + String fname = req.getParameter("fname"); + String mname = req.getParameter("mname"); + String lname = req.getParameter("lname"); + String suffix = req.getParameter("suffix"); + if (fname == null || mname == null || lname == null | suffix == null) { + throw new GigiApiException("Incomplete request!"); + } + if ( !dobSelector.isValid()) { + throw new GigiApiException("Invalid date of birth!"); + } + Name newName = new Name(fname, lname, mname, suffix); + if (user.setDob(dobSelector.getDate()) | user.setName(newName)) { + user.submitSupportAction(); + } + return true; } @Override protected void outputContent(PrintWriter out, Language l, Map vars) { + User user = this.user.getTargetUser(); + Name name = user.getName(); vars.put("mail", user.getEmail()); - vars.put("fname", user.getFname()); - vars.put("mname", user.getMname()); - vars.put("lname", user.getLname()); - vars.put("suffix", user.getSuffix()); + vars.put("fname", name.getFname()); + vars.put("mname", name.getMname()); + vars.put("lname", name.getLname()); + vars.put("suffix", name.getSuffix()); vars.put("assurer", user.canAssure()); - vars.put("dob", new DateSelector("dobd", "dobm", "doby", user.getDob())); - vars.put("blockedassurer", user.isInGroup(Group.getByString("blockedassurer"))); - vars.put("codesign", user.isInGroup(Group.getByString("codesigning"))); - vars.put("orgassurer", user.isInGroup(Group.getByString("orgassurer"))); + vars.put("dob", dobSelector); + vars.put("blockedassurer", user.isInGroup(Group.BLOCKEDASSURER)); + vars.put("codesign", user.isInGroup(Group.CODESIGNING)); + vars.put("orgassurer", user.isInGroup(Group.ORGASSURER)); vars.put("assurancepoints", user.getAssurancePoints()); - vars.put("blockedassuree", user.isInGroup(Group.getByString("blockedassuree"))); - vars.put("ttpassurer", user.isInGroup(Group.getByString("ttpassurer"))); - vars.put("ttpapplicant", user.isInGroup(Group.getByString("ttpapplicant"))); - vars.put("blockedlogin", user.isInGroup(Group.getByString("blockedlogin"))); + vars.put("blockedassuree", user.isInGroup(Group.BLOCKEDASSUREE)); + vars.put("ttpassurer", user.isInGroup(Group.TTP_ASSURER)); + vars.put("ttpapplicant", user.isInGroup(Group.TTP_APPLICANT)); + vars.put("blockedlogin", user.isInGroup(Group.BLOCKEDLOGIN)); + vars.put("supporter", user.isInGroup(Group.SUPPORTER)); vars.put("id", user.getId()); t.output(out, l, vars); }