When a webpage fails to load, it can be due to any number of factors. But when that page is served by an onion service, some of those factors have greater implications for security.
It would be cool to know if the failure is related to a malfunction in the local Tor instance, or due to nonlocal failures. If TBB can determine this, adding something to TBB to create .onion specific error messages with greater detail would be helpful.
To upload designs, you'll need to enable LFS and have an admin enable hashed storage. More information
Child items 0
Show closed items
No child items are currently assigned. Use child items to break down this issue into smaller parts.
Linked items 0
Link issues together to show that they're related.
Learn more.
We want to improve the way we communicate with users that there is an error trying to visiting an onion service. We have a good opportunity for sharing educational points and for being more transparent with users, offering them information about the kind of error they are experiencing.
We can provide more informative error messages indicating better whether the issue was on the service-side, on the client-side, or the network-side. We can do it without being overwhelming or patronizing but clear about the information we are spreading.
To illustrate this complexity, we can use a diagram of the connection and show where the error happened. I thought about isabela's idea in #23486 (moved) and I think we can have a kind of step-by-step graph here as well.
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
TODO
UI: Make the UI for each error scenario.
Content: Define the content for each page. This information also needs to have an entry at support.tpo.org and tb-manual? Onion services documentation?. We will need to l10nize it.
User Testing: Once this reaches a nightly, I'd like to share with our testing pool of users for feedback.
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
I think the concept is reasonable, but I don't have much insight on how good this will be for users VS other options that I can't imagine right now. e.g. I'm not sure if people will be helped by knowing that the problem is on the network or not.
Leaving that aside, and assuming that the idea is the best one (which is fine by me), I need to say that sometimes it's not clear where the error is (e.g. in 'F2' and 'F3' where the intro/rend fails, it's not clear whether the problem is on the network or the service itself), so in those cases I'm not sure which button should light up. I think it would be a bad idea to tell users that the problem is on the service, when actually it's just a bad rendezvous point and it would be solved by reconnecting. And given that 'F2' and 'F3' are hard to classify, and 'F1' should never really appear, I'm not sure what would be the class of 'network-level errors'.
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
I think the concept is reasonable, but I don't have much insight on how good this will be for users VS other options that I can't imagine right now. e.g. I'm not sure if people will be helped by knowing that the problem is on the network or not.
Leaving that aside, and assuming that the idea is the best one (which is fine by me), I need to say that sometimes it's not clear where the error is (e.g. in 'F2' and 'F3' where the intro/rend fails, it's not clear whether the problem is on the network or the service itself), so in those cases I'm not sure which button should light up. I think it would be a bad idea to tell users that the problem is on the service, when actually it's just a bad rendezvous point and it would be solved by reconnecting. And given that 'F2' and 'F3' are hard to classify, and 'F1' should never really appear, I'm not sure what would be the class of 'network-level errors'.
I've been noticing the cloudflare error pages much more lately, and I actually like how they present the problem. I think it would work nicely (altho we would need to think of the technical issues detailed above).
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
On the implementation side, it should be possible to add a new internal error page (e.g., about:onionerror) and have code that changes its look using CSS and JS. Using that approach i should be straightforward to include the three-part graphic (Browser / Tor Network / Host)... but we need to resolve the issues raised in comment:8.
Maybe the graphic does not add much value and we should instead focus on creating good textual descriptions with actionable advice.
Implementation would be be easier if we could reuse Firefox's existing about:neterror page layout and elements. Maybe that is not feasible if we decided to keep the Browser / Tor Network / Host graphic though, because Mozilla only includes a graphic on the left side. Load this link to see an example:
about:neterror?e=dnsNotFound&d=We%20can't%20connect%20to%20the%20server%20at%20foozat.com
If we do keep the three-part graphic, do you think it would be an improvement to change the Host label to Onion Site?
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
I think the concept is reasonable, but I don't have much insight on how good this will be for users VS other options that I can't imagine right now. e.g. I'm not sure if people will be helped by knowing that the problem is on the network or not.
With "network-level" errors, I think if that we can at least rule out that the issue lies with the browser, then we can suggest a number of strategies to users e.g to try to reconnect to the service, in order to help them out
Leaving that aside, and assuming that the idea is the best one (which is fine by me), I need to say that sometimes it's not clear where the error is (e.g. in 'F2' and 'F3' where the intro/rend fails, it's not clear whether the problem is on the network or the service itself), so in those cases I'm not sure which button should light up. I think it would be a bad idea to tell users that the problem is on the service, when actually it's just a bad rendezvous point and it would be solved by reconnecting. And given that 'F2' and 'F3' are hard to classify, and 'F1' should never really appear, I'm not sure what would be the class of 'network-level errors'.
In that case we should define what these graphics would look like for each of the error codes that we know tor will surface to the browser. I think it's fine to show some ambiguity in the graphics (e.g a question mark instead of a tick or a cross at the Tor Network and Host icons) as long as we suggest some next steps for the user, depending on the error code.
I think a good next step would be to map all of these out together and see what comes out.
What do you think? Is the graph accurate? Could it work for each scenario? Is it too complicated to have custom error pages for each scenario? I see it feasible with just CSS, but is it doable on the browser side?
On the implementation side, it should be possible to add a new internal error page (e.g., about:onionerror) and have code that changes its look using CSS and JS. Using that approach i should be straightforward to include the three-part graphic (Browser / Tor Network / Host)... but we need to resolve the issues raised in comment:8.
Maybe the graphic does not add much value and we should instead focus on creating good textual descriptions with actionable advice.
I think the three-part graphic is very useful to educate users about a) where the problem lies b) how onion services work. Also, remember we have the user testing program to test these options out.
Implementation would be be easier if we could reuse Firefox's existing about:neterror page layout and elements. Maybe that is not feasible if we decided to keep the Browser / Tor Network / Host graphic though, because Mozilla only includes a graphic on the left side. Load this link to see an example:
about:neterror?e=dnsNotFound&d=We%20can't%20connect%20to%20the%20server%20at%20foozat.com
We should try to keep it if we can. If it is going to take significantly longer to do than a simpler error page, we should evaluate doing a first, simple iteration with the aim of implementing this later on, once the S27 project is over.
If we do keep the three-part graphic, do you think it would be an improvement to change the Host label to Onion Site?
Implementation would be be easier if we could reuse Firefox's existing about:neterror page layout and elements. Maybe that is not feasible if we decided to keep the Browser / Tor Network / Host graphic though, because Mozilla only includes a graphic on the left side. Load this link to see an example:
about:neterror?e=dnsNotFound&d=We%20can't%20connect%20to%20the%20server%20at%20foozat.com
Yes for sure. We can re-use about:neterror. I do think the 3 steps graph is very useful for users, but if we decide that such implementation is out-of-scope, then we can move forward with just a title and a description.
If we do keep the three-part graphic, do you think it would be an improvement to change the Host label to Onion Site?
Yes, it's a great idea.
Did you decide against a vertical arrangement for the browser/network/onion service graphics? (Maybe it's not workable)
Antonela — in case it matters, Kathy and I think we have found a way to make a horizontal layout work within the existing about:netError page. I assume for a RTL locale we just want to reverse the order of the 3 images?
Hi! I've iterated over the originally proposed icons set and I'd like your feedback on that.
Basically, we've been discussing that using the onion icon would confuse users, so a regular cloud and server reference may help on illustrating these errors.
Also, as suggested in comment:12, I do think we should go with Onionsite. Do you think is better to have it as one-word like "website" or is it better to have two words like Onion Site. I think the former is nicer.
Personally I like the thinner lines in the "A" line for the browser and onionsite graphics (as compared to the "C" line). In particular, the fat lines of the browser window makes the toolbar seem disproportionately large.
I'm concerned that using a cloud graphic may confuse users about what the Tor Network is. I think many users will think of a cloud (on the Internet) as the place where they store images and files rather than the network. We should also be careful about reusing the Tor Browser icon to represent Network or Onionsite. Ticket #23486 (moved) includes some other ideas for icons, although our design ideas have evolved since that ticket was updated.
For "onion site" vs "onionsite", I'm ok with either term. I am curious how "website" localizes. If we are coining a new term in English ("onionsite") will our translators be able to create an equivalent term in their language? I assume they can handle it, but maybe we should check with emmapeel.
I'm back here to commenting the UI specs. So, I've uploaded two options. I think we are OK having everything on a grayscale. If that is the path we are taking, everything looks clean and clear if we use the same color for the icon and for the status container. I added a 3px solid border around it to make the shape outstand.
It seems that the error pages (about:netError) do not currently support a dark theme; at least on macOS, the colors used on that page do not change when in dark mode. Kathy and I cannot find a Bugzilla bug for that issue, but we think we should skip dark theme support for now.
We tried using the Grey 90 a80 color, but we need to avoid transparency. With transparency, the Browser/Network/Onionsite images show through the circles that surround the checkmark and (x) icons, and the Onionsite image is not a consistent color (apparently, some of the paths within the SVG overlap). Here is what it looks like with Grey 70 (no transparency); Kathy and I think the result is close to your mockup:
While we are waiting for strings (#33035 (moved)), Kathy and I think it would be OK to do a first round of reviews of the implementation.
For Torbutton we added strings for the error pages (currently, most of them are placeholders and therefore they are not ready for translation).
For the browser, we did the following:
Added an OnionServicesAboutNetError module which enhances Firefox's built-in about:netError page to add descriptive text that is tailored to each onion service error as well as a visual diagram to help people understand where the error occurred.
Added support for two additional SOCKS extended errors: SOCKS5_HS_BAD_ADDRESS (typo in .onion address) and SOCKS5_HS_INTRO_TIMEDOUT (introduction timed out).
Made changes to the onion service authentication prompt logic so the browser displays an appropriate error page after the prompt is canceled.
I am taking this out of review for now because Kathy and I found a bug in the browser patch (in browser/components/onionservices/content/authUtil.jsm the reference to this.string.clientAuthMissingTopic needs to be replaced with this.topic.clientAuthMissing). Hopefully we will have the English strings soon (from #33035 (moved)) so we can put them in a revised patch as well.
Trac: Status: needs_review to needs_revision Keywords: TorBrowserTeam202002R deleted, TorBrowserTeam202002 added
We rebased the patches (to torbutton master and to the tor-browser-68.5.0esr-9.5-1 branch), incorporated the final English strings from #33035 (moved), and fixed a couple of minor issues. We also removed the "Learn More" links for now. Here are the patches:
The patches look good to me. Just a couple of nits for onionNetError.jsm:
Shouldn't this._insertStylesheet be after the errPrefix check? (so that the stylesheet is not added for non-onion errors).
Can't we just do ld.textContent = longDescription.replace("%S", hexErr); instead of using innerHTML (and remove the eslint-disable), or longDescription may contain HTML?
The patches look good to me. Just a couple of nits for onionNetError.jsm:
Shouldn't this._insertStylesheet be after the errPrefix check? (so that the stylesheet is not added for non-onion errors).
Good catch. We will move it and post a revised patch once we receive review comments from Richard.
Can't we just do ld.textContent = longDescription.replace("%S", hexErr); instead of using innerHTML (and remove the eslint-disable), or longDescription may contain HTML?
Since we are not currently using any markup in that field we could use the textContent property. Or we could keep it as we wrote it and match Mozilla. What do other people think?
Since we are not currently using any markup in that field we could use the textContent property. Or we could keep it as we wrote it and match Mozilla. What do other people think?
During today's Sponsor 27 IRC meeting, we decided to match Mozilla and keep support for HTML.
JavaScript has a Map type now ( https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map ), and I think (?) it's best practice to use them rather than the old Object with named fields pattern (for instance, in diagramInfoMap in _insertDiagram()). I know acat gave similar feedback on one of my patches at some point but I don't quite remember the justification.
hexErrorFromName could be reduced by having the returns under each case, rather than assign && break but I don't feel particularly strongly about it.
Thank you for the reviews. Kathy and I made the suggested changes: we moved the this._insertStylesheet() call later plus we addressed everything from comment:43. We also rebased both patches on top of the latest tor-browser and Torbutton code. There were no actual changes to the Torbutton patch. New patches:
I would say make diagramInfoMap a member variable of OnionServicesAboutNetError to avoid rebuilding it each time _insertDiagram is called. Apart from that, looks good to me.
I would say make diagramInfoMap a member variable of OnionServicesAboutNetError to avoid rebuilding it each time _insertDiagram is called. Apart from that, looks good to me.
I would say make diagramInfoMap a member variable of OnionServicesAboutNetError to avoid rebuilding it each time _insertDiagram is called. Apart from that, looks good to me.