From b198040285f4ced4aa96b0e680e58ee3b08e166f Mon Sep 17 00:00:00 2001 From: imnotarobot Date: Sun, 11 Aug 2019 05:48:46 +0200 Subject: [PATCH] Upload files to 'addon_chrome/ismitmlink' --- addon_chrome/ismitmlink/bg.js | 71 +++++++++++----- addon_chrome/ismitmlink/cfg.html | 11 +++ addon_chrome/ismitmlink/cs.js | 116 ++++++++++++++++++-------- addon_chrome/ismitmlink/manifest.json | 6 +- 4 files changed, 147 insertions(+), 57 deletions(-) create mode 100644 addon_chrome/ismitmlink/cfg.html diff --git a/addon_chrome/ismitmlink/bg.js b/addon_chrome/ismitmlink/bg.js index 41588aef0..0a76ff5a9 100644 --- a/addon_chrome/ismitmlink/bg.js +++ b/addon_chrome/ismitmlink/bg.js @@ -46,25 +46,47 @@ function i_already_know_you(f) { }); } -function clear_cache_1w() { - chrome.storage.local.clear(); - chrome.storage.local.set({ - 'lastU': Math.round((new Date()).getTime() / 1000) - }); - chrome.storage.local.set({ - 'lastV': (chrome.runtime.getManifest()).version +function forget_cache_1w() { + chrome.storage.local.get(['ign1', 'ign2', 'obs'], (g) => { + chrome.storage.local.clear(); + chrome.storage.local.set({ + 'ign1': (g.ign1 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'ign2': (g.ign2 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'obs': (g.obs == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'lastU': Math.round((new Date()).getTime() / 1000) + }); + chrome.storage.local.set({ + 'lastV': (chrome.runtime.getManifest()).version + }); }); setTimeout(function () { - clear_cache_1w(); + forget_cache_1w(); }, 604800000); } chrome.storage.local.get(['lastU', 'lastV'], (g) => { if (g.lastU) { if (Math.abs(Math.round((new Date()).getTime() / 1000) - g.lastU) > 604800) { - chrome.storage.local.clear(); - chrome.storage.local.set({ - 'lastU': Math.round((new Date()).getTime() / 1000) + chrome.storage.local.get(['ign1', 'ign2', 'obs'], (g) => { + chrome.storage.local.clear(); + chrome.storage.local.set({ + 'ign1': (g.ign1 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'ign2': (g.ign2 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'obs': (g.obs == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'lastU': Math.round((new Date()).getTime() / 1000) + }); }); } } else { @@ -74,21 +96,32 @@ chrome.storage.local.get(['lastU', 'lastV'], (g) => { } let nowVer = (chrome.runtime.getManifest()).version; if (g.lastV != nowVer) { - chrome.storage.local.clear(); - chrome.storage.local.set({ - 'lastU': Math.round((new Date()).getTime() / 1000) - }); - chrome.storage.local.set({ - 'lastV': nowVer + chrome.storage.local.get(['ign1', 'ign2', 'obs'], (g) => { + chrome.storage.local.clear(); + chrome.storage.local.set({ + 'ign1': (g.ign1 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'ign2': (g.ign2 == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'obs': (g.obs == 'y' ? 'y' : 'n') + }); + chrome.storage.local.set({ + 'lastU': Math.round((new Date()).getTime() / 1000) + }); + chrome.storage.local.set({ + 'lastV': (chrome.runtime.getManifest()).version + }); }); } setTimeout(function () { - clear_cache_1w(); + forget_cache_1w(); }, 604800000); }); chrome.runtime.onMessage.addListener((request, sender, sendResponse) => { - if (request) { + if (request && sender) { i_already_know_you(request).then((r) => { if (r == 1 || r == -1) { chrome.tabs.sendMessage(sender.tab.id, [request, ((r == 1) ? true : false)]); diff --git a/addon_chrome/ismitmlink/cfg.html b/addon_chrome/ismitmlink/cfg.html new file mode 100644 index 000000000..98f1e0174 --- /dev/null +++ b/addon_chrome/ismitmlink/cfg.html @@ -0,0 +1,11 @@ + + + + + +
+
+
+ + + \ No newline at end of file diff --git a/addon_chrome/ismitmlink/cs.js b/addon_chrome/ismitmlink/cs.js index 4d40a1d3d..2cdf0736d 100644 --- a/addon_chrome/ismitmlink/cs.js +++ b/addon_chrome/ismitmlink/cs.js @@ -1,41 +1,83 @@ if (document.body && !['searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org'].includes(location.hostname)) { - let cs = (function () { - let s = document.createElement('style'); - document.head.appendChild(s); - return s.sheet; - })(); - if (cs) { - cs.insertRule("a[data-mitm=y]{cursor:not-allowed !important;text-decoration-line:line-through !important;text-decoration-color:red !important;text-decoration-style:double !important}", 0); - cs.insertRule("a[data-mitm=y]::before{content:'[\\26A0]';font-weight:bold !important;color:red !important;display:inline-block !important}", 1); - cs.insertRule("a[data-mitm=y]:hover::before{content:'[\\26A1]'}", 2); - cs.insertRule("a[data-mitm=y]:hover{color:red !important}", 3); - 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); - } - - let asked = ['', 'searxes.nmqnkngye4ct7bgss4bmv5ca3wpa55yugvxen5kz2bbq67lwy6ps54yd.onion', 'searxes.eu.org', 'api.searxes.eu.org', 'addons.mozilla.org', 'addons.thunderbird.net', 'web.archive.org']; - document.querySelectorAll('a[href]:not([data-mitm]),img[src]:not([data-mitm])').forEach(a => { - let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || ''; - 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) && !asked.includes(aF)) { - asked.push(aF); - chrome.runtime.sendMessage(aF); - } - }); - - chrome.runtime.onMessage.addListener((request, sender, sendResponse) => { - if (request.length == 2) { - document.querySelectorAll('a[href]:not([data-mitm]),img[src]:not([data-mitm])').forEach(a => { - let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || ''; - if (aF == request[0]) { - if (request[1]) { - a.dataset.mitm = 'y'; - a.title = 'MITM!'; - } else { - a.dataset.mitm = 'n'; - } - } + if (location.protocol === 'chrome-extension:') { + chrome.storage.local.get(['ign1', 'ign2', 'obs'], (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('ign1').addEventListener('click', () => { + chrome.storage.local.set({ + 'ign1': (document.getElementById('ign1').checked ? 'y' : 'n') }); + }); + document.getElementById('ign2').addEventListener('click', () => { + chrome.storage.local.set({ + 'ign2': (document.getElementById('ign2').checked ? 'y' : 'n') + }); + }); + document.getElementById('obs').addEventListener('click', () => { + chrome.storage.local.set({ + 'obs': (document.getElementById('obs').checked ? 'y' : 'n') + }); + }); + } else { + let cs = (function () { + let s = document.createElement('style'); + document.head.appendChild(s); + return s.sheet; + })(); + if (cs) { + cs.insertRule("a[data-mitm=y]{cursor:not-allowed !important;text-decoration-line:line-through !important;text-decoration-color:red !important;text-decoration-style:double !important}", 0); + cs.insertRule("a[data-mitm=y]::before{content:'[\\26A0]';font-weight:bold !important;color:red !important;display:inline-block !important}", 1); + cs.insertRule("a[data-mitm=y]:hover::before{content:'[\\26A1]'}", 2); + cs.insertRule("a[data-mitm=y]:hover{color:red !important}", 3); + 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); } - sendResponse(null); - }); + chrome.storage.local.get(['ign1', 'ign2', 'obs'], (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])'; + 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); + chrome.runtime.sendMessage(aF); + } + }); + } + scanme(); + chrome.runtime.onMessage.addListener((request, sender, sendResponse) => { + if (request.length == 2) { + document.querySelectorAll(qstall).forEach(a => { + let aF = (a.tagName == 'A' ? (new URL(a.href)).hostname : (new URL(a.src)).hostname) || ''; + if (aF == request[0]) { + if (request[1]) { + a.dataset.mitm = 'y'; + a.title = 'MITM!'; + } else { + a.dataset.mitm = 'n'; + } + } + }); + } + sendResponse(null); + }); + if (g.obs == 'y') { + (new MutationObserver(scanme)).observe(document, { + attributes: true, + childList: true, + subtree: true + }); + } + }); + } } \ No newline at end of file diff --git a/addon_chrome/ismitmlink/manifest.json b/addon_chrome/ismitmlink/manifest.json index bd9888aee..b2b4e7ef7 100644 --- a/addon_chrome/ismitmlink/manifest.json +++ b/addon_chrome/ismitmlink/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, "name": "Are links vulnerable to MITM attack?", - "version": "1.0.12", + "version": "1.0.13", "minimum_chrome_version": "60", "homepage_url": "https://codeberg.org/crimeflare/cloudflare-tor", "author": "Maslin Bossé", @@ -18,6 +18,10 @@ "bg.js" ] }, + "options_ui": { + "chrome_style": false, + "page": "cfg.html" + }, "content_scripts": [ { "matches": [