re-nav/source/background-scripts/initialize.ts

57 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-10-14 16:15:04 +00:00
import browser from 'webextension-polyfill';
import {parseRedirect} from '../redirect/exports.js';
async function browserActionClicked() {
await browser.runtime.openOptionsPage();
}
if (import.meta.env.VITE_BROWSER === 'chromium') {
browser.action.onClicked.addListener(browserActionClicked);
} else {
browser.browserAction.onClicked.addListener(browserActionClicked);
}
browser.runtime.onInstalled.addListener(async () => {
if (import.meta.env.DEV) {
await browser.runtime.openOptionsPage();
}
});
browser.webNavigation.onBeforeNavigate.addListener(async (details) => {
if (!details.url.startsWith('http')) {
return;
}
2022-10-21 16:49:16 +00:00
const {latestTime} = await browser.storage.local.get('latestTime');
const redirectDelta = Date.now() - (latestTime ?? 0);
if (redirectDelta < 100) {
return;
}
2022-10-14 16:15:04 +00:00
const url = new URL(details.url);
2022-10-21 16:49:16 +00:00
const {latestUrl} = await browser.storage.local.get('latestUrl');
if (redirectDelta < 30_000 && url.href === latestUrl) {
return;
}
2022-10-14 16:15:04 +00:00
2022-10-19 19:10:41 +00:00
for (const [id, parameters] of Object.entries(
await browser.storage.local.get(),
)) {
const redirect = parseRedirect(parameters, id);
2022-10-26 12:47:42 +00:00
if (redirect === undefined || !redirect.parameters.enabled) {
2022-10-14 16:15:04 +00:00
continue;
}
if (redirect.isMatch(url)) {
const redirectedUrl = redirect.redirect(url);
await browser.tabs.update({url: redirectedUrl.href});
2022-10-21 16:49:16 +00:00
await browser.storage.local.set({
latestTime: Date.now(),
latestUrl: url.href,
});
2022-10-14 16:15:04 +00:00
break;
}
}
});