| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  | const version = "0.0.0" | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | interface ServiceWorkerFetchEvent extends Event { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     request: RequestInfo & { url: string } | 
					
						
							|  |  |  |     respondWith: (response: any | PromiseLike<Response>) => Promise<void> | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | async function install() { | 
					
						
							|  |  |  |     console.log("Installing service worker!") | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | addEventListener("install", (e) => (<any>e).waitUntil(install())) | 
					
						
							|  |  |  | addEventListener("activate", (e) => (<any>e).waitUntil(activate())) | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | async function activate() { | 
					
						
							|  |  |  |     console.log("Activating service worker") | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     caches | 
					
						
							|  |  |  |         .keys() | 
					
						
							|  |  |  |         .then((keys) => { | 
					
						
							|  |  |  |             // Remove all old caches
 | 
					
						
							|  |  |  |             Promise.all(keys.map((key) => key !== version && caches.delete(key))) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .catch(console.error) | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-21 10:52:51 +02:00
										 |  |  | function fetchAndCache(event) { | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |     return fetch(event.request).then((networkResponse) => { | 
					
						
							|  |  |  |         return caches.open(version).then((cache) => { | 
					
						
							|  |  |  |             cache.put(event.request, networkResponse.clone()) | 
					
						
							|  |  |  |             console.log("Cached", event.request) | 
					
						
							|  |  |  |             return networkResponse | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const cacheFirst = async (event, attemptUpdate: boolean = false) => { | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  |     await event.respondWith( | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         caches.match(event.request, { ignoreSearch: true }).then((cacheResponse) => { | 
					
						
							|  |  |  |             if (cacheResponse !== undefined) { | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |                 console.debug("Loaded from cache: ", event.request) | 
					
						
							| 
									
										
										
										
											2024-07-21 10:52:51 +02:00
										 |  |  |                 if (attemptUpdate) { | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |                     fetchAndCache(event) | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  |                 return cacheResponse | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |             return fetchAndCache(event) | 
					
						
							| 
									
										
										
										
											2024-08-14 13:53:56 +02:00
										 |  |  |         }) | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  | self.addEventListener("fetch", async (e) => { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     // Important: this lambda must run synchronously, as the browser will otherwise handle the request
 | 
					
						
							|  |  |  |     const event = <ServiceWorkerFetchEvent>e | 
					
						
							|  |  |  |     try { | 
					
						
							|  |  |  |         const origin = new URL(self.origin) | 
					
						
							|  |  |  |         const requestUrl = new URL(event.request.url) | 
					
						
							|  |  |  |         if (requestUrl.pathname.endsWith("service-worker-version")) { | 
					
						
							|  |  |  |             console.log("Sending version number...") | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  |             await event.respondWith( | 
					
						
							| 
									
										
										
										
											2024-08-14 13:53:56 +02:00
										 |  |  |                 new Response(JSON.stringify({ "service-worker-version": version })) | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  |             ) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-09 16:24:38 +02:00
										 |  |  |         if (requestUrl.pathname.endsWith("/service-worker-clear")) { | 
					
						
							|  |  |  |             const keys = await caches.keys() | 
					
						
							| 
									
										
										
										
											2024-08-14 13:53:56 +02:00
										 |  |  |             await Promise.all(keys.map((k) => caches.delete(k))) | 
					
						
							| 
									
										
										
										
											2024-08-09 16:24:38 +02:00
										 |  |  |             console.log("Cleared caches") | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const shouldBeCached = | 
					
						
							|  |  |  |             origin.host === requestUrl.host && | 
					
						
							|  |  |  |             origin.hostname !== "127.0.0.1" && | 
					
						
							|  |  |  |             origin.hostname !== "localhost" && | 
					
						
							| 
									
										
										
										
											2024-01-15 01:42:23 +01:00
										 |  |  |             !origin.hostname.endsWith(".local") && | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |             !origin.host.endsWith(".gitpod.io") && | 
					
						
							|  |  |  |             origin.pathname.indexOf("service-worker") < 0 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         if (!shouldBeCached) { | 
					
						
							| 
									
										
										
										
											2024-07-16 16:11:14 +02:00
										 |  |  |             console.debug("Not intercepting ", requestUrl.toString(), origin.host, requestUrl.host) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             // We return _without_ calling event.respondWith, which signals the browser that it'll have to handle it himself
 | 
					
						
							|  |  |  |             return | 
					
						
							| 
									
										
										
										
											2022-06-02 02:59:34 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  |         await cacheFirst(event) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     } catch (e) { | 
					
						
							|  |  |  |         console.error("CRASH IN SW:", e) | 
					
						
							| 
									
										
										
										
											2023-02-24 17:47:30 +01:00
										 |  |  |         await event.respondWith(fetch(event.request.url)) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | }) |