]> WPIA git - gigi.git/blob - src/org/cacert/gigi/api/CreateCertificate.java
a846285778ed497892e761d98e397100320922a3
[gigi.git] / src / org / cacert / gigi / api / CreateCertificate.java
1 package org.cacert.gigi.api;
2
3 import java.io.IOException;
4 import java.security.GeneralSecurityException;
5
6 import javax.servlet.http.HttpServletRequest;
7 import javax.servlet.http.HttpServletResponse;
8
9 import org.cacert.gigi.GigiApiException;
10 import org.cacert.gigi.dbObjects.Certificate;
11 import org.cacert.gigi.dbObjects.Certificate.CertificateStatus;
12 import org.cacert.gigi.dbObjects.CertificateProfile;
13 import org.cacert.gigi.dbObjects.Job;
14 import org.cacert.gigi.dbObjects.User;
15 import org.cacert.gigi.pages.account.certs.CertificateRequest;
16 import org.cacert.gigi.util.AuthorizationContext;
17 import org.cacert.gigi.util.PEM;
18
19 public class CreateCertificate extends APIPoint {
20
21     public static final String PATH = "/account/certs/new";
22
23     @Override
24     public void process(HttpServletRequest req, HttpServletResponse resp, User u) throws IOException {
25         String csr = req.getParameter("csr");
26         if (csr == null) {
27             resp.sendError(500, "Error, no CSR found");
28             return;
29         }
30         CertificateProfile cp = null;
31         String cpS = req.getParameter("profile");
32         if (cpS != null) {
33             cp = CertificateProfile.getByName(cpS);
34             if (cp == null) {
35                 resp.sendError(500, "Error, profile " + cpS + "not found");
36                 return;
37             }
38         }
39         try {
40             CertificateRequest cr = new CertificateRequest(new AuthorizationContext(u, u), csr, cp);
41             Certificate result = cr.draft();
42             Job job = result.issue(null, "2y", u);
43             job.waitFor(60000);
44             if (result.getStatus() != CertificateStatus.ISSUED) {
45                 resp.sendError(510, "Error, issuing timed out");
46                 return;
47             }
48             resp.getWriter().println(PEM.encode("CERTIFICATE", result.cert().getEncoded()));
49             return;
50         } catch (GeneralSecurityException e) {
51             e.printStackTrace();
52         } catch (GigiApiException e) {
53             e.printStackTrace();
54         } catch (InterruptedException e) {
55             e.printStackTrace();
56         }
57     }
58 }