1.0.14.1 FX

This commit is contained in:
clearnet 2019-08-12 11:54:05 +02:00
parent c0838ef0cb
commit 5a88c642d3
4 changed files with 94 additions and 29 deletions

View File

@ -48,8 +48,8 @@ function i_already_know_you(f) {
}); });
} }
function forget_cache_1w() { function forget_cache_2w() {
browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => { browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
browser.storage.local.clear(); browser.storage.local.clear();
browser.storage.local.set({ browser.storage.local.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n') 'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@ -60,6 +60,9 @@ function forget_cache_1w() {
browser.storage.local.set({ browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n') 'obs': (g.obs == 'y' ? 'y' : 'n')
}); });
browser.storage.local.set({
'dbg': (g.dbg == 'y' ? 'y' : 'n')
});
browser.storage.local.set({ browser.storage.local.set({
'lastU': Math.round((new Date()).getTime() / 1000) 'lastU': Math.round((new Date()).getTime() / 1000)
}); });
@ -68,14 +71,14 @@ function forget_cache_1w() {
}); });
}); });
setTimeout(function () { setTimeout(function () {
forget_cache_1w(); forget_cache_2w();
}, 604800000); }, 1209600000);
} }
browser.storage.local.get(['lastU', 'lastV']).then(g => { browser.storage.local.get(['lastU', 'lastV']).then(g => {
if (g.lastU) { if (g.lastU) {
if (Math.abs(Math.round((new Date()).getTime() / 1000) - g.lastU) > 604800) { if (Math.abs(Math.round((new Date()).getTime() / 1000) - g.lastU) > 1209600) {
browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => { browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
browser.storage.local.clear(); browser.storage.local.clear();
browser.storage.local.set({ browser.storage.local.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n') 'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@ -86,6 +89,9 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
browser.storage.local.set({ browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n') 'obs': (g.obs == 'y' ? 'y' : 'n')
}); });
browser.storage.local.set({
'dbg': (g.dbg == 'y' ? 'y' : 'n')
});
browser.storage.local.set({ browser.storage.local.set({
'lastU': Math.round((new Date()).getTime() / 1000) 'lastU': Math.round((new Date()).getTime() / 1000)
}); });
@ -99,7 +105,7 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
let nowVer = (browser.runtime.getManifest()).version; let nowVer = (browser.runtime.getManifest()).version;
if (g.lastV != nowVer) { if (g.lastV != nowVer) {
console.log('Updated', nowVer); console.log('Updated', nowVer);
browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => { browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
browser.storage.local.clear(); browser.storage.local.clear();
browser.storage.local.set({ browser.storage.local.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n') 'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@ -110,6 +116,9 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
browser.storage.local.set({ browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n') 'obs': (g.obs == 'y' ? 'y' : 'n')
}); });
browser.storage.local.set({
'dbg': (g.dbg == 'y' ? 'y' : 'n')
});
browser.storage.local.set({ browser.storage.local.set({
'lastU': Math.round((new Date()).getTime() / 1000) 'lastU': Math.round((new Date()).getTime() / 1000)
}); });
@ -119,8 +128,8 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
}); });
} }
setTimeout(function () { setTimeout(function () {
forget_cache_1w(); forget_cache_2w();
}, 604800000); }, 1209600000);
}); });
browser.runtime.onMessage.addListener((request, sender, sendResponse) => { browser.runtime.onMessage.addListener((request, sender, sendResponse) => {
@ -141,4 +150,5 @@ browser.runtime.onMessage.addListener((request, sender, sendResponse) => {
} }
}, () => {}); }, () => {});
} }
return;
}); });

View File

@ -1,8 +1,17 @@
<html> <html>
<head>
<meta http-equiv="content-type" content="text/html;charset=UTF-8">
</head>
<body> <body>
<label><input type="checkbox" id="ign1"> Ignoru unuan partion FQDN (Ne Rekomendas)</label><br> <label><input type="checkbox" id="ign1"> Ignoru unuan partion FQDN (Ne Rekomendas)</label><br>
<label><input type="checkbox" id="ign2"> Ignoru infektitan bildon (Ne Rekomendas)</label><br> <label><input type="checkbox" id="ign2"> Ignoru infektitan bildon (Ne Rekomendas)</label><br>
<label><input type="checkbox" id="obs"> Ankaŭ skani ligojn aldonitajn de Ĝavaskripto (Rekomendi)</label><br> <label><input type="checkbox" id="obs"> Ankaŭ skani ligojn aldonitajn de Ĝavaskripto (Rekomendi)</label><br>
<label><input type="checkbox" id="dbg"> Montri demandon en konzolo</label><br>
<br>&nbsp;<br>&nbsp;<br>
Informoj pri kaŝmemoro<br>&nbsp;<br>
Infektita: <input type="text" id="viry" readonly><br>
Ne infektita: <input type="text" id="virn" readonly><br>
Entute: <input type="text" id="viro" readonly><br>
<script src="cs.js"></script> <script src="cs.js"></script>
</body> </body>
</html> </html>

View File

@ -1,9 +1,10 @@
if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org'].includes(location.hostname)) { if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org'].includes(location.hostname)) {
if (location.protocol === 'moz-extension:' && location.pathname === '/cfg.html') { if (location.protocol === 'moz-extension:' && location.pathname === '/cfg.html') {
browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => { browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
document.getElementById('ign1').checked = (g.ign1 == 'y') ? true : false; document.getElementById('ign1').checked = (g.ign1 == 'y') ? true : false;
document.getElementById('ign2').checked = (g.ign2 == 'y') ? true : false; document.getElementById('ign2').checked = (g.ign2 == 'y') ? true : false;
document.getElementById('obs').checked = (g.obs == 'y') ? true : false; document.getElementById('obs').checked = (g.obs == 'y') ? true : false;
document.getElementById('dbg').checked = (g.dbg == 'y') ? true : false;
}); });
document.getElementById('ign1').addEventListener('click', () => { document.getElementById('ign1').addEventListener('click', () => {
browser.storage.local.set({ browser.storage.local.set({
@ -20,6 +21,34 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lw
'obs': (document.getElementById('obs').checked ? 'y' : 'n') 'obs': (document.getElementById('obs').checked ? 'y' : 'n')
}); });
}); });
document.getElementById('dbg').addEventListener('click', () => {
browser.storage.local.set({
'dbg': (document.getElementById('dbg').checked ? 'y' : 'n')
});
});
browser.storage.local.get().then(g => {
let iY = 0,
iN = 0,
iT, tmp;
Object.keys(g).forEach(a => {
if (!['ign1', 'ign2', 'obs', 'dbg', 'lastU', 'lastV'].includes(a)) {
if (g[a] == 'y') {
iY++;
}
if (g[a] == 'n') {
iN++;
}
}
});
iT = iY + iN;
if (iT > 0) {
tmp = (iY * 100 / iT).toFixed(1);
document.getElementById('viry').value = iY + ' domajnoj (' + tmp + '%)';
tmp = (iN * 100 / iT).toFixed(1);
document.getElementById('virn').value = iN + ' domajnoj (' + tmp + '%)';
document.getElementById('viro').value = (iY + iN) + ' domajnoj';
}
});
} else { } else {
let cs = (function () { let cs = (function () {
let s = document.createElement('style'); let s = document.createElement('style');
@ -34,29 +63,42 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lw
cs.insertRule("img[data-mitm=y]{cursor:not-allowed !important;border:2px red dotted !important}", 4); cs.insertRule("img[data-mitm=y]{cursor:not-allowed !important;border:2px red dotted !important}", 4);
cs.insertRule("img[data-mitm=y]:hover{filter:sepia(20%)}", 5); cs.insertRule("img[data-mitm=y]:hover{filter:sepia(20%)}", 5);
} }
browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => { browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
let asked = ['', 'searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org', 'addons.mozilla.org', 'addons.thunderbird.net', 'web.archive.org', 't.co']; let asked = ['', 'searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org', 'addons.mozilla.org', 'addons.thunderbird.net', 'web.archive.org', 't.co'];
if (g.ign1 == 'y') { if (g.ign1 == 'y') {
asked.push(location.hostname); asked.push(location.hostname);
} }
let qstall = (g.ign2 == 'y') ? 'a[href]:not([data-mitm])' : 'a[href]:not([data-mitm]),img[src]:not([data-mitm])'; let qstall = (g.ign2 == 'y') ? 'a[href]:not([data-mitm])' : 'a[href]:not([data-mitm]),img[src]:not([data-mitm])';
let running = false;
function scanme() { function scanme() {
if (!running) {
running = true;
if (location.hostname == 'twitter.com') { if (location.hostname == 'twitter.com') {
document.querySelectorAll("a[href^='https://t.co/'][data-expanded-url^='http']").forEach(a => { document.querySelectorAll("a[href^='https://t.co/'][data-expanded-url^='http']").forEach(a => {
a.href = a.dataset.expandedUrl; a.href = a.dataset.expandedUrl;
}); });
} }
let unknown = [];
document.querySelectorAll(qstall).forEach(a => { document.querySelectorAll(qstall).forEach(a => {
let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || ''; let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || '';
if (!asked.includes(aF) && !/^(.*)\.(danwin1210\.me|onion|i2p|invalid|test|local|localhost|([0-9]{1,3})|bbs|chan|cyb|dyn|geek|gopher|indy|libre|neo|null|o|oss|oz|parody|pirate|bit|lib|coin|emc|bazar|fur)$/.test(aF)) { if (!asked.includes(aF)) {
asked.push(aF); asked.push(aF);
browser.runtime.sendMessage(aF); if (!/^(.*)\.(danwin1210\.me|onion|i2p|invalid|test|local|localhost|([0-9]{1,3})|bbs|chan|cyb|dyn|geek|gopher|indy|libre|neo|null|o|oss|oz|parody|pirate|bit|lib|coin|emc|bazar|fur)$/.test(aF)) {
unknown.push(aF);
}
} }
}); });
unknown.forEach(a => {
browser.runtime.sendMessage(a);
});
running = false;
}
} }
scanme();
browser.runtime.onMessage.addListener((request, sender, sendResponse) => { browser.runtime.onMessage.addListener((request, sender, sendResponse) => {
if (request.length == 2) { if (request.length == 2) {
if (g.dbg == 'y') {
console.log('isMITM:', request[0], request[1]);
}
document.querySelectorAll(qstall).forEach(a => { document.querySelectorAll(qstall).forEach(a => {
let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || ''; let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || '';
if (aF == request[0]) { if (aF == request[0]) {
@ -70,13 +112,17 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lw
}); });
} }
sendResponse(null); sendResponse(null);
return;
}); });
scanme();
if (g.obs == 'y') { if (g.obs == 'y') {
window.addEventListener('load', function () {
(new MutationObserver(scanme)).observe(document, { (new MutationObserver(scanme)).observe(document, {
attributes: true, attributes: true,
childList: true, childList: true,
subtree: true subtree: true
}); });
});
} }
}); });
} }

View File

@ -1,8 +1,8 @@
{ {
"manifest_version": 2, "manifest_version": 2,
"name": "Are links vulnerable to MITM attack?", "name": "Ĉu ligoj estas vundeblaj al MITM-atako?",
"description": "Skanu FQDN uzante la API de Searxes", "description": "Skanu FQDN uzante la API de Searxes",
"version": "1.0.13", "version": "1.0.14.1",
"homepage_url": "https://codeberg.org/crimeflare/cloudflare-tor", "homepage_url": "https://codeberg.org/crimeflare/cloudflare-tor",
"author": "Maslin Bossé", "author": "Maslin Bossé",
"permissions": [ "permissions": [