summaryrefslogtreecommitdiffstats
path: root/pki/base/common/src/com/netscape/cms/servlet/base
diff options
context:
space:
mode:
authorAde Lee <alee@redhat.com>2012-01-06 15:17:20 -0500
committerAde Lee <alee@redhat.com>2012-01-13 16:18:48 -0500
commite7ffc2b51be1e0826f93889896e3601b5f1d3f57 (patch)
tree02d358724e37ae78a3d8ba418a3b548936e7c6d3 /pki/base/common/src/com/netscape/cms/servlet/base
parentdbfa1508770473ae5c27049b967abb67956c6572 (diff)
downloadpki-e7ffc2b51be1e0826f93889896e3601b5f1d3f57.tar.gz
pki-e7ffc2b51be1e0826f93889896e3601b5f1d3f57.tar.xz
pki-e7ffc2b51be1e0826f93889896e3601b5f1d3f57.zip
Added initial code for retrieving transport cert.
Resources now extend CMSResource. Addressed following review comments: * check for null pointers in SystemCertificateResource * move logic from CertificatData constructor to CMSServlet builder method * remove unused field uriInfo and replace hard-coded cache constant * fixed some formatting issues
Diffstat (limited to 'pki/base/common/src/com/netscape/cms/servlet/base')
-rw-r--r--pki/base/common/src/com/netscape/cms/servlet/base/CMSResource.java69
1 files changed, 69 insertions, 0 deletions
diff --git a/pki/base/common/src/com/netscape/cms/servlet/base/CMSResource.java b/pki/base/common/src/com/netscape/cms/servlet/base/CMSResource.java
new file mode 100644
index 000000000..48b04859b
--- /dev/null
+++ b/pki/base/common/src/com/netscape/cms/servlet/base/CMSResource.java
@@ -0,0 +1,69 @@
+// --- BEGIN COPYRIGHT BLOCK ---
+// This program is free software; you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; version 2 of the License.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License along
+// with this program; if not, write to the Free Software Foundation, Inc.,
+// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+//
+// (C) 2012 Red Hat, Inc.
+// All rights reserved.
+// --- END COPYRIGHT BLOCK ---
+package com.netscape.cms.servlet.base;
+
+import java.security.cert.CertificateEncodingException;
+
+import javax.ws.rs.core.CacheControl;
+import javax.ws.rs.core.EntityTag;
+import javax.ws.rs.core.Request;
+import javax.ws.rs.core.Response;
+import javax.ws.rs.core.Response.ResponseBuilder;
+
+import com.netscape.certsrv.apps.CMS;
+import com.netscape.cms.servlet.cert.model.CertificateData;
+
+/**
+ * Base class for CMS RESTful resources
+ *
+ * @author alee
+ *
+ */
+public class CMSResource {
+ protected static final String HEADER = "-----BEGIN NEW CERTIFICATE REQUEST-----";
+ protected static final String TRAILER = "-----END NEW CERTIFICATE REQUEST-----";
+
+ // caching parameters
+ protected static final int DEFAULT_LONG_CACHE_LIFETIME = 1000;
+
+ protected Response sendConditionalGetResponse(int ctime, Object object, Request request) {
+ CacheControl cc = new CacheControl();
+ cc.setMaxAge(ctime);
+ EntityTag tag = new EntityTag(Integer.toString(object.hashCode()));
+
+ ResponseBuilder builder = request.evaluatePreconditions(tag);
+ if (builder != null) {
+ builder.cacheControl(cc);
+ return builder.build();
+ }
+
+ builder = Response.ok(object);
+ builder.cacheControl(cc);
+ builder.tag(tag);
+ return builder.build();
+ }
+
+ public CertificateData createCertificateData(org.mozilla.jss.crypto.X509Certificate cert)
+ throws CertificateEncodingException {
+ CertificateData data = new CertificateData();
+ String b64 = HEADER + CMS.BtoA(cert.getEncoded()) + TRAILER;
+ data.setB64(b64);
+ return data;
+ }
+
+}