]> WPIA git - gigi.git/commitdiff
ADD: SE certificate revoke
authorJanis Streib <janis@dogcraft.de>
Mon, 2 Feb 2015 18:24:13 +0000 (19:24 +0100)
committerJanis Streib <janis@dogcraft.de>
Mon, 2 Feb 2015 18:24:22 +0000 (19:24 +0100)
src/org/cacert/gigi/dbObjects/SupportedUser.java
src/org/cacert/gigi/pages/admin/support/SupportRevokeCertificatesForm.java
src/org/cacert/gigi/pages/admin/support/SupportRevokeCertificatesForm.templ
src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java

index 4ee121007863f4167679936b111b506948a59c47..fe5243dcf6b72f71ded0cbc2ba73359f8acc11ab 100644 (file)
@@ -14,6 +14,7 @@ public class SupportedUser {
     public SupportedUser(User target, User supporter, String ticket) {
         this.supporter = supporter;
         this.target = target;
+        this.ticket = ticket;
     }
 
     public void setName(String fname, String mname, String lname, String suffix) {
@@ -43,4 +44,16 @@ public class SupportedUser {
         prep.executeUpdate();
     }
 
+    public int getId() {
+        return target.getId();
+    }
+
+    public Certificate[] getCertificates(boolean includeRevoked) {
+        return target.getCertificates(includeRevoked);
+    }
+
+    public String getTicket() {
+        return ticket;
+    }
+
 }
index e51a19ec26d514d710ab14a4dee5563a8b3e206d..af02cb53681fc27b62d2ae562d9d6634e85a576b 100644 (file)
@@ -11,7 +11,7 @@ import javax.servlet.http.HttpServletRequest;
 import org.cacert.gigi.GigiApiException;
 import org.cacert.gigi.dbObjects.Certificate;
 import org.cacert.gigi.dbObjects.CertificateProfile;
-import org.cacert.gigi.dbObjects.User;
+import org.cacert.gigi.dbObjects.SupportedUser;
 import org.cacert.gigi.localisation.Language;
 import org.cacert.gigi.output.DateSelector;
 import org.cacert.gigi.output.template.Form;
@@ -22,18 +22,22 @@ public class SupportRevokeCertificatesForm extends Form {
 
     private static Template t;
 
-    private User user;
+    private SupportedUser user;
     static {
         t = new Template(SupportRevokeCertificatesForm.class.getResource("SupportRevokeCertificatesForm.templ"));
     }
 
-    public SupportRevokeCertificatesForm(HttpServletRequest hsr, User user) {
+    public SupportRevokeCertificatesForm(HttpServletRequest hsr, SupportedUser user) {
         super(hsr);
         this.user = user;
     }
 
     @Override
     public boolean submit(PrintWriter out, HttpServletRequest req) throws GigiApiException {
+        if (user.getTicket() != null) {
+            user.revokeAllCertificates();
+            return true;
+        }
         return false;
     }
 
index f4a0060e3de96ccaa1139284387d2d7b728e3e65..5fabb3cf2901fba688013cf987e9a5b37525a100 100644 (file)
@@ -22,7 +22,7 @@
             <? } ?>
         <tr>
             <th colspan="6">
-                    <input value="<?=_revoke certificates?>" type="submit">
+                    <input name="revokeall" value="<?=_revoke certificates?>" type="submit">
             </th>
         </tr>
     </tbody></table>
\ No newline at end of file
index 70146d5f8caa63d9d863d6790972dd412dfc69bd..f1eed52624011a9463e7ac7ac2af84e3494695a9 100644 (file)
@@ -10,6 +10,7 @@ import javax.servlet.http.HttpServletResponse;
 import org.cacert.gigi.GigiApiException;
 import org.cacert.gigi.dbObjects.EmailAddress;
 import org.cacert.gigi.dbObjects.Group;
+import org.cacert.gigi.dbObjects.SupportedUser;
 import org.cacert.gigi.dbObjects.User;
 import org.cacert.gigi.localisation.Language;
 import org.cacert.gigi.output.template.Form;
@@ -33,7 +34,8 @@ public class SupportUserDetailsPage extends Page {
         SupportUserDetailsForm f = new SupportUserDetailsForm(req, user);
         HashMap<String, Object> vars = new HashMap<String, Object>();
         vars.put("details", f);
-        vars.put("ticketNo", req.getSession().getAttribute("ticketNo" + user.getId()));
+        String ticket = (String) req.getSession().getAttribute("ticketNo" + user.getId());
+        vars.put("ticketNo", ticket);
         final EmailAddress[] addrs = user.getEmails();
         vars.put("emails", new IterableDataset() {
 
@@ -52,22 +54,27 @@ public class SupportUserDetailsPage extends Page {
                 return true;
             }
         });
-        vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, user));
+        vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, new SupportedUser(user, getUser(req), ticket)));
         vars.put("tickethandling", new SupportEnterTicketForm(req, user));
         getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
     }
 
     @Override
     public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
-        if (req.getParameter("setTicket") != null) {
-            try {
+        try {
+            if (req.getParameter("setTicket") != null) {
+
                 if ( !Form.getForm(req, SupportEnterTicketForm.class).submit(resp.getWriter(), req)) {
                     throw new GigiApiException("Invalid ticket number!");
                 }
-            } catch (GigiApiException e) {
-                e.printStackTrace();
-                e.format(resp.getWriter(), getLanguage(req));
+            } else if (req.getParameter("revokeall") != null) {
+                if ( !Form.getForm(req, SupportRevokeCertificatesForm.class).submit(resp.getWriter(), req)) {
+                    throw new GigiApiException("No ticket number set.");
+                }
             }
+        } catch (GigiApiException e) {
+            e.printStackTrace();
+            e.format(resp.getWriter(), getLanguage(req));
         }
         super.doPost(req, resp);
     }