Skip to content

Commit

Permalink
Fix bug in migration
Browse files Browse the repository at this point in the history
  • Loading branch information
dthung1602 committed May 15, 2022
1 parent b8b037e commit 32d42db
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 14 deletions.
18 changes: 10 additions & 8 deletions scripts/clean-spams.js
Original file line number Diff line number Diff line change
Expand Up @@ -25,10 +25,6 @@ function getAncestor(node, num, tillEncounterClass) {
return node;
}

function log(nodes) {
console.log(`Found ${nodes.length} link in ${window.document.title}`);
}

let counter = 0;
const AVATAR_DATA_URI = "";

Expand Down Expand Up @@ -114,22 +110,28 @@ async function cleanSpams() {
const action = actionMapping.get(cleanSpamAction);
const filter = (node) => containBanDomain(node, banDomains);

let spamCount = 0;
const count = () => spamCount += 1;

// replace links in nested comments
const linksInNestedComments = window.document.querySelectorAll(".UFIImageBlockContent .UFIImageBlockContent ._5mdd a");
log(linksInNestedComments);
Array.from(linksInNestedComments)
.filter(filter)
.map((node) => getAncestor(node, 11).querySelector("._3-8m"))
.forEach(action);
.map(action)
.map(count);

// replace text spams in comments & nested comments
const uncheckedComments = window.document.querySelectorAll("._3-8m:not(.spam-free)");
Array.from(uncheckedComments)
.filter(filter)
.forEach((node) => {
.map((node) => {
node.classList.add("spam-free");
action(node)
});
})
.map(count);

console.log(`Found ${spamCount} spams`);
}

cleanSpams().catch(console.error);
Expand Down
20 changes: 14 additions & 6 deletions scripts/service-worker.js
Original file line number Diff line number Diff line change
Expand Up @@ -60,23 +60,31 @@ const NEW_BAN_DOMAINS_1 = [
"/www[a-z0-9-.]*cash[a-z0-9-.]*com/",
]

async function migrationToVer1_0_1() {
let { banDomains } = await browser.storage.local.get(["banDomains"]);
DEFAULT_TEXT = "<i>Just a spam, nothing to see here</i>";

async function migrationToVer1_1_0() {
let { banDomains, cleanSpamText, clearSpamInterval } = await browser.storage.local.get([
"banDomains", "cleanSpamText", "clearSpamInterval"
]);
banDomains = Array.from(new Set([...banDomains, ...NEW_BAN_DOMAINS_1]));
cleanSpamText = cleanSpamText || DEFAULT_TEXT;
clearSpamInterval = clearSpamInterval === 1500 ? 1000 : clearSpamInterval;
await browser.storage.local.set({
version: "1.0.1",
banDomains
version: "1.1.0",
banDomains,
cleanSpamText,
clearSpamInterval,
})
}

const migrations = [
["1.0", migrateToVer1],
["1.0.1", migrationToVer1_0_1],
["1.1.0", migrationToVer1_1_0],
];

browser.runtime.onInstalled.addListener(async () => {
try {
let { version: installedVersion } = browser.storage.local.get("version");
let { version: installedVersion } = await browser.storage.local.get("version");
installedVersion = installedVersion || "0.1";
for (let [ver, migrate] of migrations) {
if (installedVersion < ver) {
Expand Down

0 comments on commit 32d42db

Please sign in to comment.