Асинхронный контроллер в Express для парсинга форм в Mongoose

В настоящее время я разрабатываю способ загрузки сообщения (файла и полей) из Dropzone в Mongoose с помощью Express Router. Мой внутренний контроллер (который вызывается после аутентификации и проверки данных) работает следующим образом:

//Import Internal Dependencies
const Loader = require('../models/loader.js');
const Formidable = require('formidable');
const fs = require('fs');

module.exports = {
    load: async (req, res, next) => {

        var form = new Formidable.IncomingForm();

        let path;
        let contentType;

        await form.parse(req, async function (err, fields, files) {

            if (err) {

                return res.status(404).json(err);

            } else {

                const {
                    user,
                    patient,
                    condition,
                    compound,
                    classi
                } = fields;

                path = files.image.path;
                contentType = files.image.type;
                fs.readFile(path, async function (err, data) {

                    if (err) {

                        return res.status(404).json(err);

                    } else {

                        //Save load
                        const newLoader = new Loader({
                            user,
                            patient,
                            condition,
                            compound,
                            classi,
                            image: {
                                data,
                                contentType
                            }
                        });

                        //Delete image in local storage
                        await fs.unlink(path, function (error) {
                            if(error){
                            return res.status(404).json(error)
                            }
                        });

                        await newLoader.save();

                        res.status(200).json("Load image sucessfully.");

                        next()
                    }
                })
            }
        });
    }
};

Когда я тестировал его с почтальоном, я получил статус 202, и изображения успешно загружаются в базу данных. Однако, когда я пытаюсь загрузить с dropzone без полей (что должно вызвать некоторую ошибку и быть отображено в dropzone), я получил следующие ошибки / предупреждение в серверной консоли (Dropzone остановилась при загрузке и не показала никакой ошибки):

(node:20834) UnhandledPromiseRejectionWarning: ValidationError: load validation failed: user: Path `user` is required., classi: Path `classi` is required.
    at new ValidationError (/root/aimuneBack/node_modules/mongoose/lib/error/validation.js:27:11)
    at model.Document.invalidate (/root/aimuneBack/node_modules/mongoose/lib/document.js:1876:32)
    at p.doValidate.skipSchemaValidators (/root/aimuneBack/node_modules/mongoose/lib/document.js:1744:17)
    at /root/aimuneBack/node_modules/mongoose/lib/schematype.js:808:9
    at _combinedTickCallback (internal/process/next_tick.js:131:7)
    at process._tickCallback (internal/process/next_tick.js:180:9)
(node:20834) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
(node:20834) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.
    at emitWarning (internal/process/promises.js:92:15)
    at emitPendingUnhandledRejections (internal/process/promises.js:109:11)
    at process._tickCallback (internal/process/next_tick.js:189:7)
POST /load - - ms - -

Так что я знаю, что сделал что-то не так с моим асинхронным кодом и, к сожалению, не могу понять это. Надеюсь, вы можете помочь. С наилучшими пожеланиями, Андре

0 ответов

Другие вопросы по тегам