2024-02-13 18:35:32 +03:00
|
|
|
---
|
|
|
|
layout: compress
|
|
|
|
permalink: /:basename.min.js
|
|
|
|
# PWA service worker
|
|
|
|
---
|
2024-01-27 21:22:33 +03:00
|
|
|
|
2024-02-13 18:35:32 +03:00
|
|
|
const swconfUrl = '{{ '/assets/js/data/swconf.js' | relative_url }}';
|
2024-01-27 21:22:33 +03:00
|
|
|
|
|
|
|
importScripts(swconfUrl);
|
|
|
|
const purge = swconf.purge;
|
|
|
|
|
|
|
|
function verifyHost(url) {
|
|
|
|
for (const host of swconf.allowHosts) {
|
|
|
|
const regex = RegExp(`^http(s)?://${host}/`);
|
|
|
|
if (regex.test(url)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
function verifyUrl(url) {
|
|
|
|
if (!verifyHost(url)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
const requestPath = new URL(url).pathname;
|
|
|
|
|
|
|
|
for (const path of swconf.denyPaths) {
|
|
|
|
if (requestPath.startsWith(path)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!purge) {
|
|
|
|
swconf.allowHosts.push(location.host);
|
|
|
|
}
|
|
|
|
|
|
|
|
self.addEventListener('install', (event) => {
|
|
|
|
if (purge) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
event.waitUntil(
|
|
|
|
caches.open(swconf.cacheName).then((cache) => {
|
|
|
|
return cache.addAll(swconf.resources);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
self.addEventListener('activate', (event) => {
|
|
|
|
event.waitUntil(
|
|
|
|
caches.keys().then((keyList) => {
|
|
|
|
return Promise.all(
|
|
|
|
keyList.map((key) => {
|
|
|
|
if (purge) {
|
|
|
|
return caches.delete(key);
|
|
|
|
} else {
|
|
|
|
if (key !== swconf.cacheName) {
|
|
|
|
return caches.delete(key);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
self.addEventListener('message', (event) => {
|
|
|
|
if (event.data === 'SKIP_WAITING') {
|
|
|
|
self.skipWaiting();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
self.addEventListener('fetch', (event) => {
|
2024-04-29 18:27:41 +03:00
|
|
|
if (event.request.headers.has('range')) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-01-27 21:22:33 +03:00
|
|
|
event.respondWith(
|
|
|
|
caches.match(event.request).then((response) => {
|
|
|
|
if (response) {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
|
|
|
|
return fetch(event.request).then((response) => {
|
|
|
|
const url = event.request.url;
|
|
|
|
|
|
|
|
if (purge || event.request.method !== 'GET' || !verifyUrl(url)) {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
|
2024-02-13 18:35:32 +03:00
|
|
|
{% comment %}See: <https://developers.google.com/web/fundamentals/primers/service-workers#cache_and_return_requests>{% endcomment %}
|
2024-01-27 21:22:33 +03:00
|
|
|
let responseToCache = response.clone();
|
|
|
|
|
|
|
|
caches.open(swconf.cacheName).then((cache) => {
|
|
|
|
cache.put(event.request, responseToCache);
|
|
|
|
});
|
|
|
|
return response;
|
|
|
|
});
|
|
|
|
})
|
|
|
|
);
|
|
|
|
});
|