-
Notifications
You must be signed in to change notification settings - Fork 30
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
HTTP Cache API #1051
Open
guybedford
wants to merge
96
commits into
main
Choose a base branch
from
http-cache
base: main
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
HTTP Cache API #1051
+6,160
−1,961
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
guybedford
force-pushed
the
http-cache
branch
2 times, most recently
from
November 22, 2024 22:02
3f13d65
to
f78e621
Compare
guybedford
changed the title
Draft proposal for the HTTP Cache API
Draft HTTP Cache API
Nov 22, 2024
guybedford
force-pushed
the
http-cache
branch
from
November 23, 2024 00:22
f78e621
to
aa85eaf
Compare
guybedford
force-pushed
the
http-cache
branch
4 times, most recently
from
November 28, 2024 21:58
d663577
to
d691bf5
Compare
guybedford
force-pushed
the
http-cache
branch
from
November 28, 2024 22:01
d691bf5
to
ab7846e
Compare
guybedford
force-pushed
the
http-cache
branch
4 times, most recently
from
December 14, 2024 00:53
1df917e
to
39159e7
Compare
guybedford
force-pushed
the
http-cache
branch
from
December 31, 2024 23:22
e993c64
to
ed4e25f
Compare
guybedford
force-pushed
the
http-cache
branch
2 times, most recently
from
January 15, 2025 05:51
56b48a9
to
468d807
Compare
guybedford
force-pushed
the
http-cache
branch
4 times, most recently
from
January 22, 2025 22:58
54e6fc8
to
96e00b5
Compare
guybedford
force-pushed
the
http-cache
branch
from
January 23, 2025 18:46
96e00b5
to
af88dc9
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This implements the HTTP Cache API following the Rust implementation very closely, it is almost a verbatim translation of the Rust SDK semantics, apart from being adapted to the JS fetch API and using async send calls.
This feature uses the HTTP cache APIs only when they are both supported and also when adding the
--enable-http-cache
CLI argument to the js-compute runtime build command. The plan is to disable this flag for future versions and make it the default, but we want to be careful to ensure adequate testing and to avoid regressions.Typing uses a variation of #1018 that uses real mutable Request and Response objects instead of relying on a new CandidateResponse object. The Response is effectively a CandidateResponse when it has a CacheEntry handle associated with it. A new error is then thrown when attempting to access the body of one of these response objects to support the CandidateResponse semantics. Effectively the CacheHandle slot being set handles the divergence here.
In the process, we also update
new CacheControl('override', { ... opts ... })
to have the new direct override object syntax variationnew CacheControl({ ...opts... })
as the override, and we also now support passing just the cache override init options to thecacheOverride
fetch option, e.g. likefetch(url, { cacheOverride: { beforeSend () {...} } })
.The
fetch
implementation is upgraded to usesend_async_v2
and the new implementation is very closely based to the Rust implementation which should replicate the former caching logic in its entirety making this mostly a backwards compatible change, pending further testing before unflagging.Support for the
fetch
cache
option is not implemented here although could now be partially implemented as per #1050, which is effectively unblocked by this landing.