]> WPIA git - gigi.git/blobdiff - src/club/wpia/gigi/pages/admin/support/FindCertPage.java
upd: rename package name and all references to it
[gigi.git] / src / club / wpia / gigi / pages / admin / support / FindCertPage.java
diff --git a/src/club/wpia/gigi/pages/admin/support/FindCertPage.java b/src/club/wpia/gigi/pages/admin/support/FindCertPage.java
new file mode 100644 (file)
index 0000000..0d2edbc
--- /dev/null
@@ -0,0 +1,89 @@
+package club.wpia.gigi.pages.admin.support;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+
+import club.wpia.gigi.dbObjects.Certificate;
+import club.wpia.gigi.dbObjects.Certificate.SubjectAlternateName;
+import club.wpia.gigi.localisation.Language;
+import club.wpia.gigi.output.ArrayIterable;
+import club.wpia.gigi.output.template.Form;
+import club.wpia.gigi.output.template.IterableDataset;
+import club.wpia.gigi.output.template.SprintfCommand;
+import club.wpia.gigi.pages.LoginPage;
+import club.wpia.gigi.pages.Page;
+import club.wpia.gigi.pages.account.certs.Certificates;
+import club.wpia.gigi.util.AuthorizationContext;
+
+public class FindCertPage extends Page {
+
+    public static final String PATH = "/support/find/certs";
+
+    public FindCertPage() {
+        super("Find Certificate");
+    }
+
+    @Override
+    public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+        new FindCertForm(req).output(resp.getWriter(), Page.getLanguage(req), new HashMap<String, Object>());
+    }
+
+    @Override
+    public boolean beforePost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+        return Form.getForm(req, FindCertForm.class).submitExceptionProtected(req, resp);
+    }
+
+    @Override
+    public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+        if ( !Form.printFormErrors(req, resp.getWriter())) {
+            final Certificate[] certs = ((FindCertForm.FindResult) req.getAttribute(Form.SUBMIT_RESULT)).getCerts();
+            if (certs.length == 1) {
+                resp.sendRedirect(Certificates.SUPPORT_PATH + "/" + certs[0].getSerial());
+            } else {
+                HashMap<String, Object> vars = new HashMap<String, Object>();
+                Language l = LoginPage.getLanguage(req);
+                if (certs.length >= 100) {
+                    vars.put("limit", l.getTranslation("100 or more entries available, only the first 100 are displayed."));
+                } else {
+                    vars.put("limit", SprintfCommand.createSimple("{0} entries found", certs.length));
+                }
+                vars.put("certtable", new ArrayIterable<Certificate>(certs) {
+
+                    @Override
+                    public void apply(Certificate t, Language l, Map<String, Object> vars) {
+                        vars.put("id", t.getId());
+                        vars.put("serial", t.getSerial());
+
+                        final List<SubjectAlternateName> san = t.getSANs();
+                        vars.put("san", new IterableDataset() {
+
+                            int j = 0;
+
+                            @Override
+                            public boolean next(Language l, Map<String, Object> vars) {
+                                if (j == san.size()) {
+                                    return false;
+                                }
+                                vars.put("entry", san.get(j).getName() + (j < san.size() - 1 ? ", " : ""));
+                                j++;
+                                return true;
+                            }
+
+                        });
+                    }
+                });
+                getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
+            }
+        }
+    }
+
+    @Override
+    public boolean isPermitted(AuthorizationContext ac) {
+        return ac != null && ac.canSupport();
+    }
+}