[tor-commits] [Git][tpo/applications/tor-browser][tor-browser-102.12.0esr-12.5-1] fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in...

ma1 (@ma1) git at gitlab.torproject.org
Wed Jun 7 20:27:34 UTC 2023



ma1 pushed to branch tor-browser-102.12.0esr-12.5-1 at The Tor Project / Applications / Tor Browser


Commits:
338b3317 by Henry Wilkes at 2023-06-07T19:58:06+00:00
fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in about:preferences#connection

Bug 41810 - Add "Connect" button instead of the "Submit" and "OK" button in the bridge request dialog and the manual bridge dialog, respectively.

- - - - -


4 changed files:

- browser/components/torpreferences/content/builtinBridgeDialog.jsm
- browser/components/torpreferences/content/connectionPane.js
- browser/components/torpreferences/content/provideBridgeDialog.jsm
- browser/components/torpreferences/content/requestBridgeDialog.jsm


Changes:

=====================================
browser/components/torpreferences/content/builtinBridgeDialog.jsm
=====================================
@@ -36,9 +36,6 @@ class BuiltinBridgeDialog {
       "#torPreferences-builtinBridge-description"
     ).textContent = TorStrings.settings.builtinBridgeDescription2;
 
-    this._acceptButton = dialog.getButton("accept");
-    this.onTorStateChange();
-
     const radioGroup = dialog.querySelector(
       "#torPreferences-builtinBridge-typeSelection"
     );
@@ -102,20 +99,26 @@ class BuiltinBridgeDialog {
     dialog.style.minWidth = "0";
     dialog.style.minHeight = "0";
 
+    this._acceptButton = dialog.getButton("accept");
+
     Services.obs.addObserver(this, TorConnectTopics.StateChange);
+    this.onAcceptStateChange();
   }
 
-  onTorStateChange() {
-    if (TorConnect.canBeginBootstrap) {
-      this._acceptButton.setAttribute(
-        "label",
-        TorStrings.settings.bridgeButtonConnect
-      );
-    } else {
-      this._acceptButton.setAttribute(
-        "label",
-        TorStrings.settings.bridgeButtonAccept
-      );
+  onAcceptStateChange() {
+    this._acceptButton.setAttribute(
+      "label",
+      TorConnect.canBeginBootstrap
+        ? TorStrings.settings.bridgeButtonConnect
+        : TorStrings.settings.bridgeButtonAccept
+    );
+  }
+
+  observe(subject, topic, data) {
+    switch (topic) {
+      case TorConnectTopics.StateChange:
+        this.onAcceptStateChange();
+        break;
     }
   }
 
@@ -126,16 +129,8 @@ class BuiltinBridgeDialog {
     }, 0);
   }
 
-  observe(subject, topic, data) {
-    switch (topic) {
-      case TorConnectTopics.StateChange:
-        this.onTorStateChange();
-        break;
-    }
-  }
-
   close() {
-    // unregister our observer topics
+    // Unregister our observer topics.
     Services.obs.removeObserver(this, TorConnectTopics.StateChange);
   }
 


=====================================
browser/components/torpreferences/content/connectionPane.js
=====================================
@@ -1047,9 +1047,47 @@ const gConnectionPane = (function() {
       });
     },
 
+    /**
+     * Save and apply settings, then optionally open about:torconnect and start
+     * bootstrapping.
+     *
+     * @param {boolean} connect - Whether to open about:torconnect and start
+     *   bootstrapping if possible.
+     */
+    async saveBridgeSettings(connect) {
+      TorSettings.saveToPrefs();
+      // FIXME: This can throw if the user adds a bridge manually with invalid
+      // content. Should be addressed by tor-browser#40552.
+      await TorSettings.applySettings();
+
+      this._populateBridgeCards();
+
+      if (!connect) {
+        return;
+      }
+
+      // The bridge dialog button is "connect" when Tor is not bootstrapped,
+      // so do the connect.
+
+      // Start Bootstrapping, which should use the configured bridges.
+      // NOTE: We do this regardless of any previous TorConnect Error.
+      if (TorConnect.canBeginBootstrap) {
+        TorConnect.beginBootstrap();
+      }
+      // Open "about:torconnect".
+      // FIXME: If there has been a previous bootstrapping error then
+      // "about:torconnect" will be trying to get the user to use
+      // AutoBootstrapping. It is not set up to handle a forced direct
+      // entry to plain Bootstrapping from this dialog so the UI will not
+      // be aligned. In particular the
+      // AboutTorConnect.uiState.bootstrapCause will be aligned to
+      // whatever was shown previously in "about:torconnect" instead.
+      TorConnect.openTorConnect();
+    },
+
     onAddBuiltinBridge() {
       const builtinBridgeDialog = new BuiltinBridgeDialog(
-        async (bridgeType, connect) => {
+        (bridgeType, connect) => {
           if (!bridgeType) {
             TorSettings.bridges.enabled = false;
             TorSettings.bridges.builtin_type = "";
@@ -1058,29 +1096,8 @@ const gConnectionPane = (function() {
             TorSettings.bridges.source = TorBridgeSource.BuiltIn;
             TorSettings.bridges.builtin_type = bridgeType;
           }
-          TorSettings.saveToPrefs();
-          await TorSettings.applySettings();
-
-          this._populateBridgeCards();
 
-          // The bridge dialog button is "connect" when Tor is not bootstrapped,
-          // so do the connect.
-          if (connect) {
-            // Start Bootstrapping, which should use the configured bridges.
-            // NOTE: We do this regardless of any previous TorConnect Error.
-            if (TorConnect.canBeginBootstrap) {
-              TorConnect.beginBootstrap();
-            }
-            // Open "about:torconnect".
-            // FIXME: If there has been a previous bootstrapping error then
-            // "about:torconnect" will be trying to get the user to use
-            // AutoBootstrapping. It is not set up to handle a forced direct
-            // entry to plain Bootstrapping from this dialog so the UI will not
-            // be aligned. In particular the
-            // AboutTorConnect.uiState.bootstrapCause will be aligned to
-            // whatever was shown previously in "about:torconnect" instead.
-            TorConnect.openTorConnect();
-          }
+          this.saveBridgeSettings(connect);
         }
       );
       builtinBridgeDialog.openDialog(gSubDialog);
@@ -1088,37 +1105,38 @@ const gConnectionPane = (function() {
 
     // called when the request bridge button is activated
     onRequestBridge() {
-      const requestBridgeDialog = new RequestBridgeDialog(aBridges => {
-        if (aBridges.length) {
+      const requestBridgeDialog = new RequestBridgeDialog(
+        (aBridges, connect) => {
+          if (!aBridges.length) {
+            return;
+          }
           const bridgeStrings = aBridges.join("\n");
           TorSettings.bridges.enabled = true;
           TorSettings.bridges.source = TorBridgeSource.BridgeDB;
           TorSettings.bridges.bridge_strings = bridgeStrings;
-          TorSettings.saveToPrefs();
-          TorSettings.applySettings().then(result => {
-            this._populateBridgeCards();
-          });
+
+          this.saveBridgeSettings(connect);
         }
-      });
+      );
       requestBridgeDialog.openDialog(gSubDialog);
     },
 
     onAddBridgeManually() {
-      const provideBridgeDialog = new ProvideBridgeDialog(aBridgeString => {
-        if (aBridgeString.length) {
-          TorSettings.bridges.enabled = true;
-          TorSettings.bridges.source = TorBridgeSource.UserProvided;
-          TorSettings.bridges.bridge_strings = aBridgeString;
-        } else {
-          TorSettings.bridges.enabled = false;
-          TorSettings.bridges.source = TorBridgeSource.Invalid;
-          TorSettings.bridges.bridge_strings = "";
+      const provideBridgeDialog = new ProvideBridgeDialog(
+        (aBridgeString, connect) => {
+          if (aBridgeString) {
+            TorSettings.bridges.enabled = true;
+            TorSettings.bridges.source = TorBridgeSource.UserProvided;
+            TorSettings.bridges.bridge_strings = aBridgeString;
+          } else {
+            TorSettings.bridges.enabled = false;
+            TorSettings.bridges.source = TorBridgeSource.Invalid;
+            TorSettings.bridges.bridge_strings = "";
+          }
+
+          this.saveBridgeSettings(connect);
         }
-        TorSettings.saveToPrefs();
-        TorSettings.applySettings().then(result => {
-          this._populateBridgeCards();
-        });
-      });
+      );
       provideBridgeDialog.openDialog(gSubDialog);
     },
 


=====================================
browser/components/torpreferences/content/provideBridgeDialog.jsm
=====================================
@@ -2,17 +2,24 @@
 
 var EXPORTED_SYMBOLS = ["ProvideBridgeDialog"];
 
+const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
+
 const { TorStrings } = ChromeUtils.import("resource:///modules/TorStrings.jsm");
 
 const { TorSettings, TorBridgeSource } = ChromeUtils.import(
   "resource:///modules/TorSettings.jsm"
 );
 
+const { TorConnect, TorConnectTopics } = ChromeUtils.import(
+  "resource:///modules/TorConnect.jsm"
+);
+
 class ProvideBridgeDialog {
   constructor(onSubmit) {
     this.onSubmit = onSubmit;
     this._dialog = null;
     this._textarea = null;
+    this._acceptButton = null;
   }
 
   static get selectors() {
@@ -49,14 +56,43 @@ class ProvideBridgeDialog {
       "placeholder",
       TorStrings.settings.provideBridgePlaceholder
     );
+    this._textarea.addEventListener("input", () => {
+      this.onAcceptStateChange();
+    });
     if (TorSettings.bridges.source == TorBridgeSource.UserProvided) {
       this._textarea.value = TorSettings.bridges.bridge_strings.join("\n");
     }
 
     this._dialog.addEventListener("dialogaccept", e => {
-      this.onSubmit(this._textarea.value);
+      let value = this._textarea.value;
+      if (!value.trim()) {
+        value = null;
+      }
+      this.onSubmit(value, value && TorConnect.canBeginBootstrap);
     });
     this._dialog.addEventListener("dialoghelp", openHelp);
+
+    this._acceptButton = this._dialog.getButton("accept");
+
+    Services.obs.addObserver(this, TorConnectTopics.StateChange);
+    this.onAcceptStateChange();
+  }
+
+  onAcceptStateChange() {
+    this._acceptButton.setAttribute(
+      "label",
+      this._textarea.value.trim() && TorConnect.canBeginBootstrap
+        ? TorStrings.settings.bridgeButtonConnect
+        : TorStrings.settings.bridgeButtonAccept
+    );
+  }
+
+  observe(subject, topic, data) {
+    switch (topic) {
+      case TorConnectTopics.StateChange:
+        this.onAcceptStateChange();
+        break;
+    }
   }
 
   init(window, aDialog) {
@@ -66,10 +102,20 @@ class ProvideBridgeDialog {
     }, 0);
   }
 
+  close() {
+    // Unregister our observer topics.
+    Services.obs.removeObserver(this, TorConnectTopics.StateChange);
+  }
+
   openDialog(gSubDialog) {
     gSubDialog.open(
       "chrome://browser/content/torpreferences/provideBridgeDialog.xhtml",
-      { features: "resizable=yes" },
+      {
+        features: "resizable=yes",
+        closingCallback: () => {
+          this.close();
+        },
+      },
       this
     );
   }


=====================================
browser/components/torpreferences/content/requestBridgeDialog.jsm
=====================================
@@ -2,9 +2,15 @@
 
 var EXPORTED_SYMBOLS = ["RequestBridgeDialog"];
 
+const { Services } = ChromeUtils.import("resource://gre/modules/Services.jsm");
+
 const { BridgeDB } = ChromeUtils.import("resource:///modules/BridgeDB.jsm");
 const { TorStrings } = ChromeUtils.import("resource:///modules/TorStrings.jsm");
 
+const { TorConnect, TorConnectTopics } = ChromeUtils.import(
+  "resource:///modules/TorConnect.jsm"
+);
+
 class RequestBridgeDialog {
   constructor(onSubmit) {
     this.onSubmit = onSubmit;
@@ -20,8 +26,6 @@ class RequestBridgeDialog {
 
   static get selectors() {
     return {
-      submitButton:
-        "accept" /* not really a selector but a key for dialog's getButton */,
       dialogHeader: "h3#torPreferences-requestBridge-header",
       captchaImage: "image#torPreferences-requestBridge-captchaImage",
       captchaEntryTextbox: "input#torPreferences-requestBridge-captchaTextbox",
@@ -57,8 +61,7 @@ class RequestBridgeDialog {
       }
     });
 
-    this._submitButton = this._dialog.getButton(selectors.submitButton);
-    this._submitButton.setAttribute("label", TorStrings.settings.submitCaptcha);
+    this._submitButton = this._dialog.getButton("accept");
     this._submitButton.disabled = true;
     this._dialog.addEventListener("dialogaccept", e => {
       e.preventDefault();
@@ -110,7 +113,25 @@ class RequestBridgeDialog {
       TorStrings.settings.incorrectCaptcha
     );
 
-    return true;
+    Services.obs.addObserver(this, TorConnectTopics.StateChange);
+    this.onAcceptStateChange();
+  }
+
+  onAcceptStateChange() {
+    this._submitButton.setAttribute(
+      "label",
+      TorConnect.canBeginBootstrap
+        ? TorStrings.settings.bridgeButtonConnect
+        : TorStrings.settings.submitCaptcha
+    );
+  }
+
+  observe(subject, topic, data) {
+    switch (topic) {
+      case TorConnectTopics.StateChange:
+        this.onAcceptStateChange();
+        break;
+    }
   }
 
   _setcaptchaImage(uri) {
@@ -142,6 +163,8 @@ class RequestBridgeDialog {
 
   close() {
     BridgeDB.close();
+    // Unregister our observer topics.
+    Services.obs.removeObserver(this, TorConnectTopics.StateChange);
   }
 
   /*
@@ -161,7 +184,7 @@ class RequestBridgeDialog {
     BridgeDB.submitCaptchaGuess(captchaText)
       .then(aBridges => {
         if (aBridges) {
-          this.onSubmit(aBridges);
+          this.onSubmit(aBridges, TorConnect.canBeginBootstrap);
           this._submitButton.disabled = false;
           // This was successful, but use cancelDialog() to close, since
           // we intercept the `dialogaccept` event.



View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/338b3317a0894e0d51b7e5639585bb93e47edf03

-- 
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/commit/338b3317a0894e0d51b7e5639585bb93e47edf03
You're receiving this email because of your account on gitlab.torproject.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.torproject.org/pipermail/tor-commits/attachments/20230607/ab613a5e/attachment-0001.htm>


More information about the tor-commits mailing list