From 80af6f6feac086490f841adad5fe769d71be86f8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kevin=20R=C3=B6bert?= Date: Thu, 14 Mar 2019 17:59:16 +0100 Subject: [PATCH] Better performance + "unlimitedStorage" permission + Changed the regex interpretation for better performance. + Also asked for "unlimitedStorage" permission to have enough space for user generated rules. --- clearurls.js | 101 +++++++++++++++++++++++++++----------------------- manifest.json | 5 ++- 2 files changed, 57 insertions(+), 49 deletions(-) diff --git a/clearurls.js b/clearurls.js index 1d09125..c5c5d30 100644 --- a/clearurls.js +++ b/clearurls.js @@ -1,20 +1,20 @@ /* - * ClearURLs - * Copyright (c) 2017-2019 Kevin Röbert - * - * This program is free software: you can redistribute it and/or modify - * it under the terms of the GNU Lesser General Public License as published by - * the Free Software Foundation, either version 3 of the License, or - * (at your option) any later version. - * - * This program 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 Lesser General Public License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with this program. If not, see . - */ +* ClearURLs +* Copyright (c) 2017-2019 Kevin Röbert +* +* This program is free software: you can redistribute it and/or modify +* it under the terms of the GNU Lesser General Public License as published by +* the Free Software Foundation, either version 3 of the License, or +* (at your option) any later version. +* +* This program 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 Lesser General Public License for more details. +* +* You should have received a copy of the GNU Lesser General Public License +* along with this program. If not, see . +*/ /*jshint esversion: 6 */ /* @@ -29,6 +29,7 @@ var dataHash; var localDataHash; var os; var currentURL; +var lastVisited = ""; function start() { @@ -237,8 +238,7 @@ function start() * @param {boolean} isActive Is this rule active? */ this.addRule = function(rule, isActive = true) { - // Add start and end delimiters to rule - rule = "^"+rule+"=[^\\/|\\?|&]*(\\/|&(amp;)?)?$"; + rule = "([\\/|\\?]|(&|&))("+rule+"=[^\\/|\\?|&]*)"; if(isActive) { @@ -414,41 +414,42 @@ function start() * before the last ?. With adding a ? on the quantifier *, * we fixed this problem. */ - fields = extractFileds(url.replace(new RegExp(".*?\\?", "i"), "")); + fields = "?"+url.replace(new RegExp(".*?\\?", "i"), ""); - fields.forEach(function(field, index) { - rules.forEach(function(rule) { - var beforReplace = fields.flat().join("&"); - var match = new RegExp(rule, "i").test(field); + rules.forEach(function(rule) { + var beforReplace = fields; + fields = fields.replace(new RegExp(rule, "gi"), ""); - if(match) { - delete fields[index]; - - //Log the action - pushToLog(domain+"?"+beforReplace, domain+"?"+fields.flat().join("&"), rule); - - if(badges[tabid] == null) badges[tabid] = 0; - - increaseURLCounter(); - - if(!checkOSAndroid()) - { - if(storage.badgedStatus) { - browser.browserAction.setBadgeText({text: (++badges[tabid]).toString(), tabId: tabid}); - } - else - { - browser.browserAction.setBadgeText({text: "", tabId: tabid}); - } - } - changes = true; + if(beforReplace !== fields) + { + //Log the action + if(storage.loggingStatus) + { + pushToLog(domain+beforReplace, domain+"?"+extractFileds(fields).flat().join("&"), rule); } - }); + + if(badges[tabid] == null) badges[tabid] = 0; + + increaseURLCounter(); + + if(!checkOSAndroid()) + { + if(storage.badgedStatus) { + browser.browserAction.setBadgeText({text: (++badges[tabid]).toString(), tabId: tabid}); + } + else + { + browser.browserAction.setBadgeText({text: "", tabId: tabid}); + } + } + changes = true; + } }); - if(fields.flat().length > 0) + var finalFields = extractFileds(fields).flat(); + if(finalFields.length > 0) { - url = domain+"?"+fields.flat().join("&"); + url = domain+"?"+finalFields.join("&"); } else{ url = domain; @@ -507,6 +508,10 @@ function start() increaseGlobalURLCounter(URLbeforeReplaceCount); if(storage.globalStatus){ + // The URL is already cleaned + if(lastVisited === request.url) { + return {}; + } var result = { "changes": false, @@ -550,6 +555,8 @@ function start() * a loop. */ if(result.changes){ + lastVisited = result.url; + return { redirectUrl: result.url }; diff --git a/manifest.json b/manifest.json index f76beae..6d9cfba 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, "name": "ClearURLs", - "version": "1.5a", + "version": "1.5.1a", "author": "Kevin R.", "description": "Remove tracking elements form URLs.", "homepage_url": "https://gitlab.com/KevinRoebert/ClearUrls", @@ -50,7 +50,8 @@ "webRequest", "webRequestBlocking", "storage", - "tabs" + "tabs", + "unlimitedStorage" ], "background": { "scripts": [