Spaces:
Running
Running
| // π€ NOTE: This file creates a service worker that cross-origin-isolates the page (read more here: https://web.dev/coop-coep/) | |
| // π Normally you'd set the COOP and COEP headers on the server (yum), but Github Pages said: "No burgers for you!" π | |
| // π So, we're doing a cheeky pizza hack π to make this work without server-side headers. | |
| /* π οΈ Edited version of: coi-serviceworker v0.1.6 - Guido Zuidhof, licensed under MIT π οΈ */ | |
| // π§ββοΈ We're using wizardry from here: https://github.com/gzuidhof/coi-serviceworker | |
| if (typeof window === 'undefined') { | |
| // π οΈ Service Worker Time! (No windows allowed in this club) | |
| // π Install event: "Let's skip the line and go straight to work!" | |
| self.addEventListener("install", () => self.skipWaiting()); | |
| // π Activate event: "I claim all clients! Mine! All mine!" (Mwahaha π) | |
| self.addEventListener("activate", e => e.waitUntil(self.clients.claim())); | |
| // π΄ Handle fetch requests, like a master chef in the kitchen! | |
| async function handleFetch(request) { | |
| // π§ Special seasoning: If we're caching but the mode's not right, we pass. | |
| if (request.cache === "only-if-cached" && request.mode !== "same-origin") { | |
| return; | |
| } | |
| // πΆοΈ For no-cors requests, we're keeping it cool π with 'omit' credentials (Bug workarounds are fun, right? π) | |
| if (request.mode === "no-cors") { | |
| request = new Request(request.url, { | |
| cache: request.cache, | |
| credentials: "omit", | |
| headers: request.headers, | |
| integrity: request.integrity, | |
| destination: request.destination, | |
| keepalive: request.keepalive, | |
| method: request.method, | |
| mode: request.mode, | |
| redirect: request.redirect, | |
| referrer: request.referrer, | |
| referrerPolicy: request.referrerPolicy, | |
| signal: request.signal, | |
| }); | |
| } | |
| // π Fetching data like a worldwide explorer! π§ | |
| let r = await fetch(request).catch(e => console.error(e)); | |
| // π If the response status is zero, we return it β probably not what we were hoping for, but hey, it's something π€·ββοΈ | |
| if (r.status === 0) { | |
| return r; | |
| } | |
| // π© Magic header time! Setting the Cross-Origin rules like a boss π§ββοΈ | |
| const headers = new Headers(r.headers); | |
| headers.set("Cross-Origin-Embedder-Policy", "credentialless"); // π‘οΈ Or: 'require-corp', for those fancy users | |
| headers.set("Cross-Origin-Opener-Policy", "same-origin"); // π§± Keep it locked down and safe. | |
| return new Response(r.body, { status: r.status, statusText: r.statusText, headers }); | |
| } | |
| // ποΈ Fetch event listener: "Don't worry, I've got this!" Handling requests like a pro π― | |
| self.addEventListener("fetch", function(e) { | |
| e.respondWith(handleFetch(e.request)); // π‘ respondWith must be synchronous, like a well-timed joke! (But it can wait for a promise π) | |
| }); | |
| } else { | |
| // π If we're running in a window (hello, browser!), we register the service worker like a superhero suiting up π¦ΈββοΈ | |
| (async function() { | |
| // β If we're already isolated, let's not double down on the isolation π | |
| if (window.crossOriginIsolated !== false) return; | |
| // ποΈ Registering the service worker like we're entering the coolest club in town! | |
| let registration = await navigator.serviceWorker.register(window.document.currentScript.src).catch(e => console.error("COOP/COEP Service Worker failed to register:", e)); | |
| if (registration) { | |
| console.log("COOP/COEP Service Worker registered", registration.scope); | |
| // π When the service worker updates, we refresh the page like a fresh cup of coffee β | |
| registration.addEventListener("updatefound", () => { | |
| console.log("Reloading page to make use of updated COOP/COEP Service Worker."); | |
| window.location.reload(); | |
| }); | |
| // π If the service worker is active but not in control, we give the page a fresh reboot π | |
| if (registration.active && !navigator.serviceWorker.controller) { | |
| console.log("Reloading page to make use of COOP/COEP Service Worker."); | |
| window.location.reload(); | |
| } | |
| } | |
| })(); | |
| } | |
| // ποΈ Code to clean up: "Time to say goodbye!" Unregister the service worker and take out the trash π§Ή | |
| // let registrations = await navigator.serviceWorker.getRegistrations(); | |
| // for(let registration of registrations) { | |
| // await registration.unregister(); | |
| // } | |