]> WPIA git - gigi.git/blob - src/club/wpia/gigi/pages/MainPage.java
add: ensure that for RA Agent actions there is a valid RA Challenge
[gigi.git] / src / club / wpia / gigi / pages / MainPage.java
1 package club.wpia.gigi.pages;
2
3 import java.io.IOException;
4 import java.util.Iterator;
5 import java.util.List;
6 import java.util.Map;
7 import java.util.Set;
8
9 import javax.servlet.http.HttpServletRequest;
10 import javax.servlet.http.HttpServletResponse;
11
12 import club.wpia.gigi.dbObjects.Certificate;
13 import club.wpia.gigi.dbObjects.Domain;
14 import club.wpia.gigi.dbObjects.EmailAddress;
15 import club.wpia.gigi.dbObjects.Group;
16 import club.wpia.gigi.dbObjects.Organisation;
17 import club.wpia.gigi.dbObjects.User;
18 import club.wpia.gigi.localisation.Language;
19 import club.wpia.gigi.output.GroupList;
20 import club.wpia.gigi.output.template.IterableDataset;
21 import club.wpia.gigi.output.template.Template;
22
23 public class MainPage extends Page {
24
25     private static final Template notLog = new Template(MainPage.class.getResource("MainPageNotLogin.templ"));
26
27     public MainPage() {
28         super("Home");
29     }
30
31     @Override
32     public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
33         Map<String, Object> vars = getDefaultVars(req);
34         if (LoginPage.getUser(req) != null) {
35             User u = LoginPage.getUser(req);
36             vars.put("username", u.getPreferredName());
37             final Set<Group> gr = u.getGroups();
38             vars.put("support-groups", new GroupList(gr, true));
39             vars.put("groups", new GroupList(gr, false));
40             vars.put("ra-agent", u.canVerify());
41             vars.put("vp", u.getVerificationPoints());
42             vars.put("xp", u.getExperiencePoints());
43
44
45             vars.put("catsinfo", false);
46             if (u.canVerify() && !u.hasValidRAChallenge()) {
47                 vars.put("catsinfo", true);
48                 vars.put("catsra", true);
49             }
50             Certificate[] c = u.getCertificates(false);
51             vars.put("c-no", c.length);
52
53             final EmailAddress[] emails = u.getEmails();
54             IterableDataset ds = new IterableDataset() {
55
56                 private int point = 0;
57
58                 @Override
59                 public boolean next(Language l, Map<String, Object> vars) {
60                     if (point >= emails.length) {
61                         return false;
62                     }
63                     EmailAddress emailAddress = emails[point];
64                     vars.put("verification", l.getTranslation(emailAddress.isVerified() ? "Verified" : "Unverified"));
65                     vars.put("last_verification", emailAddress.getLastPing(true));
66                     vars.put("address", emailAddress.getAddress());
67                     point++;
68                     return true;
69                 }
70             };
71             vars.put("emails", ds);
72
73             final Domain[] doms = u.getDomains();
74             IterableDataset dts = new IterableDataset() {
75
76                 private int point = 0;
77
78                 @Override
79                 public boolean next(Language l, Map<String, Object> vars) {
80                     if (point >= doms.length) {
81                         return false;
82                     }
83                     Domain domain = doms[point];
84                     vars.put("domain", domain.getSuffix());
85                     vars.put("status", l.getTranslation(domain.isVerified() ? "Verified" : "Unverified"));
86                     point++;
87                     return true;
88                 }
89             };
90             vars.put("domains", dts);
91             vars.put("nodomains", doms.length == 0);
92
93             final List<Organisation> o = u.getOrganisations();
94             vars.put("orgas", new IterableDataset() {
95
96                 Iterator<Organisation> it = o.iterator();
97
98                 @Override
99                 public boolean next(Language l, Map<String, Object> vars) {
100                     if ( !it.hasNext()) {
101                         return false;
102                     }
103                     Organisation o = it.next();
104                     vars.put("orgName", o.getName());
105                     vars.put("orgID", o.getId());
106                     return true;
107                 }
108             });
109             vars.put("hasorgs", !o.isEmpty());
110
111             if (u.isInGroup(Group.SUPPORTER) || u.isInGroup(Group.ORG_AGENT) || u.isInGroup(Group.TTP_AGENT) || u.canVerify() || !o.isEmpty()) {
112                 vars.put("certlogin", LoginPage.getAuthorizationContext(req).isStronglyAuthenticated());
113                 vars.put("certlogininfo", true);
114             } else {
115                 vars.put("certlogininfo", false);
116             }
117
118             getDefaultTemplate().output(resp.getWriter(), getLanguage(req), vars);
119
120         } else {
121             notLog.output(resp.getWriter(), getLanguage(req), vars);
122         }
123     }
124
125     @Override
126     public boolean needsLogin() {
127         return false;
128     }
129 }