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

Improve Developer Experience for expects_no_vary_search in Speculation Rules #349

Open
0xZOne opened this issue Dec 31, 2024 · 2 comments
Open

Comments

@0xZOne
Copy link

0xZOne commented Dec 31, 2024

Per https://github.com/WICG/nav-speculation/blob/main/triggers.md#no-vary-search-hint:

We would like preloading to make use of the improved matching enabled by the No-Vary-Search HTTP response header. When the user agent gets the response to a preloading request, it can make use of the No-Vary-Search, if present, when deciding whether to serve a subsequent navigation with the preload. However, if there is an ongoing preloading request for which the user agent has not yet received the response headers, we would need to make a tradeoff.

To solve this, we have the speculation rules syntax provide a hint for what the author expects the No-Vary-Search value to be. A rule may have an "expects_no_vary_search" field which has the expected header value as a string.

This implementation requires changes on both the front-end and server sides. Front-end developers need to add the expects_no_vary_search field in the speculation rules, while back-end developers must implement the No-Vary-Search header on the server.

If the server does NOT include a No-Vary-Search header in the response to a prerendering request, the expects_no_vary_search option in the speculation rules will not take effect, and successfully prerendered pages will be wasted.

However, Front-end developers and back-end developers are often separate groups of people working in different teams.

Here is a minor adjustment I'd like to propose:

If the response includes a No-Vary-Search header, maintain the existing logic. However, if the response is missing this header, use the expects_no_vary_search value from the speculation rules to match the preload cache.

@jeremyroman
Copy link
Collaborator

The tricky thing here is that affecting the cache treatment of resources is usually something the server controls, for a number of reasons, including that the client's expectation may be out of date, and especially for cross-origin requests, might be controlled by a separate entity.

Ultimately what's being made here is an assertion about what parameters the server does and does not use to control its response, so allowing a client to backfill that is tricky (though there is some precedent in some cases, like SW fetch interception) and certainly shouldn't be implicit.

@0xZOne
Copy link
Author

0xZOne commented Jan 4, 2025

The tricky thing here is that affecting the cache treatment of resources is usually something the server controls, for a number of reasons, including that the client's expectation may be out of date, and especially for cross-origin requests, might be controlled by a separate entity.

Ultimately what's being made here is an assertion about what parameters the server does and does not use to control its response, so allowing a client to backfill that is tricky (though there is some precedent in some cases, like SW fetch interception) and certainly shouldn't be implicit.

Thank you for your prompt response. :)

Would it be feasible to address this issue by introducing a new field in either the speculation rules API or as part of the Meta tag's http-equiv attribute? For example, we could potentially implement something like a no_vary_search field.

This explicit option could provide a clear way for developers to indicate when search result variance is not desired, without relying on implicit behavior.

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

2 participants