[tor-commits] [meek/extension] Actually use the "profile-after-change" observer.

dcf at torproject.org dcf at torproject.org
Thu Apr 3 16:33:25 UTC 2014


commit 2c389fafe92afbed16eabcfbd00fd754f7c9b73f
Author: David Fifield <david at bamsoftware.com>
Date:   Sun Mar 23 17:04:33 2014 -0700

    Actually use the "profile-after-change" observer.
    
    Before we were starting the listener as a side effect of the
    constructor. Actually wait until we get the "profile-after-change"
    notification before running.
---
 firefox/components/main.js |   24 ++++++++++++++----------
 1 file changed, 14 insertions(+), 10 deletions(-)

diff --git a/firefox/components/main.js b/firefox/components/main.js
index a55eb8c..d4b4d35 100644
--- a/firefox/components/main.js
+++ b/firefox/components/main.js
@@ -37,16 +37,7 @@ Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
 // nsIServerSocketListener.
 function MeekHTTPHelper() {
     this.wrappedJSObject = this;
-
-    const LOCAL_PORT = 7000;
-
     this.handlers = [];
-
-    // https://developer.mozilla.org/en-US/docs/XPCOM_Interface_Reference/nsIServerSocket
-    var serverSocket = Components.classes["@mozilla.org/network/server-socket;1"]
-        .createInstance(Components.interfaces.nsIServerSocket);
-    serverSocket.init(LOCAL_PORT, true, -1);
-    serverSocket.asyncListen(this);
 }
 MeekHTTPHelper.prototype = {
     classDescription: "meek HTTP helper component",
@@ -55,10 +46,22 @@ MeekHTTPHelper.prototype = {
 
     // https://developer.mozilla.org/en-US/docs/Mozilla/JavaScript_code_modules/XPCOMUtils.jsm#generateQI%28%29
     QueryInterface: XPCOMUtils.generateQI([
-        Components.interfaces.nsIServerSocketListener,
         Components.interfaces.nsIObserver,
+        Components.interfaces.nsIServerSocketListener,
     ]),
 
+    // nsIObserver implementation.
+    observe: function(subject, topic, data) {
+        if (topic !== "profile-after-change")
+            return
+
+        // https://developer.mozilla.org/en-US/docs/XPCOM_Interface_Reference/nsIServerSocket
+        var serverSocket = Components.classes["@mozilla.org/network/server-socket;1"]
+            .createInstance(Components.interfaces.nsIServerSocket);
+        serverSocket.init(MeekHTTPHelper.LOCAL_PORT, true, -1);
+        serverSocket.asyncListen(this);
+    },
+
     // nsIServerSocketListener implementation.
     onSocketAccepted: function(server, transport) {
         dump("onSocketAccepted " + transport.host + ":" + transport.port + "\n");
@@ -73,6 +76,7 @@ MeekHTTPHelper.prototype = {
 
 // Global variables and functions.
 
+MeekHTTPHelper.LOCAL_PORT = 7000;
 MeekHTTPHelper.LOCAL_READ_TIMEOUT = 2.0;
 MeekHTTPHelper.LOCAL_WRITE_TIMEOUT = 2.0;
 



More information about the tor-commits mailing list