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

106 lines
3.0 KiB
TypeScript
Raw Normal View History

2022-10-14 16:15:04 +00:00
import browser from 'webextension-polyfill';
import storage from '../redirect/storage.js';
import {updateBadge} from '../utilities/badge.js';
import {
contextClicked,
getContextMenus,
initializeContextMenus,
} from './context-menus.js';
2022-10-14 16:15:04 +00:00
async function browserActionClicked() {
await browser.runtime.openOptionsPage();
}
browser.runtime.onInstalled.addListener(async () => {
await initializeContextMenus();
await updateBadge();
2022-10-14 16:15:04 +00:00
if (import.meta.env.DEV) {
await browser.runtime.openOptionsPage();
}
});
browser.runtime.onStartup.addListener(async () => {
await updateBadge();
});
2022-10-14 16:15:04 +00:00
browser.webNavigation.onBeforeNavigate.addListener(async (details) => {
2022-11-15 11:56:27 +00:00
const {redirectsEnabled} = await browser.storage.local.get({
redirectsEnabled: true,
});
if (redirectsEnabled === false) {
return;
}
2022-11-02 11:16:39 +00:00
if (!details.url.startsWith('http') || details.frameId > 0) {
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;
}
const tab = await browser.tabs.query({active: true, lastFocusedWindow: true});
const currentTabUrl =
tab[0]?.url === undefined ? undefined : new URL(tab[0].url);
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
for (const redirect of await storage.getRedirects()) {
if (!redirect.parameters.enabled) {
2022-10-14 16:15:04 +00:00
continue;
}
if (redirect.isMatch(url)) {
// Don't redirect if the URL before going to a new page is also a match.
// This will happen when the user is already on a website that has a
// redirect, but for whatever reason hasn't redirected. So it's safe to
// assume that they want to stay on this website, rather than get
// redirected.
if (currentTabUrl !== undefined && redirect.isMatch(currentTabUrl)) {
break;
}
let redirectedUrl = redirect.redirect(url);
if (typeof redirectedUrl === 'string') {
try {
redirectedUrl = new URL(redirectedUrl);
} catch {
redirectedUrl = `https://${redirectedUrl as string}`;
redirectedUrl = new URL(redirectedUrl);
}
}
2022-10-26 16:00:42 +00:00
await browser.tabs.update(details.tabId, {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;
}
}
});
browser.contextMenus.onClicked.addListener(async (info, tab) => {
const contextMenus = getContextMenus();
const contextMenuIds = new Set<string>(
contextMenus.map(({id}) => id ?? 're-nav-unknown'),
);
await contextClicked(contextMenuIds, info, tab);
});
if (import.meta.env.VITE_BROWSER === 'chromium') {
browser.action.onClicked.addListener(browserActionClicked);
} else {
browser.browserAction.onClicked.addListener(browserActionClicked);
void initializeContextMenus();
}