aboutsummaryrefslogtreecommitdiffstats
path: root/subprojects/language-web/src/main/java
diff options
context:
space:
mode:
authorLibravatar Kristóf Marussy <kristof@marussy.com>2022-08-19 19:54:55 +0200
committerLibravatar Kristóf Marussy <kristof@marussy.com>2022-08-20 21:41:50 +0200
commit292546893af22f0e7652132630f1e0710765c153 (patch)
tree1b0c12e23b3211b34abdd13c4a8ca8da4d49ad8a /subprojects/language-web/src/main/java
parentrefactor(frontend): update theme (diff)
downloadrefinery-292546893af22f0e7652132630f1e0710765c153.tar.gz
refinery-292546893af22f0e7652132630f1e0710765c153.tar.zst
refinery-292546893af22f0e7652132630f1e0710765c153.zip
feat(frontend): add PWA manifest
Diffstat (limited to 'subprojects/language-web/src/main/java')
-rw-r--r--subprojects/language-web/src/main/java/tools/refinery/language/web/CacheControlFilter.java9
1 files changed, 7 insertions, 2 deletions
diff --git a/subprojects/language-web/src/main/java/tools/refinery/language/web/CacheControlFilter.java b/subprojects/language-web/src/main/java/tools/refinery/language/web/CacheControlFilter.java
index b13ae95d..8ac8a21e 100644
--- a/subprojects/language-web/src/main/java/tools/refinery/language/web/CacheControlFilter.java
+++ b/subprojects/language-web/src/main/java/tools/refinery/language/web/CacheControlFilter.java
@@ -2,6 +2,7 @@ package tools.refinery.language.web;
2 2
3import java.io.IOException; 3import java.io.IOException;
4import java.time.Duration; 4import java.time.Duration;
5import java.util.Set;
5import java.util.regex.Pattern; 6import java.util.regex.Pattern;
6 7
7import org.eclipse.jetty.http.HttpHeader; 8import org.eclipse.jetty.http.HttpHeader;
@@ -16,7 +17,10 @@ import jakarta.servlet.http.HttpServletRequest;
16import jakarta.servlet.http.HttpServletResponse; 17import jakarta.servlet.http.HttpServletResponse;
17 18
18public class CacheControlFilter implements Filter { 19public class CacheControlFilter implements Filter {
19 private static final Pattern CACHE_URI_PATTERN = Pattern.compile(".*\\.(css|gif|js|map|png|svg|woff2)"); 20 private static final Pattern CACHE_URI_PATTERN = Pattern.compile(".*\\.(css|gif|js|map|png|svg|woff2?)");
21
22 private static final Set<String> CACHE_URI_DENYLIST = Set.of("apple-touch-icon.png", "favicon.png", "favicon.svg",
23 "favicon-96x96.png", "icon-any.svg", "icon-192x192.png", "icon-512x512.png", "mask-icon.svg", "sw.js");
20 24
21 private static final Duration EXPIRY = Duration.ofDays(365); 25 private static final Duration EXPIRY = Duration.ofDays(365);
22 26
@@ -33,7 +37,8 @@ public class CacheControlFilter implements Filter {
33 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) 37 public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
34 throws IOException, ServletException { 38 throws IOException, ServletException {
35 if (request instanceof HttpServletRequest httpRequest && response instanceof HttpServletResponse httpResponse) { 39 if (request instanceof HttpServletRequest httpRequest && response instanceof HttpServletResponse httpResponse) {
36 if (CACHE_URI_PATTERN.matcher(httpRequest.getRequestURI()).matches()) { 40 var requestURI = httpRequest.getRequestURI();
41 if (CACHE_URI_PATTERN.matcher(requestURI).matches() && !CACHE_URI_DENYLIST.contains(requestURI)) {
37 httpResponse.setHeader(HttpHeader.CACHE_CONTROL.asString(), CACHE_CONTROL_CACHE_VALUE); 42 httpResponse.setHeader(HttpHeader.CACHE_CONTROL.asString(), CACHE_CONTROL_CACHE_VALUE);
38 httpResponse.setDateHeader(HttpHeader.EXPIRES.asString(), 43 httpResponse.setDateHeader(HttpHeader.EXPIRES.asString(),
39 System.currentTimeMillis() + EXPIRY.toMillis()); 44 System.currentTimeMillis() + EXPIRY.toMillis());