[tbb-bugs] #31286 [Applications/Tor Browser]: Include bridge configuration into about:preferences

Tor Bug Tracker & Wiki blackhole at torproject.org
Wed Oct 2 18:46:23 UTC 2019


#31286: Include bridge configuration into about:preferences
-------------------------------------------------+-------------------------
 Reporter:  gk                                   |          Owner:
                                                 |  pospeselr
     Type:  task                                 |         Status:
                                                 |  needs_revision
 Priority:  High                                 |      Milestone:
Component:  Applications/Tor Browser             |        Version:
 Severity:  Normal                               |     Resolution:
 Keywords:  tbb-9.0-must-alpha, ff68-esr, ux-    |  Actual Points:
  team, TorBrowserTeam201910                     |
Parent ID:  #10760                               |         Points:  15
 Reviewer:                                       |        Sponsor:
                                                 |  Sponsor44-can
-------------------------------------------------+-------------------------
Changes (by acat):

 * keywords:  tbb-9.0-must-alpha, ff68-esr, ux-team, TorBrowserTeam201910R
     => tbb-9.0-must-alpha, ff68-esr, ux-team, TorBrowserTeam201910
 * status:  needs_review => needs_revision


Comment:

 Nice work!

 I'm assuming we agree that we should follow mozilla coding style/practices
 for our JS code in tor-browser. If not, I think we should at least discuss
 it :) I haven't found a document that explains these in depth (other than
 https://developer.mozilla.org/en-
 US/docs/Mozilla/Developer_guide/Coding_Style#JavaScript_practices). But I
 think passing ESlint should be already a good start.

 Other than that, I'm not sure how we should decide about JS coding
 conventions and practices that are not explicitly checked in ESLint. For
 example, there is #26184 which I agree with (we should use `const`
 whenever possible, and `let` otherwise).

 In any case, I'm suggesting some general (non-exhaustive) JS practices
 which I think are good. If we would agree, we could perhaps make these
 explicit somewhere?

 1. I personally think that using classes instead of the old "function +
 .prototype.*" idiom is preferable. For example, I find

 {{{
 class TorBridgeSettings {
   constructor() {
     this._bridgeSource = TorBridgeSource.NONE;
     this._selectedDefaultBridgeType = null;
     this._bridgeStrings = [];
   }

   get selectedDefaultBridgeType() { ... }

   static get defaultBridgeTypes() { ... }

   readDefaultBridges() { ... }

   ...
 }
 }}}

 to be more readable than the `function TorBridgeSettings` version. For me
 it is much easier to see what is a class (needs to be instantiated with
 `new`) and what is just a 'regular' function, and also I find it less
 noisy, since you don't need to use all those `.prototype = function() {`
 over and over again. But converting these to class syntax should not be a
 blocker right now, I think.

 2. In the code, I see that some functions (not classes) and methods are
 capitalized and some are not. This also happens with code in `torbutton`
 and `tor-launcher`, but in general I think the convention with JS is that
 functions, methods and property names should be camel-case but not
 capitalized. That's also the case with JS code in Firefox, I think.

 3. We should use `const` whenever possible, and `let` otherwise (#26184
 +1).

 4. I think `for (const x of y) {...}` is preferrable to `y.forEach(x =>
 {...}` (faster, and control flow like `break`, `return`, `continue`,
 `await`... work as one would expect).

 5. I think strict (in)equality operators should (always?) be used (`!= ->
 !==`, `==` -> `===`).

 6. We should use .jsm modules whenever possible, and only use "XUL"
 scripts (not sure how to call them, basically all the ones in
 '/content/*') when strictly needed. *.jsm scripts allow for explicit
 importing and exporting, and we do not have to worry about variables and
 functions going to the global scope, etc. Besides, *.jsm exports can be
 imported in other *.jsm but also in *.xul scripts, which is not true with
 exports in *.xul scripts.

 ----

 I have not yet done a in-depth testing of the build, but I did a first
 pass on the code:

 * moz.build

   I'm not sure torstrings should be a component. My understanding is that
 components have something to do with UI, and it's not the case of
 torstrings. More comments later on `torstrings/content/torStrings.js`.

 * preferences/in-content/preferences.js

   Should be `/* import-globals-from
 ../../tornetworksettings/content/torNetworkPane.js */`, that fixes a
 `gTorPane is undefined` eslint error.

 * tornetworksettings/content/torBridgeDB.js

   Why not `tornetworksettings/TorBridgeDB.jsm`? Don't see it needs window
 or does anything with UI.

   In
     {{{
       let svc = Cc["@torproject.org/torlauncher-protocol-
 service;1"].getService(
         Ci.nsISupports
       );
       let gProtocolSvc = svc.wrappedJSObject;
     }}}
   Why not just:
     {{{
       let gProtocolSvc = Cc["@torproject.org/torlauncher-protocol-
 service;1"].getService(
         Ci.nsISupports. wrappedJSObject
       );
     }}}

 * tornetworksettings/content/torBridgeSettings.js:

   Again, I think it should be a jsm module.

   typos: `basd`, `abotu:config`

   It looks a bit strange that `TorBridgeSettings.DefaultBridgeTypes =
 function() {` is a static function while the previous are getters. If the
 class syntax was used, you would be able to do `static get
 DefaultBridgeTypes() {}` and easily make it a getter as the others :)

   {{{
     // treat as an unordered set for shoving bridge types into
     let bridgeTypes = {};
   }}}
   Better to use a `Set` for this I think.

   `key.indexOf(aBridgeType) == 0` -> `key.startsWith(aBridgeType)`

   In `TorBridgeSettings.prototype._readTorrcBridges = function() {`,
 `retval` is declared outside an if, but only used inside. Besides, the
 function can return either `false`, `Array` or `undefined`, I think it
 would be better to explicitly return at the end. Actually, should this
 function always return an array? Otherwise in
 `TorBridgeSettings.prototype.ReadSettings` (and perhaps others) it will
 fail, since it's expecting an array (`torrcBridges.length`). BTW, the
 `reply.lineArray.forEach` block can be written as `reply.lineArray.map(x
 => x.trim()).filter(x => x)`, which is more compact, although I'm not
 completely sure which one is more readable.

   `TorNoBridgeSettings`, `TorBuiltinBridgeSettings`,
 `TorBridgeDBBridgeSettings`, `TorUserProvidedBridgeSettings`: I would
 suggest following the convention of only capitalizing class names.
 Besides, perhaps we could add a prefix like `makeTorNoBridgeSettings` or
 `createTorNoBridgeSettings`? I think it makes it clearer that these are
 factory functions.

 * tornetworksettings/content/torFirewallSettings.js:
   * jsm module?
   * can we move `parseAddrPortList` to some module and explicitly import
 it wherever it's needed?
   * `TorEmptyFirewallSettings`, `TorCustomFirewallSettings`: same comment
 regarding factory functions as above.

 * tornetworksettings/content/torNetworkCategory.inc.xul:
   * This is currently localized with Fluent, I guess we should decide what
 to do with this. I'm not sure we can use fluent yet (not supported by
 transifex), so if we use good old DTD entities the `data-l10n` should go
 away.

 * tornetworksettings/content/torNetworkPane.js:
   * this one cannot be a JSM module, since it accesses `document` :)
   * typos: `brige`, `about:preferenes`
   * I would suggest moving `parsePort`, `parseAddrPort`,
 `parseUsernamePassword`, `parseAddrPortList`, `parseBridgeStrings`,
 `parsePortList` to some module and importing explicitly wherever it's
 needed.
   * I would replace `.innerHTML` by `.innerText`, it's safer.
   * eslint complains that several functions are undefined
 (`TorBridgeSource`, `TorBridgeSettings`, `TorProxyType`, ...) I would
 suggest importing them explicitly from the corresponding modules.

 * tornetworksettings/content/torNetworkPane.xul:
   * I think we should only need to load torNetworkPane.js here if we
 convert the others to jsm modules.

 * tornetworksettings/content/torProxySettings.js:
   * jsm module :)
   * typos: `addres`
   * same previous comments about factory methods.

 * torstrings/content/torStrings.js:
   * jsm module :)
   * It's also used in securitysettings, so perhaps we could move it to
 `browser/modules/TorStrings.jsm`?
 ----

 Should we support building with `--without-tor-launcher`? I mean disabling
 the `Tor Network Settings` UI if Tor Launcher is not available. I assume
 if one builds with that flag the UI in `about:preferences` will be
 slightly broken.

--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/31286#comment:29>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online


More information about the tbb-bugs mailing list