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

attachFieldsToBody makes request.file() return undefined. #472

Open
2 tasks done
Ryooshuu opened this issue Aug 12, 2023 · 7 comments
Open
2 tasks done

attachFieldsToBody makes request.file() return undefined. #472

Ryooshuu opened this issue Aug 12, 2023 · 7 comments
Labels
discussion Issues or PRs with this label will never stale

Comments

@Ryooshuu
Copy link

Prerequisites

  • I have written a descriptive issue title
  • I have searched existing issues to ensure the bug has not already been reported

Fastify version

4.21.0

Plugin version

7.7.3

Node.js version

20.3.1

Operating system

Windows

Operating system version (i.e. 20.04, 11.3, 10)

10.0.19044 Build 19044

Description

I'm not entirely sure if this is an intentional change, but it's certainly one that I don't personally agree with. As far as I'm aware and have explored, there is no possible way to get the name of the file as request.body.(field where the file should be) provides only the buffer and nothing else.

Steps to Reproduce

import fastify from "fastify";
import "@fastify/multipart";

const instance = fastify({ logger: true });
instance.register(require("@fastify/multipart"), {
    attachFieldsToBody: "keyValues",
});

instance.route({
    method: "POST",
    url: `/files/`,
    handler: async (request, reply) => {       
        const file = await request.file();
        console.log(file?.filename || "no file"); // returns "no file"
        
        return {
            code: 200,
            message: "ok"
        }
    }
})

instance.listen({ port: 8090 }, (err, address) => {
    if (err) {
        instance.log.error(err);
        process.exit(1);
    }
    instance.log.info(`Server listening on ${address}`);
})

Expected Behavior

Instead of returning no file, it should return the data of the sent file without requiring the usage of request.body.(field where the file should be).

@mcollina
Copy link
Member

Would you like to send a PR?

@gurgunday
Copy link
Member

gurgunday commented Aug 17, 2023

If you want the name of the file, you should be using attachFieldsToBody: true

We could make a PR where we pass file fields directly to the body

@Ryooshuu
Copy link
Author

I'm using attachFieldsToBody: "keyValues" explicitly to keep the body properties returning only the value given to it during the request. Though, I suppose internally I could make it possible to use attachFieldsToBody: true and make a function that returns the value of that property.

Thank you for the PR, however, I'll be looking forward to it being merged.

@gurgunday gurgunday added the discussion Issues or PRs with this label will never stale label Jan 28, 2024
@juancruz-factum
Copy link

does any body knows how can i access to the file name with attachFieldsToBody: "keyValues" option?

@gurgunday
Copy link
Member

You can only send it as a different field currently

@juancruz-factum
Copy link

You can only send it as a different field currently

do you know if there is an open pr for this? i don't know if i can call this an issue

@juancruz-factum
Copy link

You can only send it as a different field currently

what about this ?

onFile: async (part) => { part.value = { filename: part.filename, mimetype: part.mimetype, encoding: part.encoding, value: await part.toBuffer(), }; },

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
discussion Issues or PRs with this label will never stale
Projects
None yet
Development

No branches or pull requests

4 participants