X-Git-Url: https://code.wpia.club/?a=blobdiff_plain;f=src%2Forg%2Fcacert%2Fgigi%2Fpages%2Fadmin%2Fsupport%2FSupportUserDetailsPage.java;h=5cc35b53a9698c7c581d01c6292bbf973e31e86b;hb=63793f220fc6d84cf332df2c0e0416f096a4f007;hp=afacb56c86e3edbfda135e4aac6f2d746aace52a;hpb=20199b0674ff5acf61343b6640a1895fb54a9914;p=gigi.git diff --git a/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java b/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java index afacb56c..5cc35b53 100644 --- a/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java +++ b/src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java @@ -9,13 +9,14 @@ 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; import org.cacert.gigi.output.template.IterableDataset; +import org.cacert.gigi.pages.LoginPage; import org.cacert.gigi.pages.Page; +import org.cacert.gigi.util.AuthorizationContext; public class SupportUserDetailsPage extends Page { @@ -30,20 +31,15 @@ public class SupportUserDetailsPage extends Page { int id = -1; String[] idP = req.getPathInfo().split("/"); try { - if (req.getPathInfo().endsWith("history") || req.getPathInfo().endsWith("trainings")) { - id = Integer.parseInt(idP[idP.length - 2]); - } else { - id = Integer.parseInt(idP[idP.length - 1]); - } + id = Integer.parseInt(idP[idP.length - 1]); } catch (NumberFormatException e) { resp.sendError(404); } final User user = User.getById(id); - String ticket = (String) req.getSession().getAttribute("ticketNo" + user.getId()); - SupportUserDetailsForm f = new SupportUserDetailsForm(req, new SupportedUser(user, getUser(req), ticket)); + SupportedUser targetUser = new SupportedUser(user, getUser(req), LoginPage.getAuthorizationContext(req).getSupporterTicketId()); + SupportUserDetailsForm f = new SupportUserDetailsForm(req, targetUser); HashMap vars = new HashMap(); vars.put("details", f); - vars.put("ticketNo", ticket); final EmailAddress[] addrs = user.getEmails(); vars.put("emails", new IterableDataset() { @@ -51,35 +47,28 @@ public class SupportUserDetailsPage extends Page { @Override public boolean next(Language l, Map vars) { - if (i == addrs.length) { - return false; - } - String address = addrs[i].getAddress(); - i++; - if ( !address.equals(user.getEmail())) { - vars.put("secmail", address); + for (; i < addrs.length;) { + String address = addrs[i++].getAddress(); + if ( !address.equals(user.getEmail())) { + vars.put("secmail", address); + return true; + } } - return true; + return false; } }); - vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, new SupportedUser(user, getUser(req), ticket))); - vars.put("tickethandling", new SupportEnterTicketForm(req, user)); + vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, targetUser)); getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars); } @Override public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException { try { - if (req.getParameter("setTicket") != null) { - - if ( !Form.getForm(req, SupportEnterTicketForm.class).submit(resp.getWriter(), req)) { - throw new GigiApiException("Invalid ticket number!"); - } - } else if (req.getParameter("revokeall") != null) { + if (req.getParameter("revokeall") != null) { if ( !Form.getForm(req, SupportRevokeCertificatesForm.class).submit(resp.getWriter(), req)) { throw new GigiApiException("No ticket number set."); } - } else if (req.getParameter("detailupdate") != null) { + } else if (req.getParameter("detailupdate") != null || req.getParameter("resetPass") != null || req.getParameter("deny") != null || req.getParameter("grant") != null) { if ( !Form.getForm(req, SupportUserDetailsForm.class).submit(resp.getWriter(), req)) { throw new GigiApiException("No ticket number set."); } @@ -92,10 +81,7 @@ public class SupportUserDetailsPage extends Page { } @Override - public boolean isPermitted(User u) { - if (u == null) { - return false; - } - return u.isInGroup(Group.SUPPORTER); + public boolean isPermitted(AuthorizationContext ac) { + return ac != null && ac.canSupport(); } }