Author: ssievers
Date: Mon Feb 25 12:35:54 2013
New Revision: 1449683
URL: http://svn.apache.org/r1449683
Log:
SHINDIG-1904 | set response cache control to -1 for JsServlet when response
code is 304 | Patch from Marshall Shi. Thanks!
Modified:
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/js/IfModifiedSinceProcessor.java
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/servlet/JsServlet.java
Modified:
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/js/IfModifiedSinceProcessor.java
URL:
http://svn.apache.org/viewvc/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/js/IfModifiedSinceProcessor.java?rev=1449683&r1=1449682&r2=1449683&view=diff
==============================================================================
---
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/js/IfModifiedSinceProcessor.java
(original)
+++
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/js/IfModifiedSinceProcessor.java
Mon Feb 25 12:35:54 2013
@@ -20,6 +20,9 @@ package org.apache.shindig.gadgets.js;
import org.apache.shindig.gadgets.uri.UriStatus;
+import com.google.inject.Inject;
+import com.google.inject.name.Named;
+
import javax.servlet.http.HttpServletResponse;
/**
@@ -29,10 +32,22 @@ import javax.servlet.http.HttpServletRes
*/
public class IfModifiedSinceProcessor implements JsProcessor {
+ public static final int DEFAULT_VERSIONED_MAXAGE = -1;
+
+ private int versionedMaxAge = DEFAULT_VERSIONED_MAXAGE;
+
+ @Inject(optional=true)
+ public void setVersionedMaxAge(@Named("shindig.jscontent.versioned.maxage")
Integer maxAge) {
+ if (maxAge != null) {
+ versionedMaxAge = maxAge;
+ }
+ }
+
public boolean process(JsRequest request, JsResponseBuilder builder) {
if (request.isInCache() &&
request.getJsUri().getStatus() == UriStatus.VALID_VERSIONED) {
builder.setStatusCode(HttpServletResponse.SC_NOT_MODIFIED);
+ builder.setCacheTtlSecs(versionedMaxAge);
return false;
}
return true;
Modified:
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/servlet/JsServlet.java
URL:
http://svn.apache.org/viewvc/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/servlet/JsServlet.java?rev=1449683&r1=1449682&r2=1449683&view=diff
==============================================================================
---
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/servlet/JsServlet.java
(original)
+++
shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/servlet/JsServlet.java
Mon Feb 25 12:35:54 2013
@@ -102,11 +102,13 @@ public class JsServlet extends InjectedS
protected void emitJsResponse(JsResponse jsResponse, HttpServletRequest req,
HttpServletResponse resp) throws IOException {
- if (jsResponse.getStatusCode() == 304) {
+ if (jsResponse.getStatusCode() == HttpServletResponse.SC_NOT_MODIFIED) {
resp.setStatus(HttpServletResponse.SC_NOT_MODIFIED);
+ cachingSetter.setCachingHeaders(
+ resp, jsResponse.getCacheTtlSecs(), !jsResponse.isProxyCacheable());
return;
}
- if (jsResponse.getStatusCode() == 200 && jsResponse.toJsString().length()
== 0) {
+ if (jsResponse.getStatusCode() == HttpServletResponse.SC_OK &&
jsResponse.toJsString().length() == 0) {
resp.setStatus(HttpServletResponse.SC_NOT_FOUND);
return;
}