2013-11-14 07:29:55 +00:00
|
|
|
var mongoose = require('mongoose'),
|
2013-11-15 16:13:21 +00:00
|
|
|
bcrypt = require('bcrypt');
|
|
|
|
|
2013-11-14 07:29:55 +00:00
|
|
|
var userSchema = new mongoose.Schema({
|
2013-12-06 04:46:47 +00:00
|
|
|
|
|
|
|
// Local authentication
|
2013-12-06 07:03:27 +00:00
|
|
|
username: { type: String, unique: true, sparse: true },
|
2013-11-19 18:13:41 +00:00
|
|
|
password: String,
|
2013-12-06 04:46:47 +00:00
|
|
|
|
|
|
|
// OAuth 2.0 authentication
|
|
|
|
provider: String,
|
|
|
|
facebook: String,
|
|
|
|
twitter: String,
|
|
|
|
google: String,
|
|
|
|
github: String,
|
|
|
|
|
|
|
|
// Optional profile information
|
|
|
|
profile: {
|
2013-12-06 05:03:07 +00:00
|
|
|
name: { type: String, default: '' },
|
|
|
|
email: { type: String, default: '' },
|
2013-12-06 05:18:39 +00:00
|
|
|
gender: { type: String, default: '' },
|
2013-12-06 05:03:07 +00:00
|
|
|
location: { type: String, default: '' },
|
|
|
|
website: { type: String, default: '' },
|
2013-12-06 06:14:10 +00:00
|
|
|
picture: { type: String, default: 'http://bit.ly/1cppDAL' }
|
2013-12-06 04:46:47 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
// API access tokens
|
2013-11-30 05:52:53 +00:00
|
|
|
tokens: {
|
2013-12-06 03:42:20 +00:00
|
|
|
google: String,
|
2013-11-30 05:52:53 +00:00
|
|
|
facebook: String,
|
|
|
|
foursquare: String,
|
|
|
|
twitter: String,
|
2013-12-07 05:29:57 +00:00
|
|
|
github: String,
|
|
|
|
tumblr: String
|
2013-12-06 04:46:47 +00:00
|
|
|
}
|
2013-11-14 07:29:55 +00:00
|
|
|
});
|
|
|
|
|
2013-11-19 06:57:13 +00:00
|
|
|
userSchema.path('password').validate(function(password) {
|
|
|
|
if (this.provider) return true;
|
|
|
|
return password.length;
|
|
|
|
}, 'Password cannot be blank');
|
|
|
|
|
2013-12-06 03:48:09 +00:00
|
|
|
userSchema.path('username').validate(function(username) {
|
2013-11-19 06:57:13 +00:00
|
|
|
if (this.provider) return true;
|
2013-12-06 03:48:09 +00:00
|
|
|
return username.length;
|
|
|
|
}, 'Username cannot be blank');
|
2013-11-19 06:57:13 +00:00
|
|
|
|
2013-11-19 18:13:41 +00:00
|
|
|
|
2013-11-14 07:29:55 +00:00
|
|
|
userSchema.pre('save', function(next) {
|
|
|
|
var user = this;
|
2013-11-18 19:37:01 +00:00
|
|
|
var SALT_FACTOR = 5;
|
2013-11-14 07:29:55 +00:00
|
|
|
|
|
|
|
if (!user.isModified('password')) return next();
|
|
|
|
|
2013-11-18 19:37:01 +00:00
|
|
|
bcrypt.genSalt(SALT_FACTOR, function(err, salt) {
|
2013-11-14 07:29:55 +00:00
|
|
|
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);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2013-12-06 03:42:20 +00:00
|
|
|
module.exports = mongoose.model('User', userSchema);
|