From 4609888ad163b755ee8afedf9d1b828a5c7dd3d8 Mon Sep 17 00:00:00 2001 From: Ace Date: Fri, 3 Jun 2016 21:03:29 +0530 Subject: [PATCH] Fixes to ifmodified-since in activity provider --- .../api/ActivityInfoProviderService.java | 7 ++++- .../impl/ActivityProviderServiceImpl.java | 27 ++++++++++++++++++- 2 files changed, 32 insertions(+), 2 deletions(-) diff --git a/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/ActivityInfoProviderService.java b/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/ActivityInfoProviderService.java index 1a59a0fc93c..d7f91d9c1d6 100644 --- a/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/ActivityInfoProviderService.java +++ b/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/api/ActivityInfoProviderService.java @@ -164,6 +164,11 @@ public interface ActivityInfoProviderService { name = "limit", value = "Maximum size of resource array to return.", required = false) - @QueryParam("limit") int limit); + @QueryParam("limit") int limit, + @ApiParam( + name = "If-Modified-Since", + value = "Validates if the requested variant has not been modified since the time specified", + required = false) + @HeaderParam("If-Modified-Since") String ifModifiedSince); } diff --git a/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/ActivityProviderServiceImpl.java b/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/ActivityProviderServiceImpl.java index f351d38e88b..7f0253a0167 100644 --- a/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/ActivityProviderServiceImpl.java +++ b/components/device-mgt/org.wso2.carbon.device.mgt.api/src/main/java/org/wso2/carbon/device/mgt/jaxrs/service/impl/ActivityProviderServiceImpl.java @@ -32,6 +32,9 @@ import org.wso2.carbon.device.mgt.jaxrs.util.DeviceMgtAPIUtils; import javax.ws.rs.*; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.Date; import java.util.List; @Path("/activities") @@ -73,13 +76,35 @@ public class ActivityProviderServiceImpl implements ActivityInfoProviderService public Response getActivities( @QueryParam("timestamp") long timestamp, @QueryParam("offset") int offset, - @QueryParam("limit") int limit) { + @QueryParam("limit") int limit, + @HeaderParam("If-Modified-Since") String ifModifiedSince) { + + + long sinceTimestamp = 0; + boolean isSinceModifiedIsSet = false; + if (ifModifiedSince != null && !ifModifiedSince.isEmpty()) { + try { + SimpleDateFormat format = new SimpleDateFormat("EEE, d MMM yyyy HH:mm:ss Z"); + Date sinceDate = format.parse(ifModifiedSince); + sinceTimestamp = sinceDate.getTime(); + } catch (ParseException e) { + throw new InputValidationException(new ErrorResponse.ErrorResponseBuilder().setCode(400l) + .setMessage("Invalid date " + "string is provided in 'If-Modified-Since' header").build()); + } + } + if (sinceTimestamp > timestamp) { + timestamp = sinceTimestamp; + isSinceModifiedIsSet = true; + } List activities; DeviceManagementProviderService dmService; try { dmService = DeviceMgtAPIUtils.getDeviceManagementService(); activities = dmService.getActivitiesUpdatedAfter(timestamp); if (activities == null || activities.size() == 0) { + if (isSinceModifiedIsSet) { + return Response.status(Response.Status.NOT_MODIFIED).entity(activities).build(); + } throw new NotFoundException( new ErrorResponse.ErrorResponseBuilder().setCode(404l).setMessage("No activities " + "found.").build());