mongoose-errors-handler-i18n

0.1.1 • Public • Published

mongoose-errors-handler-i18n

Express/Node.js module to create internationalized formatted errors in Mongoose. 🇫🇷🇺🇸

mongoose-i18n-error is a lightweight module for node.js/express.js to create beautiful mongoose i18n validation error messages. It is built on top of the awesome i18n-node translation module.

{
    username: {
        type: 'required',
        message: 'is required',
        value: undefined
    },
    email: {
        type: 'regexp',
        message: 'is no valid email',
        value: 'johndoe.de'
    }
}

Usage

npm install mongoose-errors-handler-i18n --save

Configure your app to support i18n:

var i18n = require('i18n');
 
i18n.configure({
    locales: ['en', 'fr'],
    directory: './locales'
});
 
app.use(i18n.init);

Then, simply add the module as an express error handler middleware:

var i18nMongooseError = new (require('mongoose-i18n-error'))();
 
app.use(i18nMongooseError.handler(function(err, req, res, next) {
    res.status(422).json(err);
}));

Options

By default, the plugin will prefix the error messages in your locale files with 'error.':

"error.required": "is required",
"error.minlength": "needs a minimum length of %s",
"error.user.password.regexp": "is no valid email",
"error.cast": "is not valid"

You can change the prefix by passing the prefix attribute as options:

var i18nMongooseError = new (require('mongoose-i18n-error'))({
    prefix: 'err.'
});

Custom validators

In your custom mongoose validators your error message should now apply to the key in your locales.

var Schema = new mongoose.Schema({
    name: {
        type: String,
        validate: {
            validator: function(v) {
                return /^[A-Z]*$/i.test(v);
            },
            message: 'user.name.alpha' // or 'alpha'
        }
    }
});

Tests

To run the tests you need a local MongoDB instance available. Run with:

npm test

Issues

Please use the GitHub issue tracker to raise any problems or feature requests.

If you would like to submit a pull request with any changes you make, please feel free!

Package Sidebar

Install

npm i mongoose-errors-handler-i18n

Weekly Downloads

1

Version

0.1.1

License

MIT

Unpacked Size

21.6 kB

Total Files

9

Last publish

Collaborators

  • c.delouvencourt