Skip to content

Commit

Permalink
Added Neuters #231
Browse files Browse the repository at this point in the history
  • Loading branch information
ManeraKai committed Jun 11, 2022
1 parent 12d484a commit cd28522
Show file tree
Hide file tree
Showing 17 changed files with 291 additions and 7 deletions.
1 change: 1 addition & 0 deletions src/assets/images/reuters.svg
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
1 change: 1 addition & 0 deletions src/assets/javascripts/general.js
Expand Up @@ -64,6 +64,7 @@ const allPopupFrontends = [
"wikipedia",
"medium",
"quora",
"reuters",
"peertube",
"lbry",
"sendTargets"
Expand Down
2 changes: 0 additions & 2 deletions src/assets/javascripts/quora.js
Expand Up @@ -65,8 +65,6 @@ function init() {
init();
browser.storage.onChanged.addListener(init)

// https://www.quora.com/@keysikaspol/video/7061265241887345946
// https://www.quora.com/@keysikaspol
function redirect(url, type, initiator) {
if (disableQuora) return;
if (type != "main_frame") return;
Expand Down
106 changes: 106 additions & 0 deletions src/assets/javascripts/reuters.js
@@ -0,0 +1,106 @@
window.browser = window.browser || window.chrome;

import utils from './utils.js'

const targets = [
/^https?:\/{2}(www\.|)reuters\.com.*/
];

let redirects = {
"neuters": {
"normal": [
'https://neuters.de',
],
"tor": []
}
}

let
disableReuters,
reutersProtocol,
reutersRedirects,
neutersNormalRedirectsChecks,
neutersNormalCustomRedirects,
neutersTorRedirectsChecks,
neutersTorCustomRedirects;

function init() {
return new Promise(async resolve => {
browser.storage.local.get(
[
"disableReuters",
"reutersProtocol",
"reutersRedirects",
"neutersNormalRedirectsChecks",
"neutersNormalCustomRedirects",
"neutersTorRedirectsChecks",
"neutersTorCustomRedirects",
],
r => {
disableReuters = r.disableReuters;
reutersProtocol = r.reutersProtocol;
reutersRedirects = r.reutersRedirects;
neutersNormalRedirectsChecks = r.neutersNormalRedirectsChecks;
neutersNormalCustomRedirects = r.neutersNormalCustomRedirects;
neutersTorRedirectsChecks = r.neutersTorRedirectsChecks;
neutersTorCustomRedirects = r.neutersTorCustomRedirects;
resolve();
}
)
})
}

init();
browser.storage.onChanged.addListener(init)

function redirect(url, type, initiator) {
if (disableReuters) return;
if (type != "main_frame") return;
const all = [
...reutersRedirects.neuters.normal,
...neutersNormalCustomRedirects
];
if (initiator && (all.includes(initiator.origin) || targets.includes(initiator.host))) return;
if (!targets.some(rx => rx.test(url.href))) return;

let instancesList;
if (reutersProtocol == 'normal') instancesList = [...neutersNormalRedirectsChecks, ...neutersNormalCustomRedirects];
if (reutersProtocol == 'tor') instancesList = [...neutersTorRedirectsChecks, ...neutersTorCustomRedirects];
if (instancesList.length === 0) return;

const randomInstance = utils.getRandomInstance(instancesList);
// stolen from https://addons.mozilla.org/en-US/firefox/addon/reuters-redirect/
if (
url.pathname.startsWith('/article/') ||
url.pathname.startsWith('/pf/') ||
url.pathname.startsWith('/arc/') ||
url.pathname.startsWith('/resizer/')
)
return null;
else if (url.pathname.endsWith('/'))
return `${randomInstance}${url.pathname}`;
else
return `${randomInstance}${url.pathname}/`;
}

function initDefaults() {
return new Promise(resolve => {
browser.storage.local.set({
disableReuters: false,
reutersProtocol: "normal",

reutersRedirects: redirects,

neutersNormalRedirectsChecks: [...redirects.neuters.normal],
neutersNormalCustomRedirects: [],

neutersTorRedirectsChecks: [...redirects.neuters.tor],
neutersTorCustomRedirects: [],
}, () => resolve());
});
}

export default {
redirect,
initDefaults
};

0 comments on commit cd28522

Please sign in to comment.