]> WPIA git - gigi.git/commitdiff
ADD: TTP-Admin draft
authorFelix Dörre <felix@dogcraft.de>
Sun, 21 Sep 2014 14:44:51 +0000 (16:44 +0200)
committerFelix Dörre <felix@dogcraft.de>
Sun, 21 Sep 2014 14:44:51 +0000 (16:44 +0200)
src/org/cacert/gigi/Gigi.java
src/org/cacert/gigi/dbObjects/Group.java
src/org/cacert/gigi/pages/admin/TTPAdminPage.java [new file with mode: 0644]
src/org/cacert/gigi/pages/admin/TTPAdminPage.templ [new file with mode: 0644]

index f6b02f4568bf7dde1c34a39eb8033203e85a4602..60e785b0499510d0f1379103e95b8a33c720f483 100644 (file)
@@ -41,6 +41,7 @@ import org.cacert.gigi.pages.account.certs.CertificateAdd;
 import org.cacert.gigi.pages.account.certs.Certificates;
 import org.cacert.gigi.pages.account.domain.DomainOverview;
 import org.cacert.gigi.pages.account.mail.MailOverview;
+import org.cacert.gigi.pages.admin.TTPAdminPage;
 import org.cacert.gigi.pages.error.PageNotFound;
 import org.cacert.gigi.pages.main.RegisterPage;
 import org.cacert.gigi.pages.wot.AssurePage;
@@ -106,6 +107,7 @@ public class Gigi extends HttpServlet {
             putPage(DomainOverview.PATH + "*", new DomainOverview("Domains"), "Certificates");
             putPage(MyPoints.PATH, new MyPoints("My Points"), "CAcert Web of Trust");
             putPage(RequestTTPPage.PATH, new RequestTTPPage(), "CAcert Web of Trust");
+            putPage(TTPAdminPage.PATH + "/*", new TTPAdminPage(), "Admin");
             putPage("/wot/rules", new StaticPage("CAcert Web of Trust Rules", AssurePage.class.getResourceAsStream("Rules.templ")), "CAcert Web of Trust");
             baseTemplate = new Template(Gigi.class.getResource("Gigi.templ"));
             rootMenu = new Menu("Main");
index bdce278da0979f047d379ed0f1f1648481ec888f..69f8e40bf7434422bf56a957ffaceec528a0601a 100644 (file)
@@ -2,6 +2,10 @@ package org.cacert.gigi.dbObjects;
 
 import java.util.HashMap;
 
+import org.cacert.gigi.database.DatabaseConnection;
+import org.cacert.gigi.database.GigiPreparedStatement;
+import org.cacert.gigi.database.GigiResultSet;
+
 public class Group {
 
     private static HashMap<String, Group> cache = new HashMap<>();
@@ -54,4 +58,20 @@ public class Group {
     public String getDatabaseName() {
         return dbName;
     }
+
+    public User[] getMembers(int offset, int count) {
+        GigiPreparedStatement gps = DatabaseConnection.getInstance().prepare("SELECT user FROM user_groups WHERE permission=? AND deleted is NULL LIMIT ?,?");
+        gps.setString(1, dbName);
+        gps.setInt(2, offset);
+        gps.setInt(3, count);
+        GigiResultSet grs = gps.executeQuery();
+        grs.last();
+        User[] users = new User[grs.getRow()];
+        int i = 0;
+        grs.beforeFirst();
+        while (grs.next()) {
+            users[i++] = User.getById(grs.getInt(1));
+        }
+        return users;
+    }
 }
diff --git a/src/org/cacert/gigi/pages/admin/TTPAdminPage.java b/src/org/cacert/gigi/pages/admin/TTPAdminPage.java
new file mode 100644 (file)
index 0000000..0d0f438
--- /dev/null
@@ -0,0 +1,64 @@
+package org.cacert.gigi.pages.admin;
+
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+
+import org.cacert.gigi.dbObjects.Group;
+import org.cacert.gigi.dbObjects.User;
+import org.cacert.gigi.localisation.Language;
+import org.cacert.gigi.output.template.IterableDataset;
+import org.cacert.gigi.pages.Page;
+
+public class TTPAdminPage extends Page {
+
+    public static final String PATH = "/admin/ttp";
+
+    private static final Group TTP_APPLICANT = Group.getByString("ttp-applicant");
+
+    public TTPAdminPage() {
+        super("TTP-Admin");
+    }
+
+    @Override
+    public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+        String path = req.getPathInfo();
+        if (path != null && path.length() > PATH.length()) {
+            int id = Integer.parseInt(path.substring(1 + PATH.length()));
+            resp.getWriter().println("processing: " + id); // TODO
+            User u = User.getById(id);
+            if ( !u.isInGroup(TTP_APPLICANT)) {
+                return;
+            }
+            return;
+        }
+        final User[] users = TTP_APPLICANT.getMembers(0, 30);
+        HashMap<String, Object> vars = new HashMap<>();
+        vars.put("users", new IterableDataset() {
+
+            int i = 0;
+
+            @Override
+            public boolean next(Language l, Map<String, Object> vars) {
+                if (i >= users.length) {
+                    return false;
+                }
+                vars.put("id", Integer.toString(users[i].getId()));
+                vars.put("name", users[i].getName().toString());
+                vars.put("email", users[i].getEmail());
+
+                i++;
+                return true;
+            }
+        });
+        getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
+    }
+
+    @Override
+    public boolean isPermitted(User u) {
+        return u != null && u.isInGroup(Group.getByString("ttp-assuer"));
+    }
+}
diff --git a/src/org/cacert/gigi/pages/admin/TTPAdminPage.templ b/src/org/cacert/gigi/pages/admin/TTPAdminPage.templ
new file mode 100644 (file)
index 0000000..e80cea2
--- /dev/null
@@ -0,0 +1,5 @@
+<table class="wrapper dataTable">
+<? foreach($users) { ?>
+<tr><td><?=$name?></td><td><?=$email?></td><td><a href="/admin/ttp/<?=$id?>">Process</a></td></tr>
+<? } ?>
+</table>
\ No newline at end of file