]> WPIA git - gigi.git/blob - src/org/cacert/gigi/pages/admin/support/SupportUserDetailsPage.java
UPD: Allow 2-level wildcard pages
[gigi.git] / src / org / cacert / gigi / pages / admin / support / SupportUserDetailsPage.java
1 package org.cacert.gigi.pages.admin.support;
2
3 import java.io.IOException;
4 import java.util.HashMap;
5 import java.util.Map;
6
7 import javax.servlet.http.HttpServletRequest;
8 import javax.servlet.http.HttpServletResponse;
9
10 import org.cacert.gigi.GigiApiException;
11 import org.cacert.gigi.dbObjects.EmailAddress;
12 import org.cacert.gigi.dbObjects.Group;
13 import org.cacert.gigi.dbObjects.SupportedUser;
14 import org.cacert.gigi.dbObjects.User;
15 import org.cacert.gigi.localisation.Language;
16 import org.cacert.gigi.output.template.Form;
17 import org.cacert.gigi.output.template.IterableDataset;
18 import org.cacert.gigi.pages.Page;
19
20 public class SupportUserDetailsPage extends Page {
21
22     public static final String PATH = "/support/user/";
23
24     public SupportUserDetailsPage(String title) {
25         super(title);
26     }
27
28     @Override
29     public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
30         int id = -1;
31         String[] idP = req.getPathInfo().split("/");
32         try {
33             if (req.getPathInfo().endsWith("history") || req.getPathInfo().endsWith("trainings")) {
34                 id = Integer.parseInt(idP[idP.length - 2]);
35             } else {
36                 id = Integer.parseInt(idP[idP.length - 1]);
37             }
38         } catch (NumberFormatException e) {
39             resp.sendError(404);
40         }
41         final User user = User.getById(id);
42         String ticket = (String) req.getSession().getAttribute("ticketNo" + user.getId());
43         SupportUserDetailsForm f = new SupportUserDetailsForm(req, new SupportedUser(user, getUser(req), ticket));
44         HashMap<String, Object> vars = new HashMap<String, Object>();
45         vars.put("details", f);
46         vars.put("ticketNo", ticket);
47         final EmailAddress[] addrs = user.getEmails();
48         vars.put("emails", new IterableDataset() {
49
50             int i = 0;
51
52             @Override
53             public boolean next(Language l, Map<String, Object> vars) {
54                 if (i == addrs.length) {
55                     return false;
56                 }
57                 String address = addrs[i].getAddress();
58                 i++;
59                 if ( !address.equals(user.getEmail())) {
60                     vars.put("secmail", address);
61                 }
62                 return true;
63             }
64         });
65         vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, new SupportedUser(user, getUser(req), ticket)));
66         vars.put("tickethandling", new SupportEnterTicketForm(req, user));
67         getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
68     }
69
70     @Override
71     public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
72         try {
73             if (req.getParameter("setTicket") != null) {
74
75                 if ( !Form.getForm(req, SupportEnterTicketForm.class).submit(resp.getWriter(), req)) {
76                     throw new GigiApiException("Invalid ticket number!");
77                 }
78             } else if (req.getParameter("revokeall") != null) {
79                 if ( !Form.getForm(req, SupportRevokeCertificatesForm.class).submit(resp.getWriter(), req)) {
80                     throw new GigiApiException("No ticket number set.");
81                 }
82             } else if (req.getParameter("detailupdate") != null) {
83                 if ( !Form.getForm(req, SupportUserDetailsForm.class).submit(resp.getWriter(), req)) {
84                     throw new GigiApiException("No ticket number set.");
85                 }
86             }
87         } catch (GigiApiException e) {
88             e.printStackTrace();
89             e.format(resp.getWriter(), getLanguage(req));
90         }
91         super.doPost(req, resp);
92     }
93
94     @Override
95     public boolean isPermitted(User u) {
96         if (u == null) {
97             return false;
98         }
99         return u.isInGroup(Group.SUPPORTER);
100     }
101 }