-
Notifications
You must be signed in to change notification settings - Fork 25
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
Incorrect operation of upload property in avatar field configuration in next-admin library #480
Comments
I have the same issue. Also, I cannot see any logs in the Next-admin library version: 6.1.6. |
Hi, The When a form containing a file object is submitted, the client sends file data and information to the server, it catches this information and passes it to the I don't quite understand your request, can you please give more details about your request to see if I'm missing something ? |
This is a sample NextAdminOptions code from my project: const options: NextAdminOptions = {
model: {
User: {
edit: {
fields: {
avatar: {
format: "file",
required: true,
handler: {
upload: async (buffer, { name, type }) => {
const uploadedFile = await upload(
new File([buffer], name)
);
return uploadedFile.url || "";
},
},
},
},
},
},
}; Here, a function inside handler.upload with the same name takes in a File and returns an object with a download reference. Here is its code: export const upload = async (file: File) => {
const formData = new FormData();
formData.append("file", file);
try {
const response = await fetch(`${fsHost}/upload`, {
method: "POST",
body: formData,
});
if (!response.ok) {
return {
success: false,
message: `Request failed, ${response.status}`,
};
}
const data: UploadedFile = await response.json();
return data;
} catch (error) {
return {
success: false,
message: `Request failed, ${error}`,
};
}
}; if you add any debugging (console.log('example')) to handler.upload, it will not be displayed in the console |
Hi @joriksp, |
What's the return type of your This error means that you are trying to submit the output of your |
@joriksp I had the same problem in my case was that I didn`t add the options on app/api/admin/[[...nextadmin]]/route.ts by default come commented
|
handler: {
upload: async (buffer, { name, type }) => {
const uploadedFile = await upload(
new File([buffer], name)
);
return uploadedFile.url || "";
},
}, It returns string (url) |
Indeed, thanks for the precision @joriksp please let me know if you have in the same case |
Also, to avoid other problems, we recommend putting |
Problem description
When using the upload property in the avatar field configuration in the User model, a problem occurs: instead of the expected string returned from the upload handler, the actual file itself is sent in the user change form. This leads to incorrect data processing on the server and can cause errors when saving data.
Steps for playback
Expected behavior
When uploading a file, the value returned from the upload handler (in this case, the file name) should be sent for the avatar field, not the file itself.
Actual behavior
The file itself is sent to the server, not the file name, which causes problems with data processing.
More info
Next-admin library version: 6.1.6.
Nextjs version: 14.2.16.
Operating system: Windows 11
Browser: Chrome 130.0.6723.71.
The text was updated successfully, but these errors were encountered: