This repository has been archived by the owner on Jan 4, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 109
Dynamic per-request / per-session / per-site-instance proxy configuration #464
Comments
discussed in-person and in slack. we are going to start with per-session proxies instead of per request. |
diracdeltas
changed the title
Dynamic per-request proxy configuration
Dynamic per-request or per-session proxy configuration
Jan 30, 2018
I'm not sure if this is really that complicated. You can call |
@bridiver Will calling |
diracdeltas
changed the title
Dynamic per-request or per-session proxy configuration
Dynamic per-request / per-session / per-site-instance proxy configuration
Jan 31, 2018
Added option 5 which is what @darkdh is currently working on |
darkdh
added a commit
that referenced
this issue
Feb 1, 2018
… options fix #468 fix #464 Auditors: @bridiver, @riastradh-brave, @diracdeltas
Merged
done in #473 |
Sign up for free
to subscribe to this conversation on GitHub.
Already have an account?
Sign in.
In order to isolate circuits for different first-party origins, we need to dynamically choose the proxy configuration (using SOCKS5 authentication as in #462) for each request as a function of the first-party origin, the session, and some state.
The state is necessary so that we can implement a 'New Tor circuit for this site' button that, in addition to flushing cookies and other local state for the site, causes all subsequent requests to use a different Tor circuit.
For example, if I'm browsing Wikipedia about Marxist revolutionary movements in Bulgarian, Brave should use the proxy
socks5://bg.wikipedia.org:[email protected]:9050
for all those requests. If, at the same time, I'm browsing the London School of Economics grad school application site, we should use the proxysocks5://lse.ac.uk:[email protected]:9050
so that even if there's an image on that site hosted by Wikimedia Commons also used by one of the Bulgarian Marxist Wikipedia pages, the requests for these will be uncorrelated and nobody will connect my ulterior motives in grad school.Then if I want to read about explosives on Bulgarian Wikipedia, but don't want to reveal it's connected to the Marxist revolutionary movements, the 'New Tor circuit for this site' button should cause all subsequent requests to use
socks5://bg.wikipedia.org:[email protected]:9050
. Here the username is the first-party origin; the password is a string generated independently at random for each session, each site, and each time the user hits the 'New Tor circuit for this site' button.(In the long term, the 'New Tor circuit for this site' may or may not be how we want to isolate browsing; see brave/browser-laptop#12922 to track these UX questions.)
This is tricky because the byzantine maze of proxy configuration abstractions in src/net/proxy is not really designed to keep state. The draft in my Tor branch just sets a static proxy configuration for now.
Here are a few approaches that we might try:
Write a proxy autoconfig script, either with data: URL or a local file: URL.
Write logic in browser-laptop to intercept all requests using session.webRequest.onBeforeRequest and replace the proxy configuration for that one request, with state in the main context. (This is extend session.webRequest.onBeforeRequest to support a proxy URL #463.)
Write a ProxyResolver in net/proxy in C++ for Tor sessions, possibly modelled after the per-OS system proxy resolvers.
Give each first-party origin its own session object (in the sense of
electron.session
). As a bonus, this obviates the need to implement third-party isolation in various things like cookie stores, local storage, etc., wherever we haven't done so already. Then we can just use a static proxy configuration in each session on its own with no changes to C++ code. (This would make it more of a browser-laptop issue than a muon issue, but I already made the issue here.)Use
BrowserContext::CreateRequestContextForStoragePartition
to create a proxy per storage partition / Site Instance, and setShouldUseProcessPerSite
to true for the Tor browser context in order to ensure that different origins do not share a Site Instance.The text was updated successfully, but these errors were encountered: