Decorators for mongoose models.
$ npm i mongoose mongoose-decorators --save
This library supports ECMAScript decorators proposal. To use decorators with babel you need to add transform-decorators-legacy plugin to .babelrc
.
Example:
import {model, index, post} from 'mongoose-decorators';
@model({
name: String,
type: String
}, {
autoIndex: false
})
@index({name: 1, type: -1})
export default class User {
// class methods
foo() {}
@post('save')
reindex() {}
}
// User is now mongoose model
var john = new User({name: 'John'});
john.save();
console.log(john.name); // 'John'
console.log(john.foo); // [Function: foo]
definition
(object) - will be passed to mongoose.Schema constructoroptions
(object, optional) - will be passed to mongoose.Schema constructorconfigure
(function, optional) - function for configuring schema. Some schema methods (create indexes, register plugins, etc.) should be called before model is created, you can do it in this function. It will be called with one argument - mongoose schema.
Decorators that wrap common used mongoose schema methods with the same options. These decorators must be used between model
decorator and class definition.
Method decorators that register middleware.
This library is under the MIT License