]> WPIA git - gigi.git/blob - src/org/cacert/gigi/pages/orga/ViewOrgPage.java
Clean: use "authorizationContexts"
[gigi.git] / src / org / cacert / gigi / pages / orga / ViewOrgPage.java
1 package org.cacert.gigi.pages.orga;
2
3 import java.io.IOException;
4 import java.io.PrintWriter;
5 import java.util.HashMap;
6 import java.util.List;
7 import java.util.Map;
8
9 import javax.servlet.http.HttpServletRequest;
10 import javax.servlet.http.HttpServletResponse;
11
12 import org.cacert.gigi.GigiApiException;
13 import org.cacert.gigi.dbObjects.Organisation;
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.output.template.Template;
19 import org.cacert.gigi.pages.LoginPage;
20 import org.cacert.gigi.pages.Page;
21 import org.cacert.gigi.util.AuthorizationContext;
22
23 public class ViewOrgPage extends Page {
24
25     private final Template orgas = new Template(ViewOrgPage.class.getResource("ViewOrgs.templ"));
26
27     private final Template mainTempl = new Template(ViewOrgPage.class.getResource("EditOrg.templ"));
28
29     public static final String DEFAULT_PATH = "/orga";
30
31     public ViewOrgPage() {
32         super("View Organisation");
33     }
34
35     @Override
36     public boolean isPermitted(AuthorizationContext ac) {
37         return ac != null && (ac.isInGroup(CreateOrgPage.ORG_ASSURER) || ac.getActor().getOrganisations().size() != 0);
38     }
39
40     @Override
41     public void doPost(HttpServletRequest req, HttpServletResponse resp) throws IOException {
42         try {
43             User u = LoginPage.getUser(req);
44             if (req.getParameter("do_affiliate") != null || req.getParameter("del") != null) {
45                 AffiliationForm form = Form.getForm(req, AffiliationForm.class);
46                 if (form.submit(resp.getWriter(), req)) {
47                     resp.sendRedirect(DEFAULT_PATH + "/" + form.getOrganisation().getId());
48                 }
49                 return;
50             } else {
51                 if ( !u.isInGroup(CreateOrgPage.ORG_ASSURER)) {
52                     resp.sendError(403, "Access denied");
53                     return;
54                 }
55                 Form.getForm(req, CreateOrgForm.class).submit(resp.getWriter(), req);
56             }
57
58         } catch (GigiApiException e) {
59             e.format(resp.getWriter(), getLanguage(req));
60         }
61     }
62
63     @Override
64     public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
65         User u = LoginPage.getUser(req);
66         String idS = req.getPathInfo();
67         Language lang = getLanguage(req);
68         PrintWriter out = resp.getWriter();
69         if (idS.length() < DEFAULT_PATH.length() + 2) {
70             final Organisation[] orgas = Organisation.getOrganisations(0, 30);
71             HashMap<String, Object> map = new HashMap<>();
72             final List<Organisation> myOrgs = u.getOrganisations();
73             final boolean orgAss = u.isInGroup(CreateOrgPage.ORG_ASSURER);
74             if (orgAss) {
75                 map.put("orgas", makeOrgDataset(orgas));
76             } else {
77                 map.put("orgas", makeOrgDataset(myOrgs.toArray(new Organisation[myOrgs.size()])));
78             }
79             this.orgas.output(out, lang, map);
80             return;
81         }
82         idS = idS.substring(DEFAULT_PATH.length() + 1);
83         int id = Integer.parseInt(idS);
84         Organisation o = Organisation.getById(id);
85         final List<Organisation> myOrgs = u.getOrganisations();
86         final boolean orgAss = u.isInGroup(CreateOrgPage.ORG_ASSURER);
87         if (o == null || ( !orgAss && !myOrgs.contains(o))) {
88             resp.sendError(404);
89             return;
90         }
91         HashMap<String, Object> vars = new HashMap<>();
92         vars.put("editForm", new CreateOrgForm(req, o));
93         vars.put("affForm", new AffiliationForm(req, o));
94         mainTempl.output(out, lang, vars);
95     }
96
97     private IterableDataset makeOrgDataset(final Organisation[] orgas) {
98         return new IterableDataset() {
99
100             int count = 0;
101
102             @Override
103             public boolean next(Language l, Map<String, Object> vars) {
104                 if (count >= orgas.length) {
105                     return false;
106                 }
107                 Organisation org = orgas[count++];
108                 vars.put("id", Integer.toString(org.getId()));
109                 vars.put("name", org.getName());
110                 vars.put("country", org.getState());
111                 return true;
112             }
113         };
114     }
115 }