Skip to content

Commit

Permalink
rename content script api
Browse files Browse the repository at this point in the history
  • Loading branch information
chrmod committed Nov 19, 2024
1 parent 05fd0a5 commit ded4f50
Showing 1 changed file with 35 additions and 32 deletions.
67 changes: 35 additions & 32 deletions src/background/adblocker.js
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ export async function reloadMainEngine() {
console.info('[adblocker] Main engine reloaded with no filters');
}
if (__PLATFORM__ === 'firefox') {
contentScripts.clear();
contentScripts.unregisterAll();
}
}

Expand Down Expand Up @@ -173,23 +173,40 @@ export const setup = asyncSetup([
const contentScripts = (() => {
const map = new Map();
return {
set(key, value) {
this.delete(key);
map.set(key, value);
async register(hostname, code) {
this.delete(hostname);
try {
const contentScript = await browser.contentScripts.register({
js: [
{
code,
},
],
allFrames: true,
matches: [`https://*.${hostname}/*`, `http://*.${hostname}/*`],
matchAboutBlank: true,
matchOriginAsFallback: true,
runAt: 'document_start',
});
map.set(hostname, contentScript);
} catch (e) {
console.warn(e);
contentScripts.unregister(hostname);
}
},
has(key) {
return map.has(key);
isRegistered(hostname) {
return map.has(hostname);
},
delete(key) {
const contentScript = map.get(key);
unregister(hostname) {
const contentScript = map.get(hostname);
if (contentScript) {
contentScript.unregister();
map.delete(key);
map.delete(hostname);
}
},
clear() {
for (const key of map.keys()) {
this.delete(key);
unregisterAll() {
for (const hostname of map.keys()) {
this.unregister(hostname);
}
},
};
Expand Down Expand Up @@ -226,27 +243,13 @@ async function injectScriptlets(scripts, tabId, frameId, hostname) {

if (__PLATFORM__ === 'firefox') {
if (scripts.length === 0) {
contentScripts.delete(hostname);
} else if (!contentScripts.has(hostname)) {
try {
const contentScript = await browser.contentScripts.register({
js: [
{
code: `(${scriptletInjector.toString()})("${encodeURIComponent(scriptlets)}")`,
},
],
allFrames: true,
matches: [`https://*.${hostname}/*`, `http://*.${hostname}/*`],
matchAboutBlank: true,
matchOriginAsFallback: true,
runAt: 'document_start',
});
contentScripts.set(hostname, contentScript);
} catch (e) {
console.warn(e);
contentScripts.delete(hostname);
}
contentScripts.unregister(hostname);
} else if (!contentScripts.isRegistered(hostname)) {
await contentScripts.register(
`(${scriptletInjector.toString()})("${encodeURIComponent(scriptlets)}")`,
);
}
// do nothing if already registered
} else {
if (scripts.length === 0) return;

Expand Down

0 comments on commit ded4f50

Please sign in to comment.