-
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
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
fix(routing): don't trigger get of headers #12937
Conversation
🦋 Changeset detectedLatest commit: f6483fe The changes in this PR will be included in the next version bump. Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
| ReadableStream | ||
| URLSearchParams | ||
| FormData | ||
| ReadableStream<Uint8Array>; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is type provided by Request.body
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we use Request['body']
instead?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry @florian-lefebvre, I completely missed your comment. I'll follow up with another PR
|
||
export interface CreateRequestOptions { | ||
url: URL | string; | ||
clientAddress?: string | undefined; | ||
headers: HeaderType; | ||
method?: string; | ||
body?: RequestBody | undefined; | ||
body?: RequestBody | undefined | null; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added null
because Request.body
is ReadableStream<Uint8Array> | null
CodSpeed Performance ReportMerging #12937 will not alter performanceComparing Summary
|
packages/astro/src/core/request.ts
Outdated
* @param newUrl The new `URL` | ||
* @param oldRequest The old `Request` | ||
*/ | ||
export function copyRequest(newUrl: URL, oldRequest: Request, isPrerendered: boolean): Request { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Where is this version of the function used?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bad copy-paste. Good catch
'astro': patch | ||
--- | ||
|
||
Fixes an issue where the use of `Astro.rewrite` would trigger the invalid use of `Astro.request.headers` |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Are these two separate issues beign fixed? It's a little unclear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes. What should I reword?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That's fine. Just wanted to confirm that they're separate.
Changes
Closes #12931
Closes PLT-2736
The issue was that doing
oldRequest.headers
during a rewrite was causing the warning to fire, because it triggers the.get
method.This is fixed now by checking the
isPrerendered
flag.Also, I updated the method
copyRequest
to use the internal methodcopyRequest
, which creates theheaders
object based onisPrenredererd
. This should fix cases (not caught, probably) where users could have usedRequest.headers
during a rewrite.Testing
I tested it locally using the reproduction provided.
Docs
N/A