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

Updating global config on root domain doesn't affect subdomain urls once SW is installed #91

Closed
2color opened this issue Mar 7, 2024 · 7 comments
Assignees
Milestone

Comments

@2color
Copy link
Member

2color commented Mar 7, 2024

Summary

Our current implementation of global configuration has a bug where updating the config on the root origin will not affect the configuration of a subdomain once the SW is installed.

This means that it's only possible to customise the configuration for a subdomain before the service worker is installed.

Reproduction

(Make sure you haven't loaded this CID prior. If you have, clear your browser storage for the origin)

  1. Load a subdomain url: https://bafybeiedlhslivmuj2iinnpd24ulx3fyd7cjenddbkeoxbf3snjiz3npda.ipfs.inbrowser.link
  2. Look at the configuration (should be default)
  3. Click "Load content"
  4. Go to inbrowser.link and change the gateway configuration
  5. Load the same subdomain url https://bafybeiedlhslivmuj2iinnpd24ulx3fyd7cjenddbkeoxbf3snjiz3npda.ipfs.inbrowser.link and you will see that the config changes are not affecting the service worker

Cause

The main cause for this seem to be the way that we pass config across subdomain origins, namely the postMessage call from the config iframe with the root url that is initially loaded on the subdomain.

After the SW is installed, there's no way for config updates to be passed to the subdomain origin.

image

Potential solution

We may want to introduce a special path for loading the config page, that can be detected by the SW and handled as a special case. For example /sw-config would render the config page even when loaded on the subdomain origin with the SW installed. This isn't optimal, given that there's no way for us to communicate it to users. Additionally there's a low risk of path collision if the CID also has a path /sw-config.

Besides this, I can't think of any other way to allow changing configuration once the SW is installed.

Side note

The main reason for the message passing is to enable global configuration on the root domain that when updated, impacts every CID loaded via subdomains. However, this approach has a several disadvantages:

  • inherent complexity making the code harder to reason about
  • iframes are blocked by brave
@2color
Copy link
Member Author

2color commented Mar 7, 2024

@lidel @SgtPooki Any thoughts on this?

@lidel
Copy link
Member

lidel commented Mar 7, 2024

For the problem at hand, mix of cookie + "magic path" might work and make sense.
There is standard for doing them: https://en.wikipedia.org/wiki/Well-known_URI

/.well-known/ipfs/sw-config-{uuid}

(but we should get correctness and caching first, global config is nice-to-have)

@SgtPooki
Copy link
Member

SgtPooki commented Mar 7, 2024

another potential solution:

  • config flag via cookie that triggers subdomains to reload iframe
  • fetch to root service worker for config? (will SW on root actually get the fetch request from the subdomain...?)
  • timeout or getting service worker to unregister itself (which will cause config page to reload with iframe message passing solution)

@SgtPooki
Copy link
Member

SgtPooki commented Mar 8, 2024

@2color i believe this is partially resolved by #96

@SgtPooki SgtPooki added this to the Beta milestone Apr 8, 2024
@SgtPooki SgtPooki self-assigned this Apr 23, 2024
@SgtPooki
Copy link
Member

FYI we can't access cookies from firefox: https://caniuse.com/?search=cookie

so we should probably do some type of fetch from root domain at #/sw-config-json

@SgtPooki
Copy link
Member

I think maybe we can mark this as resolved for now because you can currently access config for a subdomain at https://specs-ipfs-tech.ipns.inbrowser.dev/#/ipfs-sw-config, and we also implode service-workers after 24 hours.

@SgtPooki
Copy link
Member

SgtPooki commented Apr 25, 2024

So, to clarify how this config feature works for users:

  1. global config is "extended" or inherited from when a new subdomain is loaded.
  2. that config can be customized before attempting to load the site
  3. that config can be customized later (even from subdomain urls) by accessing /#/ipfs-sw-config

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

When branches are created from issues, their pull requests are automatically linked.

3 participants