1 package org.cacert.gigi.pages.admin.support;
3 import java.io.IOException;
4 import java.util.HashMap;
7 import javax.servlet.http.HttpServletRequest;
8 import javax.servlet.http.HttpServletResponse;
10 import org.cacert.gigi.dbObjects.EmailAddress;
11 import org.cacert.gigi.localisation.Language;
12 import org.cacert.gigi.output.template.Form;
13 import org.cacert.gigi.output.template.IterableDataset;
14 import org.cacert.gigi.output.template.Template;
15 import org.cacert.gigi.pages.Page;
16 import org.cacert.gigi.util.AuthorizationContext;
18 public class FindUserByEmailPage extends Page {
20 public static final String PATH = "/support/find/email";
22 private static final Template USERTABLE = new Template(FindUserByDomainPage.class.getResource("FindUserByEmailUsertable.templ"));
24 public FindUserByEmailPage() {
29 public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
30 new FindUserByEmailForm(req).output(resp.getWriter(), Page.getLanguage(req), new HashMap<String, Object>());
34 public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
35 FindUserByEmailForm form = Form.getForm(req, FindUserByEmailForm.class);
36 if (form.submitProtected(resp.getWriter(), req)) {
37 final EmailAddress[] emails = form.getEmails();
38 if (emails.length == 1) {
39 resp.sendRedirect(SupportUserDetailsPage.PATH + emails[0].getOwner().getId() + "/");
41 HashMap<String, Object> vars = new HashMap<String, Object>();
42 vars.put("usertable", new IterableDataset() {
47 public boolean next(Language l, Map<String, Object> vars) {
48 if (i == emails.length) {
51 vars.put("usrid", emails[i].getOwner().getId());
52 vars.put("usermail", emails[i].getAddress());
57 USERTABLE.output(resp.getWriter(), getLanguage(req), vars);
63 public boolean isPermitted(AuthorizationContext ac) {
64 return ac != null && ac.canSupport();