diff options
author | Endi S. Dewata <edewata@redhat.com> | 2014-02-10 13:56:15 -0500 |
---|---|---|
committer | Endi S. Dewata <edewata@redhat.com> | 2014-03-04 22:41:46 -0500 |
commit | 56b9ead088c59ea76d796002e74d42d7e31eac44 (patch) | |
tree | 38473afc8d126936ef806b44af2aae01f2ab8fcd /base/server/cms/src/com/netscape/cms/servlet/base | |
parent | 9e14d6f3e5e69093067f0a76e5b7090c102e11d3 (diff) | |
download | pki-56b9ead088c59ea76d796002e74d42d7e31eac44.tar.gz pki-56b9ead088c59ea76d796002e74d42d7e31eac44.tar.xz pki-56b9ead088c59ea76d796002e74d42d7e31eac44.zip |
Added CLI parameter to select message format.
A new CLI parameter has been added to allow the user select the
REST message format. This is done by setting the default consumes
and produces when creating the client proxy. For this to work the
hard-coded @Consumes and @Produces annotations need to be removed
from the interface definition. A new interceptor has been added
to validate the message format before executing the operation.
Ticket #554
Diffstat (limited to 'base/server/cms/src/com/netscape/cms/servlet/base')
-rw-r--r-- | base/server/cms/src/com/netscape/cms/servlet/base/PKIService.java | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/base/server/cms/src/com/netscape/cms/servlet/base/PKIService.java b/base/server/cms/src/com/netscape/cms/servlet/base/PKIService.java index 6550715f5..27dea60db 100644 --- a/base/server/cms/src/com/netscape/cms/servlet/base/PKIService.java +++ b/base/server/cms/src/com/netscape/cms/servlet/base/PKIService.java @@ -20,6 +20,7 @@ package com.netscape.cms.servlet.base; import java.lang.reflect.Method; import java.net.URI; import java.security.cert.CertificateEncodingException; +import java.util.Arrays; import java.util.HashMap; import java.util.List; import java.util.Locale; @@ -27,13 +28,16 @@ import java.util.Map; import javax.ws.rs.FormParam; import javax.ws.rs.core.CacheControl; +import javax.ws.rs.core.Context; import javax.ws.rs.core.EntityTag; import javax.ws.rs.core.HttpHeaders; +import javax.ws.rs.core.MediaType; 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.certsrv.base.PKIException; import com.netscape.certsrv.cert.CertData; import com.netscape.certsrv.logging.IAuditor; import com.netscape.certsrv.logging.ILogger; @@ -52,18 +56,53 @@ public class PKIService { // caching parameters public static final int DEFAULT_LONG_CACHE_LIFETIME = 1000; + public static List<MediaType> MESSAGE_FORMATS = Arrays.asList( + MediaType.APPLICATION_XML_TYPE, + MediaType.APPLICATION_JSON_TYPE + ); + + @Context + private HttpHeaders headers; + public ILogger logger = CMS.getLogger(); public IAuditor auditor = CMS.getAuditor(); + public static MediaType resolveFormat(MediaType format) { + + for (MediaType supportedFormat : MESSAGE_FORMATS) { + if (format.isCompatible(supportedFormat)) return supportedFormat; + } + + return null; + } + + public static MediaType resolveFormat(List<MediaType> formats) { + + for (MediaType acceptableFormat : formats) { + MediaType supportedFormat = resolveFormat(acceptableFormat); + if (supportedFormat != null) return supportedFormat; + } + + return null; + } + + public MediaType getResponseFormat() { + MediaType responseFormat = resolveFormat(headers.getAcceptableMediaTypes()); + if (responseFormat == null) throw new PKIException(Response.Status.NOT_ACCEPTABLE); + return responseFormat; + } + public Response createOKResponse() { return Response .ok() + .type(getResponseFormat()) .build(); } public Response createOKResponse(Object entity) { return Response .ok(entity) + .type(getResponseFormat()) .build(); } @@ -71,12 +110,14 @@ public class PKIService { return Response .created(link) .entity(entity) + .type(getResponseFormat()) .build(); } public Response createNoContentResponse() { return Response .noContent() + .type(getResponseFormat()) .build(); } |