[or-cvs] [torbutton/master 05/47] Bug 1033 - Update Torbutton only over Tor.
mikeperry at torproject.org
mikeperry at torproject.org
Thu Sep 30 16:20:13 UTC 2010
Author: Mike Perry <mikeperry-git at fscked.org>
Date: Wed, 17 Mar 2010 21:25:43 -0700
Subject: Bug 1033 - Update Torbutton only over Tor.
Commit: 84d978ecd55f1d7621f44bd5069e46eb89d5a3a4
Still needs the UI portion.
---
src/chrome/content/torbutton.js | 71 +++++++++++++++++++++++++++++--
src/defaults/preferences/preferences.js | 1 +
2 files changed, 68 insertions(+), 4 deletions(-)
diff --git a/src/chrome/content/torbutton.js b/src/chrome/content/torbutton.js
index b4b141d..7f07f16 100644
--- a/src/chrome/content/torbutton.js
+++ b/src/chrome/content/torbutton.js
@@ -2867,6 +2867,69 @@ var torbutton_proxyservice = {
if (m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
if (uri.host == "localhost") return null;
}
+
+ if (!m_tb_prefs.getBoolPref("extensions.torbutton.settings_applied")) {
+ if (m_tb_prefs.getBoolPref("extensions.torbutton.update_torbutton_via_tor")) {
+ var path = new String(uri.path);
+ var update_proxy = proxy;
+ if (uri.host == "versioncheck.addons.mozilla.org") {
+ if (path.indexOf("{e0204bd5-9d31-402b-a99d-a6aa8ffebdca}") != -1) {
+ // https_proxy, https_port
+ var https_proxy=m_tb_prefs.getCharPref("extensions.torbutton.https_proxy");
+ var https_port=m_tb_prefs.getIntPref("extensions.torbutton.https_port");
+ if (!https_proxy || !https_port) {
+ var socks_host=m_tb_prefs.getCharPref("extensions.torbutton.socks_host");
+ var socks_port=m_tb_prefs.getIntPref("extensions.torbutton.socks_port");
+ var socks_version=m_tb_prefs.getIntPref("extensions.torbutton.socks_version");
+ var flag = 0;
+ if (!socks_host || !socks_port)
+ return proxy;
+ if (m_tb_prefs.getBoolPref("network.proxy.socks_remote_dns"))
+ flag = Ci.nsIProxyInfo.TRANSPARENT_PROXY_RESOLVES_HOST;
+ if (socks_version == 4) {
+ update_proxy = this._proxyservice.newProxyInfo("socks4", socks_proxy, socks_port,
+ flag, 0x7ffffffe, null);
+ } else {
+ update_proxy = this._proxyservice.newProxyInfo("socks", socks_proxy, socks_port,
+ flag, 0x7ffffffe, null);
+ }
+ } else {
+ update_proxy = this._proxyservice.newProxyInfo("http", https_proxy, https_port,
+ Ci.nsIProxyInfo.TRANSPARENT_PROXY_RESOLVES_HOST, 0x7ffffffe, null);
+ }
+ }
+ } else if (uri.host == "releases.mozilla.org") {
+ if (path.indexOf("/pub/mozilla.org/addons/2275/") == 0) {
+ var http_proxy=m_tb_prefs.getCharPref("extensions.torbutton.http_proxy");
+ var http_port=m_tb_prefs.getIntPref("extensions.torbutton.http_port");
+ if (!http_proxy || !http_port) {
+ var socks_host=m_tb_prefs.getCharPref("extensions.torbutton.socks_host");
+ var socks_port=m_tb_prefs.getIntPref("extensions.torbutton.socks_port");
+ var socks_version=m_tb_prefs.getIntPref("extensions.torbutton.socks_version");
+ var flag = 0;
+ if (!socks_host || !socks_port)
+ return proxy;
+ if (m_tb_prefs.getBoolPref("network.proxy.socks_remote_dns"))
+ flag = Ci.nsIProxyInfo.TRANSPARENT_PROXY_RESOLVES_HOST;
+ if (socks_version == 4) {
+ update_proxy = this._proxyservice.newProxyInfo("socks4", socks_proxy, socks_port,
+ flag, 0x7ffffffe, null);
+ } else {
+ update_proxy = this._proxyservice.newProxyInfo("socks", socks_proxy, socks_port,
+ flag, 0x7ffffffe, null);
+ }
+ } else {
+ update_proxy = this._proxyservice.newProxyInfo("http", http_proxy, http_port,
+ Ci.nsIProxyInfo.TRANSPARENT_PROXY_RESOLVES_HOST, 0x7ffffffe, null);
+ }
+ }
+ }
+ if (update_proxy != proxy)
+ torbutton_log(3, "Performing Torbutton update check via Tor proxy for: "+
+ uri.spec);
+ return update_proxy;
+ }
+ }
return proxy;
}
catch (e) {
@@ -2876,9 +2939,9 @@ var torbutton_proxyservice = {
register : function() {
torbutton_eclog(3, 'Proxy filter Registering...');
try {
- var proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
+ this._proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
.getService(Components.interfaces.nsIProtocolProxyService);
- proxyservice.registerFilter(this, 0);
+ this._proxyservice.registerFilter(this, 0);
} catch (e) {
torbutton_eclog(3, 'RegisterFilter failed:'+e);
}
@@ -2886,9 +2949,9 @@ var torbutton_proxyservice = {
unregister : function() {
torbutton_eclog(3, 'Proxy filter Unregistering...');
try {
- var proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
+ this._proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
.getService(Components.interfaces.nsIProtocolProxyService);
- proxyservice.unregisterFilter(this);
+ this._proxyservice.unregisterFilter(this);
} catch (e) {
torbutton_eclog(3, 'UnregisterFilter failed:'+e);
}
diff --git a/src/defaults/preferences/preferences.js b/src/defaults/preferences/preferences.js
index 9885905..b7f19a3 100644
--- a/src/defaults/preferences/preferences.js
+++ b/src/defaults/preferences/preferences.js
@@ -153,6 +153,7 @@ pref("extensions.torbutton.nontor_memory_jar",false);
pref("extensions.torbutton.tz_string","");
pref("extensions.torbutton.launch_warning",true);
pref("extensions.torbutton.disable_livemarks",true);
+pref("extensions.torbutton.update_torbutton_via_tor",true);
// Google Captcha prefs
// FIXME: NID cookie?
--
1.7.1
More information about the tor-commits
mailing list