package org.cacert.gigi.pages.admin.support;
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.EmailAddress;
+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 SupportUserDetailsPage extends Page {
}
@Override
- public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {}
+ public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+ int id;
+ String[] idP = req.getPathInfo().split("/");
+ id = Integer.parseInt(idP[idP.length - 1]);
+ final User user = User.getById(id);
+ SupportUserDetailsForm f = new SupportUserDetailsForm(req, user);
+ HashMap<String, Object> vars = new HashMap<String, Object>();
+ vars.put("details", f);
+ final EmailAddress[] addrs = user.getEmails();
+ vars.put("emails", new IterableDataset() {
+
+ int i = 0;
+
+ @Override
+ public boolean next(Language l, Map<String, Object> vars) {
+ String address = addrs[i].getAddress();
+ if ( !address.equals(user.getEmail())) {
+ vars.put("secmail", address);
+ }
+ i++;
+ return i != addrs.length - 1;
+ }
+ });
+ vars.put("certifrevoke", new SupportRevokeCertificatesForm(req, user));
+ getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
+ }
+ @Override
+ public boolean isPermitted(User u) {
+ if (u == null) {
+ return false;
+ }
+ return u.isInGroup(Group.getByString("supporter"));
+ }
}