20

有人可以帮助我了解如何在 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);
        });
      }
    }
  });
};
4

2 回答 2

16

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

models.User.find(123).success( function( user ) { 
    user.setPassword('test');
});
于 2013-10-17T17:57:53.490 回答
3

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

但是您不提供 done 参数。因此,函数将 done 保留为未定义,调用 done() 正在执行未定义的函数。

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

  1. 默认为 noop 函数完成function () {}
  2. done()在定义 done时返回
  3. 调用实例函数时提供完成回调。

另一种方法是重构它以返回它在完成时解决的承诺。

于 2015-02-17T11:15:15.080 回答