[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] r10660: Improve user agent hooking for navigator.* js stuff. Make js (in torbutton/trunk/src: . chrome/content defaults/preferences)
Author: mikeperry
Date: 2007-06-22 13:43:56 -0400 (Fri, 22 Jun 2007)
New Revision: 10660
Modified:
torbutton/trunk/src/chrome/content/jshooks.js
torbutton/trunk/src/chrome/content/torbutton.js
torbutton/trunk/src/defaults/preferences/preferences.js
torbutton/trunk/src/install.rdf
Log:
Improve user agent hooking for navigator.* js stuff. Make
jshooking more invisible. Add glue to disable tor and restore
browser state on uninstal/disable of the extension. Also fix
sessionstoring bug found by phobos.
Modified: torbutton/trunk/src/chrome/content/jshooks.js
===================================================================
--- torbutton/trunk/src/chrome/content/jshooks.js 2007-06-22 16:01:24 UTC (rev 10659)
+++ torbutton/trunk/src/chrome/content/jshooks.js 2007-06-22 17:43:56 UTC (rev 10660)
@@ -1,4 +1,4 @@
-var __HookObjects = function() {
+window.__HookObjects = function() {
/* XXX: Removeme once verified not to run twice */
if (typeof(window.__tb_hooks_ran) != 'undefined') {
alert("Error, double jshook!");
@@ -13,9 +13,11 @@
/* Hrmm.. Is it possible this breaks plugin install or other weird shit
for non-windows OS's? */
if(__tb_set_uagent) {
- var tmp_oscpu = __tb_oscpu;
- var tmp_platform = __tb_platform;
+ var tmp_oscpu = window.__tb_oscpu;
+ var tmp_platform = window.__tb_platform;
+ var tmp_productSub = window.__tb_productSub;
navigator.__defineGetter__("oscpu", function() { return tmp_oscpu;});
+ navigator.__defineGetter__("productSub", function() { return tmp_productSub;});
/*navigator.__defineGetter__("platform", function() { return tmp_platform;});*/
}
@@ -155,12 +157,15 @@
Date.UTC=function(){return tmp.apply(tmp, arguments); }
}
-if (__HookObjects) {
- __HookObjects();
- __HookObjects = undefined;
- __tb_set_uagent = undefined;
- __tb_oscpu = undefined;
- __tb_platform = undefined;
+if (window.__HookObjects) {
+ window.__HookObjects();
+
+ delete window['__HookObjects'];
+ delete window['__tb_set_uagent'];
+ delete window['__tb_oscpu'];
+ delete window['__tb_platform'];
+ delete window['__tb_productSub'];
+
/* XXX: Removeme */
window.__tb_hooks_ran = true;
}
Modified: torbutton/trunk/src/chrome/content/torbutton.js
===================================================================
--- torbutton/trunk/src/chrome/content/torbutton.js 2007-06-22 16:01:24 UTC (rev 10659)
+++ torbutton/trunk/src/chrome/content/torbutton.js 2007-06-22 17:43:56 UTC (rev 10660)
@@ -179,8 +179,9 @@
torbutton_init_jshooks();
torbutton_log(5, 'registering pref observer');
- // FIXME: Hrmm... Do we really need a pref observer for each window?
+ // FIXME: Hrmm... Do we really need observers for each window?
torbutton_pref_observer.register();
+ torbutton_uninstall_observer.register();
m_tb_wasinited = true;
} else {
torbutton_log(5, 'skipping pref observer init');
@@ -521,24 +522,24 @@
// http://kb.mozillazine.org/About:config_entries
if(mode) {
if(torprefs.getBoolPref('block_thwrite')) {
- m_tb_prefs.setIntPref("browser.sessionstore.privacy_level", 2);
+ m_tb_prefs.setIntPref("browser.sessionstore.enabled", false);
m_tb_prefs.setIntPref("browser.download.manager.retention", 0);
m_tb_prefs.setBoolPref("browser.formfill.enable", false);
m_tb_prefs.setBoolPref("signon.rememberSignons", false);
} else {
- m_tb_prefs.setIntPref("browser.sessionstore.privacy_level", 1);
+ m_tb_prefs.setIntPref("browser.sessionstore.enabled", true);
m_tb_prefs.setIntPref("browser.download.manager.retention", 2);
m_tb_prefs.setBoolPref("browser.formfill.enable", true);
m_tb_prefs.setBoolPref("signon.rememberSignons", true);
}
} else {
if(torprefs.getBoolPref('block_nthwrite')) {
- m_tb_prefs.setIntPref("browser.sessionstore.privacy_level", 2);
+ m_tb_prefs.setIntPref("browser.sessionstore.enabled", false);
m_tb_prefs.setIntPref("browser.download.manager.retention", 0);
m_tb_prefs.setBoolPref("browser.formfill.enable", false);
m_tb_prefs.setBoolPref("signon.rememberSignons", false);
} else {
- m_tb_prefs.setIntPref("browser.sessionstore.privacy_level", 1);
+ m_tb_prefs.setIntPref("browser.sessionstore.enabled", true);
m_tb_prefs.setIntPref("browser.download.manager.retention", 2);
m_tb_prefs.setBoolPref("browser.formfill.enable", true);
m_tb_prefs.setBoolPref("signon.rememberSignons", true);
@@ -788,6 +789,52 @@
Components.interfaces.nsIWebProgress.NOTIFY_LOCATION);
}
+// Technique courtesy of:
+// http://xulsolutions.blogspot.com/2006/07/creating-uninstall-script-for.html
+const TORBUTTON_EXTENSION_UUID = "{E0204BD5-9D31-402B-A99D-A6AA8FFEBDCA}";
+var torbutton_uninstall_observer = {
+_uninstall : false,
+observe : function(subject, topic, data) {
+ if (topic == "em-action-requested") {
+ subject.QueryInterface(Components.interfaces.nsIUpdateItem);
+ torbutton_log(1, "Uninstall: "+data+" "+subject.id.toUpperCase());
+
+ if (subject.id.toUpperCase() == TORBUTTON_EXTENSION_UUID) {
+ torbutton_log(1, "Uninstall: "+data);
+ // XXX: What about disabled??
+ if (data == "item-uninstalled" || data == "item-disabled") {
+ this._uninstall = true;
+ } else if (data == "item-cancel-action") {
+ this._uninstall = false;
+ }
+ }
+ } else if (topic == "quit-application-granted") {
+ if (this._uninstall) {
+ torbutton_disable_tor();
+ // Still called by pref observer:
+ // torbutton_update_status(false, false);
+ }
+ this.unregister();
+ }
+},
+register : function() {
+ var observerService =
+ Components.classes["@mozilla.org/observer-service;1"].
+ getService(Components.interfaces.nsIObserverService);
+
+ observerService.addObserver(this, "em-action-requested", false);
+ observerService.addObserver(this, "quit-application-granted", false);
+},
+unregister : function() {
+ var observerService =
+ Components.classes["@mozilla.org/observer-service;1"].
+ getService(Components.interfaces.nsIObserverService);
+
+ observerService.removeObserver(this,"em-action-requested");
+ observerService.removeObserver(this,"quit-application-granted");
+}
+}
+
window.addEventListener('load',torbutton_new_window,false);
getBrowser().addEventListener("TabOpen", torbutton_new_tab, false);
@@ -866,9 +913,10 @@
*/
var str = "<"+"script>\r\n";
- str += "var __tb_set_uagent="+m_tb_prefs.getBoolPref('extensions.torbutton.set_uagent')+";\r\n";
- str += "var __tb_oscpu=\""+m_tb_prefs.getCharPref('extensions.torbutton.oscpu_override')+"\";\r\n";
- str += "var __tb_platform=\""+m_tb_prefs.getCharPref('extensions.torbutton.platform_override')+"\";\r\n";
+ str += "window.__tb_set_uagent="+m_tb_prefs.getBoolPref('extensions.torbutton.set_uagent')+";\r\n";
+ str += "window.__tb_oscpu=\""+m_tb_prefs.getCharPref('extensions.torbutton.oscpu_override')+"\";\r\n";
+ str += "window.__tb_platform=\""+m_tb_prefs.getCharPref('extensions.torbutton.platform_override')+"\";\r\n";
+ str += "window.__tb_productSub=\""+m_tb_prefs.getCharPref('extensions.torbutton.productsub_override')+"\";\r\n";
str += m_tb_jshooks;
str += "</"+"script>";
var d = doc.createElement("div");
Modified: torbutton/trunk/src/defaults/preferences/preferences.js
===================================================================
--- torbutton/trunk/src/defaults/preferences/preferences.js 2007-06-22 16:01:24 UTC (rev 10659)
+++ torbutton/trunk/src/defaults/preferences/preferences.js 2007-06-22 17:43:56 UTC (rev 10660)
@@ -62,6 +62,7 @@
pref("extensions.torbutton.appversion_override","5.0 (Windows; en-US)");
pref("extensions.torbutton.platform_override","Win32");
pref("extensions.torbutton.oscpu_override", "Windows NT 5.1");
-pref("extensions.torbutton.useragent_override","Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.4) Gecko/20070515 Firefox/2.0.0.4");
+pref("extensions.torbutton.useragent_override", "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.4) Gecko/20070515 Firefox/2.0.0.4");
+pref("extensions.torbutton.productsub_override","20070515");
pref("extensions.torbutton.useragent_vendor", "");
pref("extensions.torbutton.useragent_vendorSub","");
Modified: torbutton/trunk/src/install.rdf
===================================================================
--- torbutton/trunk/src/install.rdf 2007-06-22 16:01:24 UTC (rev 10659)
+++ torbutton/trunk/src/install.rdf 2007-06-22 17:43:56 UTC (rev 10660)
@@ -6,7 +6,7 @@
<em:name>Torbutton</em:name>
<em:creator>Scott Squires & Mike Perry</em:creator>
<em:id>{e0204bd5-9d31-402b-a99d-a6aa8ffebdca}</em:id>
- <em:version>1.1.1-alpha</em:version>
+ <em:version>1.1.2-alpha</em:version>
<em:homepageURL>http://freehaven.net/~squires/torbutton/</em:homepageURL>
<em:updateURL>http://freehaven.net/~squires/torbutton/update.rdf</em:updateURL>
<em:optionsURL>chrome://torbutton/content/preferences.xul</em:optionsURL>