[tor-commits] [Git][tpo/applications/tor-browser][tor-browser-115.10.0esr-13.5-1] 2 commits: fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in...
Pier Angelo Vendrame (@pierov)
git at gitlab.torproject.org
Mon Apr 22 07:22:27 UTC 2024
Pier Angelo Vendrame pushed to branch tor-browser-115.10.0esr-13.5-1 at The Tor Project / Applications / Tor Browser
Commits:
a9c02248 by Henry Wilkes at 2024-04-22T07:22:05+00:00
fixup! Bug 31286: Implementation of bridge, proxy, and firewall settings in about:preferences#connection
Bug 42533: Only update the internal loxId *after* the Lox.activeLoxId
has changed. In particular, we want to ensure that the data associated
with the new loxId (invites and event data) is set before we fetch them.
- - - - -
4006866f by Henry Wilkes at 2024-04-22T07:22:05+00:00
fixup! Lox integration
Bug 42533: Add notification for when the activeLoxId changes.
- - - - -
3 changed files:
- browser/components/torpreferences/content/connectionPane.js
- browser/components/torpreferences/content/loxInviteDialog.js
- toolkit/components/lox/Lox.sys.mjs
Changes:
=====================================
browser/components/torpreferences/content/connectionPane.js
=====================================
@@ -1317,6 +1317,7 @@ const gLoxStatus = {
});
Services.obs.addObserver(this, TorSettingsTopics.SettingsChanged);
+ Services.obs.addObserver(this, LoxTopics.UpdateActiveLoxId);
Services.obs.addObserver(this, LoxTopics.UpdateEvents);
Services.obs.addObserver(this, LoxTopics.UpdateNextUnlock);
Services.obs.addObserver(this, LoxTopics.UpdateRemainingInvites);
@@ -1333,6 +1334,7 @@ const gLoxStatus = {
*/
uninit() {
Services.obs.removeObserver(this, TorSettingsTopics.SettingsChanged);
+ Services.obs.removeObserver(this, LoxTopics.UpdateActiveLoxId);
Services.obs.removeObserver(this, LoxTopics.UpdateEvents);
Services.obs.removeObserver(this, LoxTopics.UpdateNextUnlock);
Services.obs.removeObserver(this, LoxTopics.UpdateRemainingInvites);
@@ -1343,12 +1345,17 @@ const gLoxStatus = {
switch (topic) {
case TorSettingsTopics.SettingsChanged:
const { changes } = subject.wrappedJSObject;
- if (
- changes.includes("bridges.source") ||
- changes.includes("bridges.lox_id")
- ) {
+ if (changes.includes("bridges.source")) {
this._updateLoxId();
}
+ // NOTE: We do not call _updateLoxId when "bridges.lox_id" is in the
+ // changes. Instead we wait until LoxTopics.UpdateActiveLoxId to ensure
+ // that the Lox module has responded to the change in ID strictly
+ // *before* we do. In particular, we want to make sure the invites and
+ // event data has been cleared.
+ break;
+ case LoxTopics.UpdateActiveLoxId:
+ this._updateLoxId();
break;
case LoxTopics.UpdateNextUnlock:
this._updateNextUnlock();
@@ -1378,9 +1385,7 @@ const gLoxStatus = {
*/
async _updateLoxId() {
let loxId =
- TorSettings.bridges.source === TorBridgeSource.Lox
- ? TorSettings.bridges.lox_id
- : "";
+ TorSettings.bridges.source === TorBridgeSource.Lox ? Lox.activeLoxId : "";
if (loxId === this._loxId) {
return;
}
=====================================
browser/components/torpreferences/content/loxInviteDialog.js
=====================================
@@ -104,6 +104,7 @@ const gLoxInvites = {
// NOTE: TorSettings should already be initialized when this dialog is
// opened.
Services.obs.addObserver(this, TorSettingsTopics.SettingsChanged);
+ Services.obs.addObserver(this, LoxTopics.UpdateActiveLoxId);
Services.obs.addObserver(this, LoxTopics.UpdateRemainingInvites);
Services.obs.addObserver(this, LoxTopics.NewInvite);
@@ -119,6 +120,7 @@ const gLoxInvites = {
*/
uninit() {
Services.obs.removeObserver(this, TorSettingsTopics.SettingsChanged);
+ Services.obs.removeObserver(this, LoxTopics.UpdateActiveLoxId);
Services.obs.removeObserver(this, LoxTopics.UpdateRemainingInvites);
Services.obs.removeObserver(this, LoxTopics.NewInvite);
},
@@ -127,13 +129,13 @@ const gLoxInvites = {
switch (topic) {
case TorSettingsTopics.SettingsChanged:
const { changes } = subject.wrappedJSObject;
- if (
- changes.includes("bridges.source") ||
- changes.includes("bridges.lox_id")
- ) {
+ if (changes.includes("bridges.source")) {
this._updateLoxId();
}
break;
+ case LoxTopics.UpdateActiveLoxId:
+ this._updateLoxId();
+ break;
case LoxTopics.UpdateRemainingInvites:
this._updateRemainingInvites();
break;
@@ -155,9 +157,7 @@ const gLoxInvites = {
*/
_updateLoxId() {
const loxId =
- TorSettings.bridges.source === TorBridgeSource.Lox
- ? TorSettings.bridges.lox_id
- : "";
+ TorSettings.bridges.source === TorBridgeSource.Lox ? Lox.activeLoxId : "";
if (!loxId || (this._loxId !== null && loxId !== this._loxId)) {
// No lox id, or it changed. Close this dialog.
this._dialog.cancelDialog();
=====================================
toolkit/components/lox/Lox.sys.mjs
=====================================
@@ -55,6 +55,8 @@ XPCOMUtils.defineLazyModuleGetters(lazy, {
});
export const LoxTopics = Object.freeze({
+ // Whenever the activeLoxId value changes.
+ UpdateActiveLoxId: "lox:update-active-lox-id",
// Whenever the bridges *might* have changed.
// getBridges only uses #credentials, so this will only fire when it changes.
UpdateBridges: "lox:update-bridges",
@@ -141,6 +143,10 @@ class LoxImpl {
*/
#activeLoxId = null;
+ get activeLoxId() {
+ return this.#activeLoxId;
+ }
+
/**
* Update the active lox id.
*/
@@ -164,6 +170,8 @@ class LoxImpl {
this.#store();
}
this.#activeLoxId = loxId;
+
+ Services.obs.notifyObservers(null, LoxTopics.UpdateActiveLoxId);
}
observe(subject, topic, data) {
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/00e009df2d38975ffa60f64a6fd8e9d4e60787a7...4006866f6958a8a127496203bcb90011fecbbd9e
--
This project does not include diff previews in email notifications.
View it on GitLab: https://gitlab.torproject.org/tpo/applications/tor-browser/-/compare/00e009df2d38975ffa60f64a6fd8e9d4e60787a7...4006866f6958a8a127496203bcb90011fecbbd9e
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/20240422/8de14728/attachment-0001.htm>
More information about the tor-commits
mailing list