在Sequelize中使用实例方法

时间:2013-10-17 17:54:49

标签: javascript node.js postgresql sequelize.js

有人可以帮我理解如何在Sequelize中使用实例方法吗?我已经查看了文档,但发现它很稀疏。目前,我正在尝试在我的用户模型上使用setPassword和verifyPassword实例方法。当我尝试在REPL中调用代码时,在导入用户模型并同步数据库之后,我得到以下内容:

> models.User.setPassword('test');
TypeError: Object [object Object] has no method 'setPassword'

以下是用户模型的代码:

var bcrypt = require('bcrypt');

module.exports = function(sequelize, DataTypes) {
  return sequelize.define('User', {
    email: { type: DataTypes.STRING, unique: true, allowNull: false, validate: { isEmail: true } },
    password: { type: DataTypes.STRING, allowNull: false},
    firstName: {type: DataTypes.STRING},
    lastName: {type: DataTypes.STRING},
    companyName: {type: DataTypes.STRING},
    admin: {type: DataTypes.BOOLEAN, allowNull: false, defaultValue: false,},
    forgotUrl: {type: DataTypes.STRING, unique: true},
    forgotDate: {type: DataTypes.STRING},
    lastLogin: {
      type: DataTypes.DATE,
      defaultValue: DataTypes.NOW
    }
  }, {
    paranoid: true,
    instanceMethods: {
      setPassword: function(password, done) {
        return bcrypt.genSalt(10, function(err, salt) {
          return bcrypt.hash(password, salt, function(error, encrypted) {
            this.password = encrypted;
            this.salt = salt;
            return done();
          });
        });
      },
      verifyPassword: function(password, done) {
        return bcrypt.compare(password, this.password, function(err, res) {
          return done(err, res);
        });
      }
    }
  });
};

2 个答案:

答案 0 :(得分:16)

实例方法可用于特定元素实例,例如

models.User.find(123).success( function( user ) { 
    user.setPassword('test');
});

答案 1 :(得分:3)

您将函数定义为: function(password, done)

但是你没有提供完成参数。 因此,函数将以未定义的方式完成,并且调用done()正在执行未定义的函数。

您可以通过3种方式解决此问题:

  1. 默认完成noop函数function () {}
  2. 如果已定义完成,则仅返回done()
  3. 调用实例函数时提供完成回调。
  4. 另一种方法是重构它以返回它在完成时解析的承诺。