You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have searched existing issues to ensure the feature has not already been requested
🚀 Feature Proposal
I would like to use fastify as a reverse proxy. My current reverse proxy handles multipart form data, so a requirement for my new reverse proxy would need to handle this. I am aware that fastify-reply-from and fastify-multipart plugins are not compatible. Does anyone have any advice on creating a reverse proxy with fastify that handles multipart form data?
I believe the documentation should be updated to indicate if reply-from does not support any multipart file handling or JUST is not compatible with the multipart plugin. This would help end users decide if this plugin is acceptable for the use cases that are needed.
Motivation
Save developers time when choosing plugins
Example
No response
The text was updated successfully, but these errors were encountered:
From looking at the code and experience trying to use it, in the current implementation, when body is present, @fastify/reply-from parses the content-type header and only keeps the base type. For most headers this won't make too big of a difference, but for multipart this means the boundary is dropped completely which results in nonsensical multipart header and will cause errors on the receiver (basically unusable). Consequently breaking forms.
Some frameworks and form plugins for frameworks use multipart even if the form is not some upload form, so this basically means the proxy breaks all the forms, not just specific cases.
I don't think content type should be touched.
For anyone finding this and looking for a solution. A quick fix is simply to remember the content-type before reply-from touches it and then rewrite it back by passing it to reply-from's rewriteHeaders.
Loosly, something like this:
typeLocals={originalContentType?: string}constproxy=Fastify({logger: true})proxy.addContentTypeParser("*",/* ... */)proxy.addHook("preHandler",asyncfunctionpreHandler(req,reply){letlocals: Locals={originalContentType: req.headers["content-type"],}// eslint-disable-next-line @typescript-eslint/no-explicit-any;(reqasany).locals=locals// ...anything else you want to do})proxy.register(replyFrom,{base: UPSTREAM,})proxy.get("/*",/* ... */)proxy.post("/*",(req,reply)=>{// eslint-disable-next-line @typescript-eslint/no-explicit-anyletlocals: Locals=(reqasany).localsasLocalsletextraHeaders: {[header: string]: string}={// ...any other extra headers here}if(locals.originalContentType!=nil){extraHeaders["content-type"]=locals.originalContentType}reply.from(req.originalUrl,{rewriteRequestHeaders: (req,headers)=>{return{
...headers,
...extraHeaders,}},})})
Prerequisites
🚀 Feature Proposal
I would like to use fastify as a reverse proxy. My current reverse proxy handles multipart form data, so a requirement for my new reverse proxy would need to handle this. I am aware that fastify-reply-from and fastify-multipart plugins are not compatible. Does anyone have any advice on creating a reverse proxy with fastify that handles multipart form data?
I believe the documentation should be updated to indicate if reply-from does not support any multipart file handling or JUST is not compatible with the multipart plugin. This would help end users decide if this plugin is acceptable for the use cases that are needed.
Motivation
Save developers time when choosing plugins
Example
No response
The text was updated successfully, but these errors were encountered: