]> WPIA git - gigi.git/blob - src/org/cacert/gigi/pages/orga/CreateOrgForm.java
upd: use a more strict pattern for handling forms
[gigi.git] / src / org / cacert / gigi / pages / orga / CreateOrgForm.java
1 package org.cacert.gigi.pages.orga;
2
3 import java.io.PrintWriter;
4 import java.util.Map;
5
6 import javax.servlet.http.HttpServletRequest;
7
8 import org.cacert.gigi.GigiApiException;
9 import org.cacert.gigi.dbObjects.Organisation;
10 import org.cacert.gigi.email.EmailProvider;
11 import org.cacert.gigi.localisation.Language;
12 import org.cacert.gigi.output.CountrySelector;
13 import org.cacert.gigi.output.template.Form;
14 import org.cacert.gigi.output.template.SprintfCommand;
15 import org.cacert.gigi.output.template.Template;
16 import org.cacert.gigi.pages.LoginPage;
17
18 public class CreateOrgForm extends Form {
19
20     private final static Template t = new Template(CreateOrgForm.class.getResource("CreateOrgForm.templ"));
21
22     private Organisation result;
23
24     private String o = "";
25
26     private String st = "";
27
28     private String l = "";
29
30     private String email = "";
31
32     private String optionalName = "";
33
34     private String postalAddress = "";
35
36     private boolean isEdit = false;
37
38     private CountrySelector cs;
39
40     public CreateOrgForm(HttpServletRequest hsr) {
41         super(hsr);
42         cs = new CountrySelector("C", false);
43     }
44
45     public CreateOrgForm(HttpServletRequest hsr, Organisation t) {
46         this(hsr);
47         isEdit = true;
48         result = t;
49         o = t.getName();
50
51         cs = new CountrySelector("C", false, t.getState());
52
53         st = t.getProvince();
54         l = t.getCity();
55         email = t.getContactEmail();
56         optionalName = t.getOptionalName();
57         postalAddress = t.getPostalAddress();
58     }
59
60     @Override
61     public boolean submit(HttpServletRequest req) throws GigiApiException {
62         String action = req.getParameter("action");
63         if (action == null) {
64             return false;
65         }
66
67         if (action.equals("new")) {
68             checkCertData(req);
69             checkOrganisationData(req);
70             Organisation ne = new Organisation(o, cs.getCountry(), st, l, email, optionalName, postalAddress, LoginPage.getUser(req));
71             result = ne;
72             return true;
73         } else if (action.equals("updateOrganisationData")) {
74             checkOrganisationData(req);
75             result.updateOrgData(email, optionalName, postalAddress);
76             return true;
77         } else if (action.equals("updateCertificateData")) {
78             checkCertData(req);
79             result.updateCertData(o, cs.getCountry(), st, l);
80             return true;
81         }
82
83         return false;
84     }
85
86     private void checkOrganisationData(HttpServletRequest req) throws GigiApiException {
87         email = extractParam(req, "contact");
88         optionalName = extractParam(req, "optionalName");
89         postalAddress = extractParam(req, "postalAddress");
90         if ( !EmailProvider.isValidMailAddress(email)) {
91             throw new GigiApiException("Contact email is not a valid email address");
92         }
93     }
94
95     private void checkCertData(HttpServletRequest req) throws GigiApiException {
96         o = extractParam(req, "O");
97         st = extractParam(req, "ST");
98         l = extractParam(req, "L");
99
100         if (o.length() > 64 || o.length() < 1) {
101             throw new GigiApiException(SprintfCommand.createSimple("{0} not given or longer than {1} characters", "Organisation name", 64));
102         }
103
104         cs.update(req);
105
106         if (st.length() > 128 || st.length() < 1) {
107             throw new GigiApiException(SprintfCommand.createSimple("{0} not given or longer than {1} characters", "State/county", 128));
108         }
109
110         if (l.length() > 128 || l.length() < 1) {
111             throw new GigiApiException(SprintfCommand.createSimple("{0} not given or longer than {1} characters", "Town/suburb", 128));
112         }
113     }
114
115     private String extractParam(HttpServletRequest req, String name) {
116         String parameter = req.getParameter(name);
117         if (parameter == null) {
118             return "";
119         }
120         return parameter.trim();
121     }
122
123     public Organisation getResult() {
124         return result;
125     }
126
127     @Override
128     protected void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
129         vars.put("O", o);
130         vars.put("C", cs);
131         vars.put("ST", st);
132         vars.put("L", this.l);
133         vars.put("email", email);
134         vars.put("optionalName", optionalName);
135         vars.put("postalAddress", postalAddress);
136         vars.put("countryCode", cs);
137         if (isEdit) {
138             vars.put("edit", true);
139         }
140         t.output(out, l, vars);
141     }
142 }