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

[or-cvs] r13860: Woah, that truck came at us from a totally different directi (in torbutton/trunk/src: chrome/content components)



Author: mikeperry
Date: 2008-03-04 14:40:58 -0500 (Tue, 04 Mar 2008)
New Revision: 13860

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

Woah, that truck came at us from a totally different
direction. And is masqueraded as a jeep! We need a bandaid
over here too.



Modified: torbutton/trunk/src/chrome/content/torbutton.js
===================================================================
--- torbutton/trunk/src/chrome/content/torbutton.js	2008-03-04 18:01:59 UTC (rev 13859)
+++ torbutton/trunk/src/chrome/content/torbutton.js	2008-03-04 19:40:58 UTC (rev 13860)
@@ -1539,7 +1539,7 @@
     }
 
     torbutton_log(2, "Hooking document: "+win.location);
-    if(doc.doctype) {
+    if(doc && doc.doctype) {
         torbutton_log(2, "Type: "+doc.doctype.name);
     }
     
@@ -1568,7 +1568,6 @@
     str2 += "window.__tb_oscpu=\""+m_tb_prefs.getCharPref('extensions.torbutton.oscpu_override')+"\";\r\n";
     str2 += "window.__tb_platform=\""+m_tb_prefs.getCharPref('extensions.torbutton.platform_override')+"\";\r\n";
     str2 += "window.__tb_productSub=\""+m_tb_prefs.getCharPref('extensions.torbutton.productsub_override')+"\";\r\n";
-    str2 += "window.__tb_block_js_history="+m_tb_prefs.getBoolPref('extensions.torbutton.block_js_history')+";\r\n";
     str2 += m_tb_jshooks;
 
     try {
@@ -1582,11 +1581,11 @@
         } else if(result === 13) {
             torbutton_log(3, "Double-hook at: " + win.location);
         } else {
-            win.alert("Sandbox evaluation failed. Date hooks not applied!");
+            window.alert("Sandbox evaluation failed. Date hooks not applied!");
             torbutton_log(5, "Hook evaluation failure at " + win.location);
         }
     } catch (e) {
-        win.alert("Exception in sandbox evaluation. Date hooks not applied:\n"+e);
+        window.alert("Exception in sandbox evaluation. Date hooks not applied:\n"+e);
         torbutton_log(5, "Hook exception at: "+win.location+", "+e);
     }
 
@@ -1613,10 +1612,9 @@
             DOMWindow = aRequest.notificationCallbacks.QueryInterface(
                     Components.interfaces.nsIInterfaceRequestor).getInterface(
                         Components.interfaces.nsIDOMWindow);
-        } catch(e) {
-        }
+        } catch(e) { }
     }
-
+    
     // FIXME if intstanceof nsIHttpChannel check headers for 
     // Content-Disposition..
 
@@ -1630,12 +1628,14 @@
                     && chanreq instanceof Components.interfaces.nsIChannel
                     && aRequest.isPending()) {
 
-                torbutton_eclog(2, 'Pending request: '+aRequest.name);
+                try { torbutton_eclog(2, 'Pending request: '+aRequest.name); }
+                catch(e) { }
 
                 if(DOMWindow && DOMWindow.opener 
                         && m_tb_prefs.getBoolPref("extensions.torbutton.isolate_content")) {
 
-                    torbutton_eclog(3, 'Popup request: '+aRequest.name);
+                    try { torbutton_eclog(3, 'Popup request: '+aRequest.name); } 
+                    catch(e) { }
 
                     if(!(DOMWindow.top instanceof Components.interfaces.nsIDOMChromeWindow)) {
                         // Workaround for Firefox bug 409737

Modified: torbutton/trunk/src/components/cssblocker.js
===================================================================
--- torbutton/trunk/src/components/cssblocker.js	2008-03-04 18:01:59 UTC (rev 13859)
+++ torbutton/trunk/src/components/cssblocker.js	2008-03-04 19:40:58 UTC (rev 13860)
@@ -140,9 +140,11 @@
         }
 
         if(!this.isolate_content) {
-            this.logger.eclog(1, "Content policy disabled");
+            this.logger.eclog(2, "Content policy disabled");
             return ok;
         }
+            
+        this.logger.log(2, "Cpolicy load of: "+contentLocation.spec+" from: "+requestOrigin.spec);
 
         // "Host-free" schemes do not have an nsIURI.host property
         if(contentLocation.scheme in hostFreeSchemes) {
@@ -151,7 +153,7 @@
             }
             if(requestOrigin && 
                     (requestOrigin.scheme in safeOriginSchemes)) { 
-                this.logger.eclog(1, "Skipping chrome-sourced local: "+contentLocation.spec);
+                this.logger.eclog(2, "Skipping chrome-sourced local: "+contentLocation.spec);
                 return ok;
             } else if(contentLocation.spec.toLowerCase().indexOf("torbutton") != -1 || this.tor_enabled) {
                 this.logger.eclog(4, "Blocking local: "+contentLocation.spec+" from: "+requestOrigin.spec);
@@ -180,10 +182,10 @@
 		// Local stuff has to be eclog because otherwise debuglogger will
         // get into an infinite log-loop w/ its chrome updates
         if (this.isLocalScheme(contentLocation.scheme)) {
-            this.logger.eclog(1, "Skipping local: "+contentLocation.spec);
+            this.logger.eclog(2, "Skipping local: "+contentLocation.spec);
 			return ok;
-        } 
-        
+        }
+
         var node = wrapNode(insecNode);
         var wind = getWindow(node);
 
@@ -232,6 +234,18 @@
             return block; 
         }
 
+        // For javascript links (and others?) the normal http events
+        // for the weblistener in torbutton.js are suppressed
+        if(tor_state && node instanceof Ci.nsIDOMWindow) {
+            var wm = Cc["@mozilla.org/appshell/window-mediator;1"]
+                         .getService(Components.interfaces.nsIWindowMediator);
+            var chrome = wm.getMostRecentWindow("navigator:browser");
+
+            this.logger.eclog(2, "Hooking iframe domwindow");
+            // It doesn't really matter which chome window does the hooking.
+            chrome.torbutton_hookdoc(node, null);
+        }
+
         // source window of browser chrome window with a document content
         // type means the user entered a new URL.
         if(wind.top instanceof Components.interfaces.nsIDOMChromeWindow) {
@@ -259,7 +273,7 @@
                         if(browser.__tb_tor_fetched == tor_state) {
                             return ok;
                         } else {
-                            this.logger.log(3, "Blocking redirect: "+contentLocation.spec);
+                            this.logger.log(4, "Blocking redirect: "+contentLocation.spec);
                             return block;
                         }
                     }
@@ -271,7 +285,7 @@
         if(browser.__tb_tor_fetched == tor_state) {
             return ok;
         } else {
-            this.logger.log(3, "Blocking: "+contentLocation.spec);
+            this.logger.log(4, "Blocking: "+contentLocation.spec);
             return block;
         }
 	},