[tor-bugs] #17248 [Tor Browser]: Investigate new WebExtensions API requirements for our extensions
Tor Bug Tracker & Wiki
blackhole at torproject.org
Thu Nov 12 15:55:57 UTC 2015
#17248: Investigate new WebExtensions API requirements for our extensions
----------------------------------+--------------------------
Reporter: gk | Owner: tbb-team
Type: task | Status: new
Priority: High | Milestone:
Component: Tor Browser | Version:
Severity: Normal | Resolution:
Keywords: TorBrowserTeam201511 | Actual Points:
Parent ID: | Points:
Sponsor: |
----------------------------------+--------------------------
Changes (by brade):
* cc: mcs, brade (added)
* severity: => Normal
Comment:
Mark and I made a pass through Tor Launcher looking at API requirements.
I am going to post a series of comments that capture what we learned (this
is the first).
'''Requirements for which there is no solution / no Web Extensions API
(NS#):'''
NS1: Define and potentially override default preference values
Current Solution: defaults/preferences/prefs.js
NS2: Read, write, observe, and enumerate existing browser preferences
Current Solution: nsIPrefService/nsIPrefBranch and related APIs
NS3: Change the browser's UI locale without restart
Current Solution: Change the browser.useragent.locale preference and then
send a "chrome-flush-caches" observer notification
Notes: Used in Tor Launcher after the user choose a language
NS4: Localized HTML
Current Solution: XUL with localized entities
Related bugs: https://code.google.com/p/chromium/issues/detail?id=115800
NS5: Get notified just before the browser exits
Current Solution: Observer for "quit-application-granted"
Notes: Could count open and close of tabs but this will not work on Mac OS
NS6: Display a confirm prompt with custom button labels
Current Solution: nsIPromptService.confirmEx()
Notes: Used in Tor Launcher for the "Restart Tor?" prompt
NS7: Compare application version strings
Current Solution: nsIVersionComparator
Notes: We could create our own JS implemention or use third party code
such as https://github.com/linagora/mozilla-version-comparator
NS8: Check for existence, get, and set environment variables
Current Solution: nsIEnvironment
NS9: Log to stderr
Current Solution: window.dump()
NS10: TCP communication to the Tor control port
Current Solution: nsISocketTransportService.createTransport()
Notes: Tor Launcher uses non-blocking sockets as well as
nsIInputStream.asyncWait(). Also, in the future we want to be able to use
UNIX domain sockets.
NS11: Modal interaction before browser completely starts up
Current Solution: Modal dialogs opened from a "profile-after-change"
observer
Notes: The first time Tor Browser starts up, Tor Launcher displays a
configuration wizard. Every time Tor Browser starts up, a modal progress
dialog is displayed while a Tor network connection is established. It is
important that browser windows and menus are not shown until the startup
dialogs have closed.
--
Ticket URL: <https://trac.torproject.org/projects/tor/ticket/17248#comment:2>
Tor Bug Tracker & Wiki <https://trac.torproject.org/>
The Tor Project: anonymity online
More information about the tor-bugs
mailing list