aboutsummaryrefslogtreecommitdiff
path: root/bg
diff options
context:
space:
mode:
authorhackademix <giorgio@maone.net>2018-07-31 18:08:45 +0200
committerhackademix <giorgio@maone.net>2018-07-31 18:10:42 +0200
commit5975e67b1de999c168209f8a5b7652f3d4551412 (patch)
tree9ddac462cb5c4cde58e521d5d96dec5469c57b98 /bg
parent0039b016a8e9d13de5b70e09833aa0cc768350c5 (diff)
Refactoring out list management in its own class / bug fixing and simplifying UI synchronization.
Diffstat (limited to 'bg')
-rw-r--r--bg/ListManager.js71
1 files changed, 71 insertions, 0 deletions
diff --git a/bg/ListManager.js b/bg/ListManager.js
new file mode 100644
index 0000000..34d9531
--- /dev/null
+++ b/bg/ListManager.js
@@ -0,0 +1,71 @@
+/**
+* GNU LibreJS - A browser add-on to block nonfree nontrivial JavaScript.
+*
+* Copyright (C) 2018 Giorgio Maone <giorgio@maone.net>
+*
+* This file is part of GNU LibreJS.
+*
+* GNU LibreJS is free software: you can redistribute it and/or modify
+* it under the terms of the GNU General Public License as published by
+* the Free Software Foundation, either version 3 of the License, or
+* (at your option) any later version.
+*
+* GNU LibreJS is distributed in the hope that it will be useful,
+* but WITHOUT ANY WARRANTY; without even the implied warranty of
+* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+* GNU General Public License for more details.
+*
+* You should have received a copy of the GNU General Public License
+* along with GNU LibreJS. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+/*
+ A class to manage whitelist/blacklist operations
+*/
+
+let {ListStore} = require("./Storage");
+
+class ListManager {
+ constructor(whitelist, blacklist, builtInHashes) {
+ this.lists = {whitelist, blacklist};
+ this.builtInHashes = new Set(builtInHashes);
+ }
+ async whitelist(key) {
+ await this.lists.blacklist.remove(key);
+ await this.lists.whitelist.store(key);
+ }
+ async blacklist(key) {
+ await this.lists.whitelist.remove(key);
+ await this.lists.blacklist.store(key);
+ }
+ async forget(key) {
+ for (let list of Object.values(this.lists)) {
+ await list.remove(key);
+ }
+ }
+ /* key is a string representing either a URL or an optional path
+ with a trailing (hash).
+ Returns "blacklisted", "whitelisted" or defValue
+ */
+ getStatus(key, defValue = "unknown") {
+ let {blacklist, whitelist} = this.lists;
+ let match = key.match(/\(([^)]+)\)(?=[^()]*$)/);
+ if (!match) {
+ let url = ListStore.urlItem(key);
+ let site = ListStore.siteItem(key);
+ return (blacklist.contains(url) || blacklist.contains(site))
+ ? "blacklisted"
+ : whitelist.contains(url) || whitelist.contains(site)
+ ? "whitelisted" : defValue;
+ }
+
+ let [hashItem, srcHash] = match; // (hash), hash
+
+ return blacklist.contains(hashItem) ? "blacklisted"
+ : this.builtInHashes.has(srcHash) || whitelist.contains(hashItem)
+ ? "whitelisted"
+ : defValue;
+ }
+}
+
+module.exports = { ListManager };