[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r20181: {torbutton} Create a protocol proxy filter to allow "localhost" to bypas (torbutton/trunk/src/chrome/content)



Author: mikeperry
Date: 2009-07-28 15:49:04 -0400 (Tue, 28 Jul 2009)
New Revision: 20181

Modified:
   torbutton/trunk/src/chrome/content/torbutton.js
Log:

Create a protocol proxy filter to allow "localhost" to bypass
the proxy as opposed to using Firefox's logic. Based on patch
from optimist.



Modified: torbutton/trunk/src/chrome/content/torbutton.js
===================================================================
--- torbutton/trunk/src/chrome/content/torbutton.js	2009-07-28 06:32:58 UTC (rev 20180)
+++ torbutton/trunk/src/chrome/content/torbutton.js	2009-07-28 19:49:04 UTC (rev 20181)
@@ -2246,6 +2246,40 @@
 }
 }
 
+var torbutton_proxyservice = {
+  applyFilter : function(ps, uri, proxy) {
+    try {
+      torbutton_eclog(3, 'apply: '+uri.host+' '+uri.scheme+', '+proxy);
+      if (m_tb_prefs.getBoolPref("extensions.torbutton.tor_enabled")) {
+        if (uri.host == "localhost") return null;
+      }
+      return proxy;
+    }
+    catch (e) {
+      torbutton_eclog(3, 'applyFilter failed:' +e);
+    }
+  },
+  register : function() {
+    torbutton_eclog(3, 'Proxy filter Registering...');
+    try {
+    var proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
+      .getService(Components.interfaces.nsIProtocolProxyService);
+    proxyservice.registerFilter(this, 0);
+    } catch (e) {
+      torbutton_eclog(3, 'RegisterFilter failed:'+e);
+    }
+  },
+  unregister : function() {
+    torbutton_eclog(3, 'Proxy filter Unregistering...');
+    try {
+    var proxyservice = Components.classes["@mozilla.org/network/protocol-proxy-service;1"]
+      .getService(Components.interfaces.nsIProtocolProxyService);
+    proxyservice.unregisterFilter(this, 0);
+    } catch (e) {
+      torbutton_eclog(3, 'UnregisterFilter failed:'+e);
+    }
+  }
+}
 
 function torbutton_do_main_window_startup()
 {
@@ -2266,6 +2300,7 @@
     torbutton_unique_pref_observer.register();
     torbutton_uninstall_observer.register();
     torbutton_http_observer.register();
+    torbutton_proxyservice.register();
 }
 
 function torbutton_set_initial_state() {
@@ -2529,6 +2564,7 @@
         torbutton_unique_pref_observer.unregister();
         torbutton_uninstall_observer.unregister();
         torbutton_http_observer.unregister();
+        torbutton_proxyservice.unregister();
 
         if(m_tb_is_main_window) { // main window not reset above
             // This happens on Mac OS because they allow firefox