summaryrefslogtreecommitdiffstats
path: root/pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java
diff options
context:
space:
mode:
authorAde Lee <alee@redhat.com>2012-01-12 12:24:24 -0500
committerAde Lee <alee@redhat.com>2012-01-16 13:04:26 -0500
commit8ff3cae8509bf5527d49166f818776cfc618555c (patch)
treea7cf488310c08e68daa529f4f016dbae2592d4b8 /pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java
parent0491736b2570447391835bc2e5282d809f0de4f1 (diff)
downloadpki-8ff3cae8509bf5527d49166f818776cfc618555c.tar.gz
pki-8ff3cae8509bf5527d49166f818776cfc618555c.tar.xz
pki-8ff3cae8509bf5527d49166f818776cfc618555c.zip
Enhanced new REST search interface for keys and key requests
Defined parameters that can be searched for in key and keyrequest searches. Searches for KeyRequests and Keys will perform VLV searches if those searches are defined. The results will include links to next and previous pages in the results. Also added maxTime and maxResults parameters for regular searches. These will be operational unless they exceed server defined limits - which are enforced at the repo level. Modified link URL from "link" to "Link"
Diffstat (limited to 'pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java')
-rw-r--r--pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java55
1 files changed, 45 insertions, 10 deletions
diff --git a/pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java b/pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java
index 98f12ae5a..4cf5db3f4 100644
--- a/pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java
+++ b/pki/base/common/src/com/netscape/cms/servlet/key/KeysResource.java
@@ -20,21 +20,22 @@
*/
package com.netscape.cms.servlet.key;
+import javax.ws.rs.DefaultValue;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
+import javax.ws.rs.QueryParam;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.UriInfo;
-import java.util.List;
-
+import com.netscape.certsrv.apps.CMS;
import com.netscape.certsrv.base.EBaseException;
import com.netscape.cms.servlet.base.CMSResource;
import com.netscape.cms.servlet.key.model.KeyDAO;
-import com.netscape.cms.servlet.key.model.KeyDataInfo;
+import com.netscape.cms.servlet.key.model.KeyDataInfos;
/**
* @author alee
@@ -43,6 +44,9 @@ import com.netscape.cms.servlet.key.model.KeyDataInfo;
@Path("/keys")
public class KeysResource extends CMSResource {
+ private static final String DEFAULT_MAXTIME = "10";
+ private static final String DEFAULT_MAXRESULTS = "100";
+
@Context
UriInfo uriInfo;
@@ -51,20 +55,51 @@ public class KeysResource extends CMSResource {
*/
@GET
@Produces({ MediaType.APPLICATION_XML, MediaType.APPLICATION_JSON, MediaType.TEXT_XML })
- public List<KeyDataInfo> listKeys() {
+ public KeyDataInfos listKeys(@QueryParam("clientID") String clientID,
+ @QueryParam("status") String status,
+ @DefaultValue(DEFAULT_MAXRESULTS) @QueryParam("maxResults") int maxResults,
+ @DefaultValue(DEFAULT_MAXTIME) @QueryParam("maxTime") int maxTime) {
// auth and authz
- // parse search parameters from uriInfo and create search filter
- // String clientID = uriInfo.getQueryParameters().getFirst(CLIENT_ID);
- String filter = "objectClass=keyRecord";
+
+ // get ldap filter
+ String filter = createSearchFilter(status, clientID);
+ CMS.debug("listKeys: filter is " + filter);
+
KeyDAO dao = new KeyDAO();
- List<KeyDataInfo> info;
+ KeyDataInfos infos;
try {
- info = dao.listKeys(filter, uriInfo);
+ infos = dao.listKeys(filter, maxResults, maxTime, uriInfo);
} catch (EBaseException e) {
e.printStackTrace();
throw new WebApplicationException(Response.Status.INTERNAL_SERVER_ERROR);
}
- return info;
+ return infos;
+ }
+
+ private String createSearchFilter(String status, String clientID) {
+ String filter = "";
+ int matches = 0;
+
+ if ((status == null) && (clientID == null)) {
+ filter = "(serialno=*)";
+ return filter;
+ }
+
+ if (status != null) {
+ filter += "(status=" + status + ")";
+ matches ++;
+ }
+
+ if (clientID != null) {
+ filter += "(clientID=" + clientID + ")";
+ matches ++;
+ }
+
+ if (matches > 1) {
+ filter = "(&" + filter + ")";
+ }
+
+ return filter;
}
}