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

[or-cvs] r13869: Fix Torbutton discovery bug found by Greg. (torbutton/trunk/src/components)



Author: mikeperry
Date: 2008-03-05 02:12:40 -0500 (Wed, 05 Mar 2008)
New Revision: 13869

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

Fix Torbutton discovery bug found by Greg.



Modified: torbutton/trunk/src/components/cssblocker.js
===================================================================
--- torbutton/trunk/src/components/cssblocker.js	2008-03-05 05:00:26 UTC (rev 13868)
+++ torbutton/trunk/src/components/cssblocker.js	2008-03-05 07:12:40 UTC (rev 13869)
@@ -68,21 +68,26 @@
 	return fakeFactory.createInstance(insecNode, Components.interfaces.nsISupports);
 }
 
+function make_nsIURI(url) {
+    var nsiuri = Cc["@mozilla.org/network/standard-url;1"].createInstance(Ci.nsIStandardURL);
+    nsiuri.init(Ci.nsIStandardURL.URLTYPE_STANDARD, -1, url, null, null);
+    return nsiuri;
+}
+
 // Unwraps jar:, view-source: and wyciwyg: URLs, returns the contained URL
-// This is no longer needed. These urls are now blocked by mozilla,
-// or treated as normal network urls
-function unwrapURL(url) {
+function unwrapURL(url, changed) {
 	if (!url)
 		return url;
 
-	var ret = url.replace(/^view-source:/).replace(/^wyciwyg:\/\/\d+\//);
+	var ret = url.replace(/^view-source:/, "").replace(/^wyciwyg:\/\/\d+\//, "");
 	if (/^jar:(.*?)!/.test(ret))
 		ret = RegExp.$1;
 
 	if (ret == url)
-		return url;
-	else
-		return unwrapURL(ret);
+        if(changed) return make_nsIURI(url);
+        else return url;
+    else
+		return unwrapURL(ret, true);
 }
 
 var localSchemes = {"about" : true, "chrome" : true, "file" : true, 
@@ -146,6 +151,13 @@
             
         this.logger.log(2, "Cpolicy load of: "+contentLocation.spec+" from: "+requestOrigin.spec);
 
+        var utmp = unwrapURL(contentLocation.spec, false);
+        if(utmp instanceof Ci.nsIURI) {
+            utmp = utmp.QueryInterface(Ci.nsIURI);            
+            contentLocation = utmp;
+            this.logger.log(2, "Unwrapped cpolicy load of: "+contentLocation.spec+" from: "+requestOrigin.spec);
+        }
+
         // "Host-free" schemes do not have an nsIURI.host property
         if(contentLocation.scheme in hostFreeSchemes) {
             if(!requestOrigin) {
@@ -155,7 +167,7 @@
                     (requestOrigin.scheme in safeOriginSchemes)) { 
                 this.logger.eclog(2, "Skipping chrome-sourced local: "+contentLocation.spec);
                 return ok;
-            } else if(contentLocation.spec.toLowerCase().indexOf("torbutton") != -1 || this.tor_enabled) {
+            } else if(this.tor_enabled) {
                 this.logger.eclog(4, "Blocking local: "+contentLocation.spec+" from: "+requestOrigin.spec);
                 return block;
             }