Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Per-domain exclusions not excluding sites from isolation #607

Closed
JustEffy opened this issue Oct 18, 2022 · 6 comments
Closed

Per-domain exclusions not excluding sites from isolation #607

JustEffy opened this issue Oct 18, 2022 · 6 comments
Labels

Comments

@JustEffy
Copy link

temporary_containers_preferences_2022-10-18_19.03.00.json.txt
TCDebug.log

  • Temporary Containers Version: 1.9.2
  • Firefox Version: 105.0.3 (current in Linux Mint repos)

Actual behavior / Steps to reproduce

..
Make new profile, install Temporary Containers.
Turn on automatic mode, set all Global Isolation options to domain+subdomain.
Make per-domain rules for lowerclapton.nhs.uk and *.lowerclapton.nhs.uk, excluding practice365.co.uk and *.practice365.co.uk from isolation in each rule.
Visit lowerclapton.nhs.uk, click on any of the practice365.co.uk links, and instead of opening in the same temp container they open in a new one.

Expected behavior

..
"Domain Patterns added here will not get isolated if encountered in a Navigation or Mouse Click Isolation."
I was expecting to click through the practice365 links in the same temp container as the originating site, once I'd set up the exclusion rules.

In any case, thank you for TC, it's really good!

@stoically
Copy link
Owner

Unfortunately I can't reach lowerclapton.nhs.uk from here. There's no DNS entry available. Maybe it's Geo-locked?

However, it seems you found indeed a bug where the exclusion pattern does not properly take into account mouse clicks. If you configure the mouse clicks to Never for the per-domain isolation rules, it'll work as expected. Generally that's no issue, since navigation isolation always takes precedence over mouse click isolation – so if you have navigation isolation configured, configuring the same mouse click isolation rules has no effect. It only gets relevant if you configure different isolation behaviors.

@stoically stoically added the bug label Oct 19, 2022
@JustEffy
Copy link
Author

Ah, sorry, that's my bad! Should have been www.lowerclapton.nhs.uk . I'll try setting mouse clicks to Never and report back.

@JustEffy
Copy link
Author

temporary_containers_preferences_2022-10-19_17.27.51.json.txt
TCDebug2.log
Still seeing the same behaviour here

@stoically stoically changed the title Per-domain exclusions not excluding sites from isolation. Per-domain exclusions don't work for mouse clicks as expected Oct 19, 2022
@stoically stoically changed the title Per-domain exclusions don't work for mouse clicks as expected Per-domain exclusions not excluding sites from isolation Oct 19, 2022
@stoically
Copy link
Owner

Turns out they're doing funky double-redirects. You need to add *.lowerclapton.nhs.uk as exclusion pattern to the *.lowerclapton.nhs.uk per-domain isolation rule, then it works.

@stoically stoically added support and removed bug labels Oct 19, 2022
@JustEffy
Copy link
Author

JustEffy commented Oct 19, 2022

That works... I'm trying to get my head around what's happening so I can write rules correctly in future.

So, the redirect back from practice365 is triggering the *.lowerclapton rule (because... shenanigans? Is it still in the context of lowerclapton when it triggers?), but when the rule's actually being tested it's treating practice365 as the source and therefore not being allowed by the Global Different from Tab Domain & Subdomains rules that would allow lowerclapton pages to load other lowerclapton pages without triggering isolation?

And thank you for TC and for your help!

@stoically
Copy link
Owner

stoically commented Oct 19, 2022

Glad it works for you and thanks!

This looks like a race condition around the active tab domain. Looking at the logs, without the additional exclude:

[webRequestOnBeforeRequest] incoming request" {"requestId":"211","url":"https://practice365.co.uk/f84003/health-information/book-an-appointment/"
[shouldIsolateNavigation] not isolating because excluded domain pattern matches" "https://practice365.co.uk/f84003/health-information/book-an-appointment/" "practice365.co.uk"
[webRequestOnBeforeRequest] incoming request" {"requestId":"211","url":"https://www.lowerclapton.nhs.uk/health-information/book-an-appointment/
[shouldIsolateNavigation] found pattern" "*.lowerclapton.nhs.uk" {"action":"global"}
[checkIsolationPreferenceAgainstUrl]" "notsamedomain" "practice365.co.uk" "www.lowerclapton.nhs.uk"
[checkIsolationPreferenceAgainstUrl] isolating based on "notsamedomain"

It seems that at the point of comparing the domains, the tab updated to the practice365.co.uk domain – or, maybe, there's a bug because Firefox's request id stays the same and TC might do some naive caching there. Could be both I guess.

With the additional exclude it's

[shouldIsolateNavigation] not isolating because excluded domain pattern matches" "https://www.lowerclapton.nhs.uk/health-information/book-an-appointment/" "*.lowerclapton.nhs.uk

because it compares the full incoming request URL against the exclude patterns, not the active tab domain.

Overall the TC request/isolation handling could use some long overdue improvements, especially #397 would be nice. But, oh well, priorities.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

2 participants