61 lines
1.5 KiB
JavaScript
61 lines
1.5 KiB
JavaScript
var mongoose = require('mongoose');
|
|
var bcrypt = require('bcrypt');
|
|
|
|
var userSchema = new mongoose.Schema({
|
|
username: { type: String, unique: true, sparse: true },
|
|
password: String,
|
|
|
|
tokens: Array,
|
|
provider: String,
|
|
facebook: String,
|
|
twitter: String,
|
|
google: String,
|
|
github: String,
|
|
|
|
profile: {
|
|
name: { type: String, default: '' },
|
|
email: { type: String, default: '' },
|
|
gender: { type: String, default: '' },
|
|
location: { type: String, default: '' },
|
|
website: { type: String, default: '' },
|
|
picture: { type: String, default: '' }
|
|
}
|
|
});
|
|
|
|
userSchema.path('password').validate(function(password) {
|
|
if (this.provider) return true;
|
|
return password.length;
|
|
}, 'Password cannot be blank');
|
|
|
|
userSchema.path('username').validate(function(username) {
|
|
if (this.provider) return true;
|
|
return username.length;
|
|
}, 'Email cannot be blank');
|
|
|
|
|
|
userSchema.pre('save', function(next) {
|
|
var user = this;
|
|
var SALT_FACTOR = 5;
|
|
|
|
if (!user.isModified('password')) return next();
|
|
|
|
bcrypt.genSalt(SALT_FACTOR, function(err, salt) {
|
|
if (err) return next(err);
|
|
|
|
bcrypt.hash(user.password, salt, function(err, hash) {
|
|
if (err) return next(err);
|
|
user.password = hash;
|
|
next();
|
|
});
|
|
});
|
|
});
|
|
|
|
userSchema.methods.comparePassword = function(candidatePassword, cb) {
|
|
bcrypt.compare(candidatePassword, this.password, function(err, isMatch) {
|
|
if(err) return cb(err);
|
|
cb(null, isMatch);
|
|
});
|
|
};
|
|
|
|
module.exports = mongoose.model('User', userSchema);
|