diff --git a/addon_firefox/ismitmlink/bg.js b/addon_firefox/ismitmlink/bg.js
index af20d0e..4e5e82a 100644
--- a/addon_firefox/ismitmlink/bg.js
+++ b/addon_firefox/ismitmlink/bg.js
@@ -48,8 +48,8 @@ function i_already_know_you(f) {
});
}
-function forget_cache_1w() {
- browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => {
+function forget_cache_2w() {
+ browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
browser.storage.local.clear();
browser.storage.local.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@@ -60,6 +60,9 @@ function forget_cache_1w() {
browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n')
});
+ browser.storage.local.set({
+ 'dbg': (g.dbg == 'y' ? 'y' : 'n')
+ });
browser.storage.local.set({
'lastU': Math.round((new Date()).getTime() / 1000)
});
@@ -68,14 +71,14 @@ function forget_cache_1w() {
});
});
setTimeout(function () {
- forget_cache_1w();
- }, 604800000);
+ forget_cache_2w();
+ }, 1209600000);
}
browser.storage.local.get(['lastU', 'lastV']).then(g => {
if (g.lastU) {
- if (Math.abs(Math.round((new Date()).getTime() / 1000) - g.lastU) > 604800) {
- browser.storage.local.get(['ign1', 'ign2', 'obs']).then(g => {
+ if (Math.abs(Math.round((new Date()).getTime() / 1000) - g.lastU) > 1209600) {
+ browser.storage.local.get(['ign1', 'ign2', 'obs', 'dbg']).then(g => {
browser.storage.local.clear();
browser.storage.local.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@@ -86,6 +89,9 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n')
});
+ browser.storage.local.set({
+ 'dbg': (g.dbg == 'y' ? 'y' : 'n')
+ });
browser.storage.local.set({
'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;
if (g.lastV != 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.set({
'ign1': (g.ign1 == 'y' ? 'y' : 'n')
@@ -110,6 +116,9 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
browser.storage.local.set({
'obs': (g.obs == 'y' ? 'y' : 'n')
});
+ browser.storage.local.set({
+ 'dbg': (g.dbg == 'y' ? 'y' : 'n')
+ });
browser.storage.local.set({
'lastU': Math.round((new Date()).getTime() / 1000)
});
@@ -119,8 +128,8 @@ browser.storage.local.get(['lastU', 'lastV']).then(g => {
});
}
setTimeout(function () {
- forget_cache_1w();
- }, 604800000);
+ forget_cache_2w();
+ }, 1209600000);
});
browser.runtime.onMessage.addListener((request, sender, sendResponse) => {
@@ -141,4 +150,5 @@ browser.runtime.onMessage.addListener((request, sender, sendResponse) => {
}
}, () => {});
}
+ return;
});
\ No newline at end of file
diff --git a/addon_firefox/ismitmlink/cfg.html b/addon_firefox/ismitmlink/cfg.html
index c8c9f9b..860980f 100644
--- a/addon_firefox/ismitmlink/cfg.html
+++ b/addon_firefox/ismitmlink/cfg.html
@@ -1,8 +1,17 @@
+
+
+
+
+
+ Informoj pri kaŝmemoro
+ Infektita:
+ Ne infektita:
+ Entute:
\ No newline at end of file
diff --git a/addon_firefox/ismitmlink/cs.js b/addon_firefox/ismitmlink/cs.js
index 534c090..0067955 100644
--- a/addon_firefox/ismitmlink/cs.js
+++ b/addon_firefox/ismitmlink/cs.js
@@ -1,9 +1,10 @@
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') {
- 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('ign2').checked = (g.ign2 == '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', () => {
browser.storage.local.set({
@@ -20,6 +21,34 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lw
'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 {
let cs = (function () {
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]: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'];
if (g.ign1 == 'y') {
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 running = false;
function scanme() {
- if (location.hostname == 'twitter.com') {
- document.querySelectorAll("a[href^='https://t.co/'][data-expanded-url^='http']").forEach(a => {
- a.href = a.dataset.expandedUrl;
- });
- }
- document.querySelectorAll(qstall).forEach(a => {
- 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)) {
- asked.push(aF);
- browser.runtime.sendMessage(aF);
+ if (!running) {
+ running = true;
+ if (location.hostname == 'twitter.com') {
+ document.querySelectorAll("a[href^='https://t.co/'][data-expanded-url^='http']").forEach(a => {
+ a.href = a.dataset.expandedUrl;
+ });
}
- });
+ let unknown = [];
+ document.querySelectorAll(qstall).forEach(a => {
+ let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || '';
+ if (!asked.includes(aF)) {
+ asked.push(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) => {
if (request.length == 2) {
+ if (g.dbg == 'y') {
+ console.log('isMITM:', request[0], request[1]);
+ }
document.querySelectorAll(qstall).forEach(a => {
let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || '';
if (aF == request[0]) {
@@ -70,12 +112,16 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lw
});
}
sendResponse(null);
+ return;
});
+ scanme();
if (g.obs == 'y') {
- (new MutationObserver(scanme)).observe(document, {
- attributes: true,
- childList: true,
- subtree: true
+ window.addEventListener('load', function () {
+ (new MutationObserver(scanme)).observe(document, {
+ attributes: true,
+ childList: true,
+ subtree: true
+ });
});
}
});
diff --git a/addon_firefox/ismitmlink/manifest.json b/addon_firefox/ismitmlink/manifest.json
index 550985f..f503ce2 100644
--- a/addon_firefox/ismitmlink/manifest.json
+++ b/addon_firefox/ismitmlink/manifest.json
@@ -1,8 +1,8 @@
{
"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",
- "version": "1.0.13",
+ "version": "1.0.14.1",
"homepage_url": "https://codeberg.org/crimeflare/cloudflare-tor",
"author": "Maslin Bossé",
"permissions": [