From 50673f7dc590047a1ce60ab0f5b3ebba814dfe6d Mon Sep 17 00:00:00 2001
From: Aaron Kollasch
Date: Mon, 23 May 2022 15:30:08 -0400
Subject: [PATCH] Add a soft-allowlist for URLs allowed in or out of GC
---
background.js | 32 +++++++++++++++++++++++++++++---
options.html | 12 +++++++++++-
options.js | 2 ++
3 files changed, 42 insertions(+), 4 deletions(-)
diff --git a/background.js b/background.js
index 1236760..0e5488f 100644
--- a/background.js
+++ b/background.js
@@ -55,6 +55,7 @@ const googleHostREs = [];
const youtubeHostREs = [];
const whitelistedHostREs = [];
const allowlistedHostREs = [];
+const softAllowlistedHostREs = [];
async function isMACAddonEnabled () {
try {
@@ -181,6 +182,15 @@ function generateAllowlistedHostREs () {
}
}
+function generateSoftAllowlistedHostREs () {
+ if (softAllowlistedHostREs.length != 0) {return;}
+ const matchOperatorsRegex = /[|\\{}()[\]^$+*?.-]/g;
+ for (let allowlistedDomain of extensionSettings.soft_allowlist) {
+ allowlistedDomain = allowlistedDomain.replace(matchOperatorsRegex, '\\$&');
+ softAllowlistedHostREs.push(new RegExp(`(^|\\.)${allowlistedDomain}$`));
+ }
+}
+
async function loadExtensionSettings () {
extensionSettings = await browser.storage.sync.get();
if (extensionSettings.whitelist === undefined){
@@ -189,6 +199,9 @@ async function loadExtensionSettings () {
if (extensionSettings.allowlist === undefined){
extensionSettings.allowlist = "";
}
+ if (extensionSettings.soft_allowlist === undefined){
+ ▸ extensionSettings.soft_allowlist = "";
+ }
}
async function clearGoogleCookies () {
@@ -312,6 +325,18 @@ function isAllowlistedURL (url) {
return false;
}
+function isSoftAllowlistedURL (url) {
+ generateSoftAllowlistedHostREs();
+ const parsedUrl = new URL(url);
+ for (let allowlistedHostRE of softAllowlistedHostREs) {
+ if (allowlistedHostRE.test(parsedUrl.hostname)) {
+ return true;
+ }
+ }
+ return false;
+}
+
+
function isSearchPageURL (url) {
const parsedUrl = new URL(url);
return parsedUrl.pathname.startsWith('/search');
@@ -344,7 +369,8 @@ function shouldContainInto (url, tab) {
}
let allowlistUrl = (extensionSettings.allowlist.length!=0 && isAllowlistedURL(url));
- let handleUrl = isGoogleURL(url) || allowlistUrl;
+ let softAllowlistUrl = (extensionSettings.soft_allowlist.length!=0 && isSoftAllowlistedURL(url));
+ let handleUrl = isGoogleURL(url) || allowlistUrl || softAllowlistUrl;
if (handleUrl && extensionSettings.whitelist.length!=0 && isWhitelistedURL(url)) {
handleUrl = false;
@@ -381,8 +407,8 @@ function shouldContainInto (url, tab) {
return false;
}
- if (allowlistUrl) {
- // Don't force an allowlisted URL to be in the Google Container
+ if (softAllowlistUrl) {
+ // Don't force an soft-allowlisted URL to be in the Google Container
return false;
}
diff --git a/options.html b/options.html
index 877f854..0386cbc 100644
--- a/options.html
+++ b/options.html
@@ -68,7 +68,17 @@
Settings
Include additional urls in Google Container
- (Means use Google Container on these additional urls, e.g. for third party SSO or "Log in with Google". Use one url per line.)
+ (Means always use Google Container on these additional urls, e.g. for "Log in with Google". Use one url per line.)
+
+