1 package org.cacert.gigi.pages.account;
3 import java.io.PrintWriter;
6 import javax.servlet.http.HttpServletRequest;
8 import org.cacert.gigi.Domain;
9 import org.cacert.gigi.GigiApiException;
10 import org.cacert.gigi.User;
11 import org.cacert.gigi.localisation.Language;
12 import org.cacert.gigi.output.Form;
13 import org.cacert.gigi.output.template.IterableDataset;
14 import org.cacert.gigi.output.template.OutputableArrayIterable;
15 import org.cacert.gigi.output.template.Template;
16 import org.cacert.gigi.pages.Page;
17 import org.cacert.gigi.util.RandomToken;
19 public class DomainAddForm extends Form {
21 private static final Template t = new Template(DomainManagementForm.class.getResource("DomainAddForm.templ"));
25 private String tokenName = RandomToken.generateToken(8);
27 private String tokenValue = RandomToken.generateToken(16);
29 public DomainAddForm(HttpServletRequest hsr, User target) {
35 public boolean submit(PrintWriter out, HttpServletRequest req) {
37 String parameter = req.getParameter("newdomain");
38 if (parameter.trim().isEmpty()) {
39 throw new GigiApiException("No domain inserted.");
41 Domain d = new Domain(target, parameter);
44 } catch (GigiApiException e) {
45 e.format(out, Page.getLanguage(req));
50 public static final String[] AUTHORATIVE_EMAILS = new String[] {
51 "root", "hostmaster", "postmaster", "admin", "webmaster"
55 protected void outputContent(PrintWriter out, Language l, Map<String, Object> vars) {
56 vars.put("tokenName", tokenName);
57 vars.put("tokenValue", tokenValue);
58 vars.put("authEmails", new OutputableArrayIterable(AUTHORATIVE_EMAILS, "email"));
59 vars.put("ssl-services", new IterableDataset() {
64 public boolean next(Language l, Map<String, Object> vars) {
68 vars.put("i", counter);
73 t.output(out, l, vars);