summaryrefslogtreecommitdiffstats
path: root/addon_firefox
diff options
context:
space:
mode:
authorsurveillanceeconomy <surveillance@eco.nomy>2019-05-29 12:06:51 +0000
committersurveillanceeconomy <surveillance@eco.nomy>2019-05-29 12:06:51 +0000
commit3bb801d058030697262872836738176f96e6b820 (patch)
tree4bb1d6949f64ddf79d925c7f7d249755d1fcbb2e /addon_firefox
parent200caeef6cd0b73cdaa9c1a12ce69c9f4cc4f56b (diff)
downloadcloudflare-tor-3bb801d058030697262872836738176f96e6b820.tar
cloudflare-tor-3bb801d058030697262872836738176f96e6b820.tar.gz
cloudflare-tor-3bb801d058030697262872836738176f96e6b820.tar.lz
cloudflare-tor-3bb801d058030697262872836738176f96e6b820.tar.xz
cloudflare-tor-3bb801d058030697262872836738176f96e6b820.zip
Upload files to 'addon_firefox/bcma'
Diffstat (limited to 'addon_firefox')
-rw-r--r--addon_firefox/bcma/anticloudflare.js56
-rw-r--r--addon_firefox/bcma/manifest.json2
-rw-r--r--addon_firefox/bcma/mydata.html8
-rw-r--r--addon_firefox/bcma/mydata.js19
-rw-r--r--addon_firefox/bcma/style.css3
5 files changed, 27 insertions, 61 deletions
diff --git a/addon_firefox/bcma/anticloudflare.js b/addon_firefox/bcma/anticloudflare.js
index 59c06e3a..09f272ac 100644
--- a/addon_firefox/bcma/anticloudflare.js
+++ b/addon_firefox/bcma/anticloudflare.js
@@ -1,22 +1,12 @@
/*
"Welcome to PRISM 2.0"
*/
-var cf_flag_ok = 'icons/cf_0.png';
-var cf_flag_ng = 'icons/cf_1.png';
-var force_whitelist = ['searxes.eu.org', 'thunderbird.net', 'mozilla.org', 'archive.org', 'cloudflare.com', 'cloudflareapps.com', 'cloudflare-dns.com', 'cloudflarestatus.com', 'cloudflareapi.com', 'cloudflare-ipfs.com', 'cloudflare-quic.com'];
-var cfdomains = [];
-var known_cf_domains = [];
-
-fetch('bcmadata.txt',{method:'GET'}).then(function (b) {
- return b.text();
-}).then(function (b) {
- cfdomains = b.split("\n").filter(v=>v!='');
- known_cf_domains = cfdomains;
-});
-
-var my_cf_collection = [];
-var my_cf_ignore = [];
-var my_action = 2;
+const cf_flag_ok = 'icons/cf_0.png';
+const cf_flag_ng = 'icons/cf_1.png';
+const force_whitelist = ['searxes.eu.org', 'thunderbird.net', 'mozilla.org', 'archive.org', 'cloudflare.com', 'cloudflareapps.com', 'cloudflare-dns.com', 'cloudflarestatus.com', 'cloudflareapi.com', 'cloudflare-ipfs.com', 'cloudflare-quic.com'];
+let my_cf_collection = [];
+let my_cf_ignore = [];
+let my_action = 2;
function onError(e) {
console.log(`BCMA: Error:${e}`);
@@ -603,8 +593,8 @@ function get_realdomain(w) {
}
function update_icon(tid, url) {
- var _nu = new URL(url);
- var cf_hostname = _nu.hostname;
+ let _nu = new URL(url);
+ let cf_hostname = _nu.hostname;
if ((_nu.protocol != 'http:' && _nu.protocol != 'https:') || cf_hostname.length < 1) {
browser.browserAction.setIcon({
tabId: tid,
@@ -620,17 +610,17 @@ function update_icon(tid, url) {
});
return;
}
- if (known_cf_domains.includes(cf_hostname) || my_cf_collection.includes(cf_hostname)) {
+ if (my_cf_collection.includes(cf_hostname)) {
if (my_action == 3) {
browser.tabs.executeScript(tid, {
matchAboutBlank: true,
runAt: 'document_end',
- code: "if (location.hostname=='%%CFHOST%%'||location.hostname.endsWith('.%%CFHOST%%')){if (!document.title.startsWith('[!!MITM!!]') && (typeof _bcma_bdr)=='undefined'){document.title='[!!MITM!!]'+document.title;function _bcma_bdr(){document.body.style = 'border:4px dashed #' + ['e74c3c', '9b59b6', '3498db', '17a589', '196f3d', 'f4d03f', 'f39c12', 'd35400'][Math.floor(Math.random() * 8)] + ' !important';setTimeout(_bcma_bdr,4860);};_bcma_bdr();}}".replace('%%CFHOST%%', cf_hostname).replace('%%CFHOST%%', cf_hostname)
+ code: "if (location.hostname=='%%CFHOST%%'||location.hostname.endsWith('.%%CFHOST%%')){if (!document.title.startsWith('[!!MITM!!]') && (typeof _bcma_bdr)=='undefined'){document.title='[!!MITM!!]'+document.title;function _bcma_bdr(){document.body.style = 'border:4px dashed #' + ['e74c3c', '9b59b6', '3498db', '17a589', '196f3d', 'f4d03f', 'f39c12', 'd35400'][Math.floor(Math.random() * 8)] + ' !important';setTimeout(_bcma_bdr,4900);};_bcma_bdr();}}".replace('%%CFHOST%%', cf_hostname).replace('%%CFHOST%%', cf_hostname)
});
browser.tabs.executeScript(tid, {
matchAboutBlank: true,
runAt: 'document_idle',
- code: "if (location.hostname=='%%CFHOST%%'||location.hostname.endsWith('.%%CFHOST%%')){if (!document.title.startsWith('[!!MITM!!]') && (typeof _bcma_bdr)=='undefined'){document.title='[!!MITM!!]'+document.title;function _bcma_bdr(){document.body.style = 'border:4px dashed #' + ['e74c3c', '9b59b6', '3498db', '17a589', '196f3d', 'f4d03f', 'f39c12', 'd35400'][Math.floor(Math.random() * 8)] + ' !important';setTimeout(_bcma_bdr,4860);};_bcma_bdr();}}".replace('%%CFHOST%%', cf_hostname).replace('%%CFHOST%%', cf_hostname)
+ code: "if (location.hostname=='%%CFHOST%%'||location.hostname.endsWith('.%%CFHOST%%')){if (!document.title.startsWith('[!!MITM!!]') && (typeof _bcma_bdr)=='undefined'){document.title='[!!MITM!!]'+document.title;function _bcma_bdr(){document.body.style = 'border:4px dashed #' + ['e74c3c', '9b59b6', '3498db', '17a589', '196f3d', 'f4d03f', 'f39c12', 'd35400'][Math.floor(Math.random() * 8)] + ' !important';setTimeout(_bcma_bdr,4900);};_bcma_bdr();}}".replace('%%CFHOST%%', cf_hostname).replace('%%CFHOST%%', cf_hostname)
});
}
browser.browserAction.setIcon({
@@ -678,11 +668,11 @@ browser.webRequest.onHeadersReceived.addListener(function (wr) {
if (force_whitelist.includes(wr_hostname)) {
return;
}
- var cf_is = (known_cf_domains.includes(wr_hostname) || my_cf_collection.includes(wr_hostname)) ? true : false;
+ var cf_is = (my_cf_collection.includes(wr_hostname)) ? true : false;
if (!cf_is) {
var cf_headers = wr.responseHeaders,
cf_v_name, cf_v_value;
- for (var i = 0; i < cf_headers.length; i++) {
+ for (let i = 0; i < cf_headers.length; i++) {
cf_v_name = cf_headers[i]['name'].toLowerCase();
cf_v_value = (cf_headers[i]['value'] != undefined) ? cf_headers[i]['value'].toLowerCase() : '';
if (cf_v_name == 'server' && cf_v_value.includes('cloudflare')) {
@@ -702,6 +692,10 @@ browser.webRequest.onHeadersReceived.addListener(function (wr) {
if (cf_is) {
if (my_cf_collection.length > 500) {
my_cf_collection.shift();
+ my_cf_collection.shift();
+ my_cf_collection.shift();
+ my_cf_collection.shift();
+ my_cf_collection.shift();
}
if (!my_cf_collection.includes(wr_hostname)) {
my_cf_collection.push(wr_hostname);
@@ -720,7 +714,7 @@ browser.webRequest.onHeadersReceived.addListener(function (wr) {
}
if (my_action == 2) {
return {
- redirectUrl: 'https://web.archive.org/web/' + wr.url.split('?')[0]
+ redirectUrl: 'https://web.archive.org/web/' + wr.url
};
}
}
@@ -761,7 +755,7 @@ browser.webRequest.onBeforeRequest.addListener(function (wr) {
if (force_whitelist.includes(wr_hostname)) {
return;
}
- var cf_is = (known_cf_domains.includes(wr_hostname) || my_cf_collection.includes(wr_hostname)) ? true : false;
+ var cf_is = (my_cf_collection.includes(wr_hostname)) ? true : false;
if (cf_is) {
console.log('BCMA: Block Cloudflare BR', wr_hostname);
if (my_action == 0 || my_action == 1) {
@@ -777,7 +771,7 @@ browser.webRequest.onBeforeRequest.addListener(function (wr) {
}
if (my_action == 2) {
return {
- redirectUrl: 'https://web.archive.org/web/' + wr.url.split('?')[0]
+ redirectUrl: 'https://web.archive.org/web/' + wr.url
};
}
}
@@ -788,20 +782,12 @@ browser.webRequest.onBeforeRequest.addListener(function (wr) {
browser.runtime.onMessage.addListener(function (a, b, c) {
if (a[0] == 'cf') {
- c(['ok', JSON.stringify(my_cf_collection), JSON.stringify(my_cf_ignore), (known_cf_domains.length == 0) ? false : true, my_action]);
+ c(['ok', JSON.stringify(my_cf_collection), JSON.stringify(my_cf_ignore), my_action]);
}
if (a[0] == 'erosman') {
my_cf_collection = [];
c(['destroy']);
}
- if (a[0] == 'bi') {
- if (a[1] == 'y') {
- known_cf_domains = cfdomains;
- } else {
- known_cf_domains = [];
- }
- c(['ok']);
- }
if (a[0] == 'ta') {
if (a[1] == '0') {
my_action = 0;
diff --git a/addon_firefox/bcma/manifest.json b/addon_firefox/bcma/manifest.json
index 9f16c623..8762027b 100644
--- a/addon_firefox/bcma/manifest.json
+++ b/addon_firefox/bcma/manifest.json
@@ -2,7 +2,7 @@
"manifest_version": 2,
"name": "Block Cloudflare MITM Attack",
"description": "Submit to global surveillance or resist. The choice is yours.",
- "version": "1.0.1905.1",
+ "version": "1.0.1906.1",
"author": "Project BCMA",
"homepage_url": "https://trac.torproject.org/projects/tor/ticket/24351",
"permissions": [
diff --git a/addon_firefox/bcma/mydata.html b/addon_firefox/bcma/mydata.html
index 1894e2b5..060db731 100644
--- a/addon_firefox/bcma/mydata.html
+++ b/addon_firefox/bcma/mydata.html
@@ -4,12 +4,8 @@
<link rel="stylesheet" href="style.css">
</head>
<body style="display:none">
- Temporary configurations
+ <i>Temporary</i> configurations
<hr>
- <b>&#9758; Built-in Cloudflare list (.com only)</b> <small>(powered by <a href="https://searxes.danwin1210.me/" target="_blank">Searxes</a>)</small><br>
- <label><input type="radio" id="bi0" name="bi" value="0"> Use built-in list</label> <small>(Default)</small><br>
- <label><input type="radio" id="bi1" name="bi" value="1"> Don't use built-in list</label><br>
- <br>
<b>&#9822; Take Action</b><br>
<label><input type="radio" id="ta0" name="ta" value="0"> Block request immediately <small>(first-party + third-party)</small></label><br>
<label><input type="radio" id="ta1" name="ta" value="1"> Block request immediately <small>(third-party only / ignore first-party)</small></label><br>
@@ -17,7 +13,7 @@
<label><input type="radio" id="ta3" name="ta" value="3"> Notify only</label><br>
<br>
<b>&#9997; Your Cloudflare Domain collection</b> <small>(Last 500)</small><br>
- <small>(please share with <a href="https://notabug.org/themusicgod1/cloudflare-tor/" target="_blank">cloudflare-tor@notabug</a>)</small><br>
+ <small>(please share with <a href="https://notabug.org/crimeflare/cloudflare-tor/" target="_blank">cloudflare-tor@crimeflare</a>)</small><br>
<textarea cols="50" rows="12" id="t" wrap="off" spellcheck="false" placeholder="Cloudflare domains"></textarea>
<br>
<button type="button" id="exp">[ &#8659; Export ]</button>
diff --git a/addon_firefox/bcma/mydata.js b/addon_firefox/bcma/mydata.js
index cc255e7e..f39e3622 100644
--- a/addon_firefox/bcma/mydata.js
+++ b/addon_firefox/bcma/mydata.js
@@ -7,14 +7,7 @@ document.addEventListener('DOMContentLoaded', function () {
if (r[0] == 'ok') {
document.getElementById('t').value = JSON.parse(r[1]).join("\n");
document.getElementById('g').value = JSON.parse(r[2]).join("\n");
- if (r[3]) {
- document.getElementById('bi0').checked = true;
- document.getElementById('bi1').checked = false;
- } else {
- document.getElementById('bi0').checked = false;
- document.getElementById('bi1').checked = true;
- }
- switch (r[4]) {
+ switch (r[3]) {
case 1:
document.getElementById('ta0').checked = false;
document.getElementById('ta1').checked = true;
@@ -67,16 +60,6 @@ document.getElementById('clr').addEventListener('click', function () {
document.getElementById('t').value = '';
}, onError);
});
-document.getElementById('bi0').addEventListener('click', function () {
- if (this.checked) {
- browser.runtime.sendMessage(['bi', 'y']).then(function (r) {}, onError);
- }
-});
-document.getElementById('bi1').addEventListener('click', function () {
- if (this.checked) {
- browser.runtime.sendMessage(['bi', 'n']).then(function (r) {}, onError);
- }
-});
document.getElementById('ta0').addEventListener('click', function () {
if (this.checked) {
browser.runtime.sendMessage(['ta', '0']).then(function (r) {}, onError);
diff --git a/addon_firefox/bcma/style.css b/addon_firefox/bcma/style.css
index 31782bd2..e66a29e9 100644
--- a/addon_firefox/bcma/style.css
+++ b/addon_firefox/bcma/style.css
@@ -13,7 +13,8 @@ button {
border: 0;
overflow: hidden;
outline: none;
- outline-style: none
+ outline-style: none;
+ cursor: pointer
}
body {