[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] [torbutton/master] Implement prefetching of google cookies.
Author: Mike Perry <mikeperry-git@xxxxxxxxxx>
Date: Sat, 10 Oct 2009 13:12:08 -0700
Subject: Implement prefetching of google cookies.
Commit: efd4a5353392f8b2cec1c51f2fe23e426e39fb93
---
src/chrome/content/torbutton.js | 140 ++++++++++++++++++++++++++++++++-------
1 files changed, 115 insertions(+), 25 deletions(-)
diff --git a/src/chrome/content/torbutton.js b/src/chrome/content/torbutton.js
index c14d60c..88ecf2b 100644
--- a/src/chrome/content/torbutton.js
+++ b/src/chrome/content/torbutton.js
@@ -9,6 +9,7 @@ var m_tb_jshooks = false;
var m_tb_plugin_mimetypes = false;
var m_tb_plugin_string = false;
var m_tb_is_main_window = false;
+var m_tb_hidden_browser = false;
var m_tb_window_height = window.outerHeight;
var m_tb_window_width = window.outerWidth;
@@ -1288,12 +1289,6 @@ function torbutton_update_status(mode, force_update) {
}
m_tb_prefs.setBoolPref("extensions.torbutton.settings_applied", mode);
-
- // This must happen after settings_applied is set so we know it
- // is safe to do any potential google.ca fetches.
- if (mode) {
- torbutton_new_google_cookie();
- }
torbutton_log(3, "Settings applied for mode: "+mode);
}
@@ -2184,9 +2179,13 @@ register: function() {
},
unregister: function() {
- var os = Components.classes['@mozilla.org/observer-service;1'].
+ try {
+ var os = Components.classes['@mozilla.org/observer-service;1'].
getService(Components.interfaces.nsIObserverService);
os.removeObserver(torbutton_cookie_observer, 'cookie-changed');
+ } catch(e) {
+ torbutton_log(3, "Already unregistered cookie observer");
+ }
}
};
@@ -2211,7 +2210,7 @@ function torbutton_new_google_cookie() {
}
if (!gpref) {
- torbutton_safelog(3, "No google cookie found. Regenerating.");
+ torbutton_log(3, "No google cookie found. Regenerating.");
if (reset) {
torbutton_reset_google_cookie();
} else if (regen) {
@@ -2220,25 +2219,108 @@ function torbutton_new_google_cookie() {
}
}
+function torbutton_init_hidden_browser() {
+ var loaderBox = document.createElement("hbox");
+ loaderBox.setAttribute("style", "overflow: hidden; visibility: hidden;");
+ loaderBox.setAttribute("flex", "1");
+ loaderBox.setAttribute("height", "0");
+ loaderBox.setAttribute("maxheight", "0");
+ loaderBox.setAttribute("minheight", "0");
+
+ var loaderSubBox = document.createElement("vbox");
+ loaderSubBox.setAttribute("flex", "0");
+ loaderBox.appendChild(loaderSubBox);
+ document.documentElement.appendChild(loaderBox);
+
+ var win_width = window.getBrowser().contentWindow.innerWidth;
+ var win_height = window.getBrowser().contentWindow.innerHeight;
+
+ loaderSubBox.setAttribute("width", win_width);
+ loaderSubBox.setAttribute("minwidth", win_width);
+ loaderSubBox.setAttribute("maxwidth", win_width);
+ loaderSubBox.setAttribute("height", win_height);
+ loaderSubBox.setAttribute("minheight", win_height);
+ loaderSubBox.setAttribute("maxheight", win_height);
+
+ loaderSubBox.style.width = win_width + "px !important";
+ loaderSubBox.style.maxWidth = loaderSubBox.style.width;
+ loaderSubBox.style.minWidth = loaderSubBox.style.width;
+ loaderSubBox.style.height = win_height + "px !important";
+ loaderSubBox.style.maxHeight = loaderSubBox.style.height;
+ loaderSubBox.style.minHeight = loaderSubBox.style.height;
+
+ m_tb_hidden_browser = document.createElement("browser");
+ m_tb_hidden_browser.setAttribute("class", "torbuttonBrowser");
+ m_tb_hidden_browser.setAttribute("type", "content");
+ m_tb_hidden_browser.setAttribute("disablehistory", true);
+ m_tb_hidden_browser.setAttribute("allowPlugins", false);
+ m_tb_hidden_browser.setAttribute("flex", "1");
+ m_tb_hidden_browser.setAttribute("id", "torbuttonBrowser");
+
+ loaderSubBox.appendChild(m_tb_hidden_browser);
+ torbutton_log(3, "Created hidden browser.");
+}
+
+var torbutton_google_cookie_regen_listener = {
+ QueryInterface: function(aIID)
+ {
+ if (aIID.equals(Components.interfaces.nsIDOMEventListener) ||
+ aIID.equals(Components.interfaces.nsIWebProgressListener) ||
+ aIID.equals(Components.interfaces.nsISupportsWeakReference) ||
+ aIID.equals(Components.interfaces.nsISupports))
+ return this;
+ throw Components.results.NS_NOINTERFACE;
+ },
+
+ onStateChange: function(aWebProgress, aRequest, aFlag, aStatus) {
+ torbutton_log(3, "Google cookie fetch progress");
+ if ((aFlag & Ci.nsIWebProgressListener.STATE_STOP)
+ && (aFlag & Ci.nsIWebProgressListener.STATE_IS_WINDOW)) {
+ m_tb_hidden_browser.removeProgressListener(torbutton_google_cookie_regen_listener);
+ m_tb_hidden_browser.setAttribute("src", "about:blank");
+ torbutton_log(3, "Google cookie fetch complete.");
+ }
+ },
+
+ onLocationChange: function(aProgress, aRequest, aURI) { return 0; },
+ onProgressChange: function() {return 0;},
+ onStatusChange: function() {return 0;},
+ onSecurityChange: function() {return 0;},
+ onLinkIconAvailable: function() {return 0;}
+};
+
function torbutton_regen_google_cookie() {
// Only fire if tor fully enabled...
- if (m_tb_prefs.getBoolPref("extensions.torbutton.settings_applied")) {
+ if (m_tb_prefs.getBoolPref("extensions.torbutton.proxies_applied")) {
torbutton_log(3, "Regenerating google cookie via fetch");
- // XXX: Make sure our docshell hooks and plugin protections apply
- // to any window we create.
- // https://addons.mozilla.org/en-US/firefox/addon/2207
- // https://addons.mozilla.org/en-US/firefox/addon/8879
- // https://addons.mozilla.org/en-US/firefox/addon/4810
+ if (!m_tb_hidden_browser) {
+ torbutton_init_hidden_browser();
+ }
+ m_tb_hidden_browser.addProgressListener(torbutton_google_cookie_regen_listener,
+ Ci.nsIWebProgress.NOTIFY_STATE_DOCUMENT);
+
+ /* XXX: ideal, but broken..
+ m_tb_hidden_browser.loadURIWithFlags(
+ "http://www"+m_tb_prefs.getCharPref("extensions.torbutton.gpref_host")+"/",
+ Ci.nsIWebNavigation.LOAD_FLAGS_BYPASS_CACHE
+ |Ci.nsIWebNavigation.LOAD_FLAGS_BYPASS_HISTORY, null, null);
+ */
+
+ torbutton_log(3, "Cookie fetch initiating..");
+
+ m_tb_hidden_browser.setAttribute("src",
+ "http://www"+m_tb_prefs.getCharPref("extensions.torbutton.gpref_host")+"/");
+
}
}
function torbutton_reset_google_cookie() {
// Only fire if tor is fully enabled..
- if (m_tb_prefs.getBoolPref("extensions.torbutton.settings_applied")) {
+ if (m_tb_prefs.getBoolPref("extensions.torbutton.proxies_applied")) {
torbutton_log(3, "Resetting google cookie to pref");
var cm = Components.classes['@mozilla.org/cookiemanager;1'].
getService(Components.interfaces.nsICookieManager2);
- const expires = (new Date("Jan 1, 3000")).getTime() / 1000;
+ var expires = (new Date("Jan 1, 3000")).getTime() / 1000;
// FIXME: NID cookie?
cm.add(
@@ -2255,7 +2337,7 @@ function torbutton_reset_google_cookie() {
function torbutton_xfer_google_cookie(subject, topic, data) {
// Only fire if tor is fully enabled
- if (m_tb_prefs.getBoolPref("extensions.torbutton.settings_applied")) {
+ if (m_tb_prefs.getBoolPref("extensions.torbutton.proxies_applied")) {
// catch load requests for nsIURI.host of google.(com|[\S\S](.[\S\S])?)$
// If no pref cookie, generate from google.ca PREF
var httpChannel = subject.QueryInterface(Components.interfaces.nsIHttpChannel);
@@ -2264,8 +2346,13 @@ function torbutton_xfer_google_cookie(subject, topic, data) {
// check nsIURI
if (hostmatch) {
+ var google_host = m_tb_prefs.getCharPref("extensions.torbutton.gpref_host");
torbutton_log(3, "Got Google request for host: "+subject.URI.host
+", matched: "+hostmatch[0]);
+ if ("."+hostmatch[0] == google_host) {
+ torbutton_log(3, "Skipping google cookie for main host");
+ return;
+ }
// Check if we have a cookie yet:
var cookies = null;
try {
@@ -2280,7 +2367,6 @@ function torbutton_xfer_google_cookie(subject, topic, data) {
.getService(Ci.nsICookieManager);
var cookiesEnum = cookieManager.enumerator;
var gpref = null;
- var google_host = m_tb_prefs.getCharPref("extensions.torbutton.gpref_host");
var use_google_host =
m_tb_prefs.getBoolPref("extensions.torbutton.reset_gpref_cookie")
|| m_tb_prefs.getBoolPref("extensions.torbutton.regen_gpref_cookie");
@@ -2293,13 +2379,14 @@ function torbutton_xfer_google_cookie(subject, topic, data) {
} else {
hostmatched = (new String(cookie.host)).match(/^\.google\.(co\.\S\S|com|\S\S|com\.\S\S)$/);
}
- if (hostmatched && cookie.path == "/" && cookie.name == "PREF") {
+ if (cookie.host != "."+hostmatch[0] && hostmatched &&
+ cookie.path == "/" && cookie.name == "PREF") {
gpref = cookie;
}
}
- torbutton_log(3, "Got gpref: "+(gpref ? gpref.name : "none"));
+ torbutton_log(3, "Got gpref: "+(gpref ? gpref.host+" "+gpref.value : "none"));
if (!gpref) {
- torbutton_safelog(4, "No cookie to xfer to new host: ", subject.URI.host);
+ torbutton_safelog(4, "No cookie to migrate: ", subject.URI.host);
return;
}
httpChannel.setRequestHeader("Cookie", gpref.name+"="+gpref.value,
@@ -2310,13 +2397,12 @@ function torbutton_xfer_google_cookie(subject, topic, data) {
// FIXME: NID cookie?
- // XXX: isSession? Should be overrriden by our prefs.. right?
cm.add(
"."+hostmatch[0],
- "/", // path
+ gpref.path, // path
gpref.name,
gpref.value,
- false, // isSecure
+ gpref.isSecure, // isSecure
false, // isHttpOnly
false, // isSession
expires);
@@ -2351,6 +2437,10 @@ observe : function(subject, topic, data) {
torbutton_disable_tor();
}
+ // Remove the cookie observer so clearing cookies does not
+ // issue a new request.
+ torbutton_cookie_observer.unregister();
+
// Set pref in case this is just an upgrade (So we don't
// mess with cookies)
torbutton_log(2, "Torbutton normal exit");
@@ -2922,7 +3012,7 @@ function torbutton_update_tags(win) {
// an alternate tor state. It wil lmake this window totally
// useless, but that is better than some undefined state
browser.__tb_tor_fetched = tor_tag;
- }
+ }
if(browser.__tb_tor_fetched != !tor_tag) {
// Purge session history every time we fetch a new doc
// in a new tor state
--
1.5.6.5