mirror of
https://github.com/MercuryWorkshop/scramjet.git
synced 2025-05-14 23:10:02 -04:00
clean up worker code
This commit is contained in:
parent
8c58108727
commit
c189e54509
3 changed files with 1550 additions and 1212 deletions
2563
pnpm-lock.yaml
generated
2563
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load diff
|
@ -17,7 +17,14 @@ self.ScramjetServiceWorker = class ScramjetServiceWorker {
|
||||||
this.client = new BareClient();
|
this.client = new BareClient();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
route(event: Event | any) {
|
||||||
|
const { request } = event;
|
||||||
|
if (request.url.startsWith(location.origin + self.__scramjet$config.prefix)) return true;
|
||||||
|
else return false;
|
||||||
|
}
|
||||||
|
|
||||||
async fetch(event: FetchEvent) {
|
async fetch(event: FetchEvent) {
|
||||||
|
try {
|
||||||
const url = new URL(self.__scramjet$bundle.rewriters.url.decodeUrl(event.request.url));
|
const url = new URL(self.__scramjet$bundle.rewriters.url.decodeUrl(event.request.url));
|
||||||
|
|
||||||
// implement header rewriting later
|
// implement header rewriting later
|
||||||
|
@ -30,12 +37,10 @@ self.ScramjetServiceWorker = class ScramjetServiceWorker {
|
||||||
|
|
||||||
let responseBody;
|
let responseBody;
|
||||||
const responseHeaders = self.__scramjet$bundle.rewriters.rewriteHeaders(response.rawHeaders, origin);
|
const responseHeaders = self.__scramjet$bundle.rewriters.rewriteHeaders(response.rawHeaders, origin);
|
||||||
|
if (response.body) {
|
||||||
switch (event.request.destination) {
|
switch (event.request.destination) {
|
||||||
case "document":
|
|
||||||
responseBody = self.__scramjet$bundle.rewriters.rewriteHtml(await response.text(), url.origin);
|
|
||||||
break;
|
|
||||||
case "iframe":
|
case "iframe":
|
||||||
|
case "document":
|
||||||
responseBody = self.__scramjet$bundle.rewriters.rewriteHtml(await response.text(), url.origin);
|
responseBody = self.__scramjet$bundle.rewriters.rewriteHtml(await response.text(), url.origin);
|
||||||
break;
|
break;
|
||||||
case "script":
|
case "script":
|
||||||
|
@ -52,7 +57,11 @@ self.ScramjetServiceWorker = class ScramjetServiceWorker {
|
||||||
responseBody = response.body;
|
responseBody = response.body;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (responseHeaders.accept === 'text/event-stream') {
|
||||||
|
responseHeaders.headers['content-type'] = 'text/event-stream';
|
||||||
|
}
|
||||||
if (crossOriginIsolated) {
|
if (crossOriginIsolated) {
|
||||||
responseHeaders["Cross-Origin-Embedder-Policy"] = "require-corp";
|
responseHeaders["Cross-Origin-Embedder-Policy"] = "require-corp";
|
||||||
}
|
}
|
||||||
|
@ -62,5 +71,11 @@ self.ScramjetServiceWorker = class ScramjetServiceWorker {
|
||||||
status: response.status,
|
status: response.status,
|
||||||
statusText: response.statusText
|
statusText: response.statusText
|
||||||
})
|
})
|
||||||
|
} catch (err) {
|
||||||
|
if (!['document', 'iframe'].includes(event.request.destination))
|
||||||
|
return new Response(undefined, { status: 500 });
|
||||||
|
|
||||||
|
console.error(err);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ const scramjet = new ScramjetServiceWorker();
|
||||||
|
|
||||||
self.addEventListener("fetch", async (event) => {
|
self.addEventListener("fetch", async (event) => {
|
||||||
event.respondWith((async() => {
|
event.respondWith((async() => {
|
||||||
if (event.request.url.startsWith(location.origin + __scramjet$config.prefix)) {
|
if (scramjet.route(event)) {
|
||||||
return await scramjet.fetch(event);
|
return await scramjet.fetch(event);
|
||||||
} else {
|
} else {
|
||||||
return await fetch(event.request);
|
return await fetch(event.request);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue