Import 1.0.8 from a.m.o. Closes #7.

This commit is contained in:
nullius 2017-12-30 22:03:16 +00:00
parent ce7503453c
commit d675c90d2b
No known key found for this signature in database
GPG Key ID: C42793159F9EF949
3 changed files with 11 additions and 11 deletions

View File

@ -2,7 +2,7 @@
"manifest_version": 2, "manifest_version": 2,
"name": "Block Cloudflare MiTM Attack", "name": "Block Cloudflare MiTM Attack",
"description": "If the destination website use Cloudflare, block further request.", "description": "If the destination website use Cloudflare, block further request.",
"version": "1.0.7.1", "version": "1.0.8",
"homepage_url": "https://trac.torproject.org/projects/tor/ticket/24351", "homepage_url": "https://trac.torproject.org/projects/tor/ticket/24351",
"permissions": ["webRequest","webRequestBlocking","<all_urls>","storage","activeTab"], "permissions": ["webRequest","webRequestBlocking","<all_urls>","storage","activeTab"],
"options_ui": { "options_ui": {

View File

@ -1,3 +1,4 @@
function onError(e){console.log(`CFMITM_CFG Error:${e}`);}
function saveWhitelist(e){ function saveWhitelist(e){
e.preventDefault(); e.preventDefault();
//WHITELIST //WHITELIST
@ -23,6 +24,7 @@ if (document.querySelector("#myset_xsucuri").checked){browser.storage.local.set(
if (document.querySelector("#myset_xignhttp").checked){browser.storage.local.set({myset_xignhttp: "y"});}else{browser.storage.local.set({myset_xignhttp: "n"});} if (document.querySelector("#myset_xignhttp").checked){browser.storage.local.set({myset_xignhttp: "y"});}else{browser.storage.local.set({myset_xignhttp: "n"});}
if (document.querySelector("#myset_xigncj").checked){browser.storage.local.set({myset_xigncj: "y"});}else{browser.storage.local.set({myset_xigncj: "n"});} if (document.querySelector("#myset_xigncj").checked){browser.storage.local.set({myset_xigncj: "y"});}else{browser.storage.local.set({myset_xigncj: "n"});}
if (document.querySelector("#myset_xsimplewarn").checked){browser.storage.local.set({myset_xsimplewarn: "y"});}else{browser.storage.local.set({myset_xsimplewarn: "n"});} if (document.querySelector("#myset_xsimplewarn").checked){browser.storage.local.set({myset_xsimplewarn: "y"});}else{browser.storage.local.set({myset_xsimplewarn: "n"});}
browser.runtime.sendMessage({relnow:'go'}).then(function(r){},onError);
} }
function loadWhitelist(){ function loadWhitelist(){
function setCurrentChoice(r){ function setCurrentChoice(r){
@ -36,7 +38,6 @@ if (r.myset_xignhttp=='y'){document.querySelector("#myset_xignhttp").checked=tru
if (r.myset_xigncj=='y'){document.querySelector("#myset_xigncj").checked=true;}else{document.querySelector("#myset_xigncj").checked=false;} if (r.myset_xigncj=='y'){document.querySelector("#myset_xigncj").checked=true;}else{document.querySelector("#myset_xigncj").checked=false;}
if (r.myset_xsimplewarn=='y'){document.querySelector("#myset_xsimplewarn").checked=true;}else{document.querySelector("#myset_xsimplewarn").checked=false;} if (r.myset_xsimplewarn=='y'){document.querySelector("#myset_xsimplewarn").checked=true;}else{document.querySelector("#myset_xsimplewarn").checked=false;}
} }
function onError(e){console.log(`CFMITM_CFG Error:${e}`);}
var getting=browser.storage.local.get(); var getting=browser.storage.local.get();
getting.then(setCurrentChoice, onError); getting.then(setCurrentChoice, onError);
} }

View File

@ -6,6 +6,7 @@
* http://www.crimeflare.com/ * http://www.crimeflare.com/
*/ */
var cfaddon_isdone=0;
var cf_ignore=[]; var cf_ignore=[];
var cf_history=[];//used by whitelist-from-warnpage var cf_history=[];//used by whitelist-from-warnpage
var stop_incapsula=0; var stop_incapsula=0;
@ -15,13 +16,11 @@ var ign_phttp=0;
var ign_rescj=0; var ign_rescj=0;
var do_simplewarn=0; var do_simplewarn=0;
function whitelist_reload(w){ function whitelist_reload(){browser.storage.local.get().then(function(w){
//WHITELIST //WHITELIST
if (w.myset_cfwhite){ if (w.myset_cfwhite){
var tmp_whitelist=w.myset_cfwhite; var tmp_whitelist=w.myset_cfwhite;tmp_whitelist=tmp_whitelist.split("\n").filter(v=>v!='');
tmp_whitelist=tmp_whitelist.split("\n").filter(v=>v!='');
cf_ignore=tmp_whitelist; cf_ignore=tmp_whitelist;
//console.log(cf_ignore);
}else{cf_ignore=[];} }else{cf_ignore=[];}
//ADVANCED //ADVANCED
if (w.myset_xincapsula=='y'){stop_incapsula=1;}else{stop_incapsula=0;} if (w.myset_xincapsula=='y'){stop_incapsula=1;}else{stop_incapsula=0;}
@ -30,12 +29,13 @@ if (w.myset_xsucuri=='y'){stop_sucuri=1;}else{stop_sucuri=0;}
if (w.myset_xignhttp=='y'){ign_phttp=1;}else{ign_phttp=0;} if (w.myset_xignhttp=='y'){ign_phttp=1;}else{ign_phttp=0;}
if (w.myset_xigncj=='y'){ign_rescj=1;}else{ign_rescj=0;} if (w.myset_xigncj=='y'){ign_rescj=1;}else{ign_rescj=0;}
if (w.myset_xsimplewarn=='y'){do_simplewarn=1;}else{do_simplewarn=0;} if (w.myset_xsimplewarn=='y'){do_simplewarn=1;}else{do_simplewarn=0;}
} },onError);}
function onError(e){console.log(`CFMITM Error:${e}`);} function onError(e){console.log(`CFMITM Error:${e}`);}
function analyzemydata(res){ function analyzemydata(res){
var lmcfg=browser.storage.local.get();lmcfg.then(whitelist_reload,onError);// load latest settings without restarting a browser if (cfaddon_isdone==0){cfaddon_isdone=1;whitelist_reload();}
if (ign_rescj==1){if (/^http(.*)\.(js|css|jpg|jpeg|gif|png|tif|ico|svg|woff|woff2|ttf|cur|ani)(|\?(.*))$/.test(res.url)||['image','stylesheet'].includes(res.type)){return;}}
//console.log("CFMITM: scanning: "+res.url); //console.log("CFMITM: scanning: "+res.url);
var cflink = document.createElement('a'); var cflink = document.createElement('a');
@ -53,8 +53,6 @@ if (stop_sucuri==1){if (cf_hostname.endsWith('.sucuri.net')||cf_hostname=='sucur
//whitelisted //whitelisted
if (cf_ignore.includes(cf_hostname)){return;} if (cf_ignore.includes(cf_hostname)){return;}
if (cf_protocol=='http:' && ign_phttp==1){return;} if (cf_protocol=='http:' && ign_phttp==1){return;}
if (ign_rescj==1 && /^http(.*)\.(js|css|jpg|jpeg|gif|png|tif|ico|svg|woff|woff2|ttf|cur|ani)(|\?(.*))$/.test(res.url)){return;}
if ((cf_protocol == 'http:' || cf_protocol == 'https:') && cf_hostname.length >= 4) { if ((cf_protocol == 'http:' || cf_protocol == 'https:') && cf_hostname.length >= 4) {
@ -150,4 +148,5 @@ return {cancel: true};
browser.webRequest.onHeadersReceived.addListener(analyzemydata,{urls:["http://*/*","https://*/*"]},["blocking","responseHeaders"]); browser.webRequest.onHeadersReceived.addListener(analyzemydata,{urls:["http://*/*","https://*/*"]},["blocking","responseHeaders"]);
browser.webRequest.onBeforeRequest.addListener(gotwhitelistrequest,{urls:["https://0.0.0.0/cfmitm_addon/*"]},["blocking"]); browser.webRequest.onBeforeRequest.addListener(gotwhitelistrequest,{urls:["https://0.0.0.0/cfmitm_addon/*"]},["blocking"]);
browser.runtime.onMessage.addListener(function(r,s,sr){if (r.relnow!=undefined){whitelist_reload();sr({response: 'ok'});};return true;});
browser.browserAction.onClicked.addListener(function(t){browser.runtime.openOptionsPage().then(function(){},onError);}); browser.browserAction.onClicked.addListener(function(t){browser.runtime.openOptionsPage().then(function(){},onError);});