[tor-commits] [tor-browser/tor-browser-91.2.0esr-11.0-1] fixup! Bug 27476: Implement about:torconnect captive portal within Tor Browser
sysrqb at torproject.org
sysrqb at torproject.org
Wed Oct 6 13:32:12 UTC 2021
commit c962f24a8a8c7825ec18ce513d354f4093e78363
Author: Richard Pospesel <richard at torproject.org>
Date: Fri Sep 10 11:42:55 2021 -0500
fixup! Bug 27476: Implement about:torconnect captive portal within Tor Browser
---
.../torconnect/content/torBootstrapUrlbar.js | 2 +-
.../components/torpreferences/content/torPane.js | 51 ++++++++++++++--------
.../torpreferences/content/torPreferences.css | 9 ++--
browser/modules/TorConnect.jsm | 13 ++++--
4 files changed, 48 insertions(+), 27 deletions(-)
diff --git a/browser/components/torconnect/content/torBootstrapUrlbar.js b/browser/components/torconnect/content/torBootstrapUrlbar.js
index 7843b80be8b9..e6a88490f33d 100644
--- a/browser/components/torconnect/content/torBootstrapUrlbar.js
+++ b/browser/components/torconnect/content/torBootstrapUrlbar.js
@@ -76,7 +76,7 @@ var TorBootstrapUrlbar = {
inputContainer: gURLBar._inputContainer,
})
this.elements.torConnectBox.addEventListener("click", () => {
- window.openTrustedLinkIn("about:torconnect", "tab");
+ TorConnect.openTorConnect();
});
Services.obs.addObserver(this, TorConnectTopics.StateChange);
this.observing = true;
diff --git a/browser/components/torpreferences/content/torPane.js b/browser/components/torpreferences/content/torPane.js
index afdb27351831..a975c93cb8ed 100644
--- a/browser/components/torpreferences/content/torPane.js
+++ b/browser/components/torpreferences/content/torPane.js
@@ -10,7 +10,7 @@ const { TorProtocolService } = ChromeUtils.import(
"resource:///modules/TorProtocolService.jsm"
);
-const { TorConnect } = ChromeUtils.import(
+const { TorConnect, TorConnectTopics, TorConnectState } = ChromeUtils.import(
"resource:///modules/TorConnect.jsm"
);
@@ -159,35 +159,42 @@ const gTorPane = (function() {
this._messageBoxButton = prefpane.querySelector(selectors.messageBox.button);
// wire up connect button
this._messageBoxButton.addEventListener("click", () => {
- TorConnect.beginBootstrap().then((result) => {
- let win = Services.wm.getMostRecentWindow("navigator:browser");
- // switch to existing about:torconnect tab or create a new one
- win.switchToTabHavingURI("about:torconnect", true);
- });
+ TorConnect.beginBootstrap();
+ TorConnect.openTorConnect();
});
- let populateMessagebox = () => {
- if (TorConnect.shouldShowTorConnect) {
+ this._populateMessagebox = () => {
+ if (TorConnect.shouldShowTorConnect &&
+ TorConnect.state === TorConnectState.Configuring) {
// set messagebox style and text
if (TorProtocolService.torBootstrapErrorOccurred()) {
+ this._messageBox.parentNode.style.display = null;
this._messageBox.className = "error";
this._messageBoxMessage.innerText = TorStrings.torConnect.tryAgainMessage;
this._messageBoxButton.innerText = TorStrings.torConnect.tryAgain;
} else {
+ this._messageBox.parentNode.style.display = null;
this._messageBox.className = "warning";
this._messageBoxMessage.innerText = TorStrings.torConnect.connectMessage;
this._messageBoxButton.innerText = TorStrings.torConnect.torConnectButton;
}
} else {
+ // we need to explicitly hide the groupbox, as switching between
+ // the tor pane and other panes will 'unhide' (via the 'hidden'
+ // attribute) the groupbox, offsetting all of the content down
+ // by the groupbox's margin (even if content is 0 height)
+ this._messageBox.parentNode.style.display = "none";
this._messageBox.className = "hidden";
this._messageBoxMessage.innerText = "";
this._messageBoxButton.innerText = "";
}
}
- populateMessagebox();
+ this._populateMessagebox();
+ Services.obs.addObserver(this, TorConnectTopics.StateChange);
+
// update the messagebox whenever we come back to the page
window.addEventListener("focus", val => {
- populateMessagebox();
+ this._populateMessagebox();
});
// Heading
@@ -571,6 +578,7 @@ const gTorPane = (function() {
uninit() {
// unregister our observer topics
Services.obs.removeObserver(TorSettingsTopics.SettingChanged, this);
+ Services.obs.removeObserver(TorConnectTopics.StateChange, this);
},
// whether the page should be present in about:preferences
@@ -582,15 +590,24 @@ const gTorPane = (function() {
// Callbacks
//
- // callback for when the quickstart pref changes
observe(subject, topic, data) {
- if (topic === TorSettingsTopics.SettingChanged) {
- let obj = subject?.wrappedJSObject;
- switch(data) {
- case TorSettingsData.QuickStartEnabled: {
- this._enableQuickstartCheckbox.checked = obj.value;
- break;
+ switch (topic) {
+ // triggered when a TorSettings param has changed
+ case TorSettingsTopics.SettingChanged: {
+ let obj = subject?.wrappedJSObject;
+ switch(data) {
+ case TorSettingsData.QuickStartEnabled: {
+ this._enableQuickstartCheckbox.checked = obj.value;
+ break;
+ }
}
+ break;
+ }
+ // triggered when tor connect state changes and we may
+ // need to update the messagebox
+ case TorConnectTopics.StateChange: {
+ this._populateMessagebox();
+ break;
}
}
},
diff --git a/browser/components/torpreferences/content/torPreferences.css b/browser/components/torpreferences/content/torPreferences.css
index 47b8ff18e0af..e3cc429f5982 100644
--- a/browser/components/torpreferences/content/torPreferences.css
+++ b/browser/components/torpreferences/content/torPreferences.css
@@ -87,14 +87,15 @@
border-radius: 2px;
border: 0;
- padding-left: 8px;
- padding-right: 8px;
+ padding: 0px 8px;
margin-left: auto;
margin-right: 0px;
font-size: 11px;
- font-weight: 400;
+ font-weight: 600;
white-space: nowrap;
+
+ color: white;
}
#torPreferences-connectMessageBox.error #torPreferences-connectMessageBox-button {
@@ -115,12 +116,10 @@
#torPreferences-connectMessageBox.warning #torPreferences-connectMessageBox-button:hover {
background-color: var(--purple-80);
- color: white!important;
}
#torPreferences-connectMessageBox.warning #torPreferences-connectMessageBox-button:active {
background-color: var(--purple-90);
- color: white!important;
}
/* Advanced Settings */
diff --git a/browser/modules/TorConnect.jsm b/browser/modules/TorConnect.jsm
index f2c92dcb8f21..ddc14148eb88 100644
--- a/browser/modules/TorConnect.jsm
+++ b/browser/modules/TorConnect.jsm
@@ -329,8 +329,8 @@ const TorConnect = (() => {
return (TorProtocolService.ownsTorDaemon &&
// and we're not using the legacy launcher
!TorLauncherUtil.useLegacyLauncher &&
- // legacy checks, TODO: maybe this should be in terms of our own state?
- (TorProtocolService.isNetworkDisabled() || !TorProtocolService.isBootstrapDone()));
+ // if we have succesfully bootstraped, then no need to show TorConnect
+ this.state != TorConnectState.Bootstrapped);
},
get shouldQuickStart() {
@@ -420,8 +420,13 @@ const TorConnect = (() => {
Further external commands and helper methods
*/
openTorPreferences: function() {
- const win = BrowserWindowTracker.getTopWindow()
- win.openTrustedLinkIn("about:preferences#tor", "tab");
+ const win = BrowserWindowTracker.getTopWindow();
+ win.switchToTabHavingURI("about:preferences#tor", true);
+ },
+
+ openTorConnect: function() {
+ const win = BrowserWindowTracker.getTopWindow();
+ win.switchToTabHavingURI("about:torconnect", true, {ignoreQueryString: true});
},
copyTorLogs: function() {
More information about the tor-commits
mailing list