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

Origin specificity #46

Open
LuHuangMSFT opened this issue Jun 12, 2021 · 8 comments
Open

Origin specificity #46

LuHuangMSFT opened this issue Jun 12, 2021 · 8 comments

Comments

@LuHuangMSFT
Copy link

I understand from the explainer that currently the smallest possible FPS would include all origins of a single domain name. Would it be possible to include only specific origins from a single domain or from multiple different domains?

@krgovind
Copy link
Collaborator

That's an excellent question! Unfortunately, the current design doesn't allow for this. We did consider designing FPS so that it is specified as origins, see the alternative design section; but did not pursue it further due to complexity?

Could you explain further the motivation/use-case behind your question?

@krgovind
Copy link
Collaborator

Hi @LuHuangMSFT - just pinging this discussion to see if you are able to expand upon the motivation/use-case behind your question.

@LuHuangMSFT
Copy link
Author

LuHuangMSFT commented Aug 4, 2021

@krgovind Sorry I lost track of this issue.

I work on PWA features and would like be able to define a first party set of origins such that each of those origins can be treated as though they are part of the same app. Currently a PWA must be implemented within a single origin. If a PWA window navigates outside of that window, privacy/security considerations often require the window to show warning UI. This is unnecessary if the developer can configure first party origins. What's particular about PWAs is that it's a common pattern to structure them at subdomains like "app.domain.com" so it would be necessary to include individual origins. Imagine trying to create a PWA that spans app.domain.com, app.domain.co, app.domain.uk, app.domain.fr, and so on. When navigating the PWA window to URLs within first party origins, displaying UI that highlights URLs/origin boundaries would not be necessary and the user can be shown a more seamless, native-like app experience.

@krgovind
Copy link
Collaborator

krgovind commented Aug 4, 2021

@LuHuangMSFT Could you expand on the warning UI that is displayed? Is it a warning displayed by the browser, or by the destination origin? Or perhaps, were you referring to how a cross-origin navigation inside a PWA can result in the opening of the destination in a Custom Tab?

@LuHuangMSFT
Copy link
Author

referring to how a cross-origin navigation inside a PWA can result in the opening of the destination in a Custom Tab?

Yes, that's the example I was thinking about. The Custom Tab solution isn't required by any web spec. so there could be other solutions to make the user aware about cross-origin or out-of-app-scope navigation in PWA windows.

The general problem I would like to solve is to allow the creation of a multi-origin PWA (whether of origins from the same domain or from multiple different domains.) This can be either 1.) implicit: the browser detects a FPS and allows the app window
to navigate freely to URLs within the FPS, or 2.) explicitly: the PWA developer specifies multiple origins for the app scope, and the browser must verify that there is a suitable FPS. The origins involved need to validate the relationship for a multi-origin PWA concept to work.

@davidben
Copy link
Contributor

davidben commented Aug 4, 2021

I'm not familiar with the PWA setup, but the latter (explicit) seems preferable to me. If we overload FPS with lots of meanings, we'll weaken privsep. Suppose a site says "from this PWA, origins A, B, C are allowed to do something, but in the context of XSRF protections on this particular resource, I want C, D, E". If those all use FPS implicitly, it would need to contain the union and we'd end up with weaker protections.

More explicit strategies avoid this. And then, where the feature has cross-site tracking implications, a same-site/FPS/whatever check can be layered in addition to what the site declared.

@krgovind
Copy link
Collaborator

krgovind commented Aug 4, 2021

+1 to what @davidben wrote.

For the case of PWAs, something explicit like scope_extensions would indeed be preferable.

We had a similar discussion about how FPS could apply to cache partitioning, where we concluded that an explicit opt-in is preferable because there are side-channel/security implications.

@LuHuangMSFT
Copy link
Author

LuHuangMSFT commented Aug 4, 2021

The scope_extensions proposal as it is currently written relies on the web-app-origin-association format (originally proposed at https://github.com/WICG/pwa-url-handler/blob/main/explainer.md#web-app-origin-association-file) to perform the 2-way handshake between a PWA and an origin. Appreciate any feedback either of you may have for that proposed format since there may be some overlap in functionality with First Party Sets. One discussed usage of scope_extensions is to allow seamless navigation in an app window between participating origins without showing CCT or equivalent UI.

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

No branches or pull requests

3 participants