2016-04-20 18:03:55 +08:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
// external modules
|
|
|
|
var md5 = require("blueimp-md5");
|
|
|
|
var Sequelize = require("sequelize");
|
2016-12-02 01:58:14 +08:00
|
|
|
var scrypt = require('scrypt');
|
2016-04-20 18:03:55 +08:00
|
|
|
|
|
|
|
// core
|
|
|
|
var logger = require("../logger.js");
|
2017-01-06 05:37:40 +01:00
|
|
|
var letterAvatars = require('../letter-avatars.js');
|
2016-04-20 18:03:55 +08:00
|
|
|
|
|
|
|
module.exports = function (sequelize, DataTypes) {
|
|
|
|
var User = sequelize.define("User", {
|
|
|
|
id: {
|
|
|
|
type: DataTypes.UUID,
|
|
|
|
primaryKey: true,
|
|
|
|
defaultValue: Sequelize.UUIDV4
|
|
|
|
},
|
|
|
|
profileid: {
|
|
|
|
type: DataTypes.STRING,
|
|
|
|
unique: true
|
|
|
|
},
|
|
|
|
profile: {
|
|
|
|
type: DataTypes.TEXT
|
|
|
|
},
|
|
|
|
history: {
|
|
|
|
type: DataTypes.TEXT
|
2016-05-11 17:04:45 -04:00
|
|
|
},
|
|
|
|
accessToken: {
|
|
|
|
type: DataTypes.STRING
|
2016-05-15 12:20:42 +08:00
|
|
|
},
|
|
|
|
refreshToken: {
|
|
|
|
type: DataTypes.STRING
|
2016-12-02 01:58:14 +08:00
|
|
|
},
|
|
|
|
email: {
|
|
|
|
type: Sequelize.TEXT,
|
|
|
|
validate: {
|
|
|
|
isEmail: true
|
|
|
|
}
|
|
|
|
},
|
|
|
|
password: {
|
|
|
|
type: Sequelize.TEXT,
|
|
|
|
set: function(value) {
|
|
|
|
var hash = scrypt.kdfSync(value, scrypt.paramsSync(0.1)).toString("hex");
|
|
|
|
this.setDataValue('password', hash);
|
|
|
|
}
|
2016-04-20 18:03:55 +08:00
|
|
|
}
|
|
|
|
}, {
|
2016-12-02 01:58:14 +08:00
|
|
|
instanceMethods: {
|
|
|
|
verifyPassword: function(attempt) {
|
|
|
|
if (scrypt.verifyKdfSync(new Buffer(this.password, "hex"), attempt)) {
|
|
|
|
return this;
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2016-04-20 18:03:55 +08:00
|
|
|
classMethods: {
|
|
|
|
associate: function (models) {
|
|
|
|
User.hasMany(models.Note, {
|
|
|
|
foreignKey: "ownerId",
|
|
|
|
constraints: false
|
|
|
|
});
|
|
|
|
User.hasMany(models.Note, {
|
|
|
|
foreignKey: "lastchangeuserId",
|
|
|
|
constraints: false
|
|
|
|
});
|
|
|
|
},
|
2016-12-02 01:58:14 +08:00
|
|
|
getProfile: function (user) {
|
|
|
|
return user.profile ? User.parseProfile(user.profile) : (user.email ? User.parseProfileByEmail(user.email) : null);
|
|
|
|
},
|
2016-04-20 18:03:55 +08:00
|
|
|
parseProfile: function (profile) {
|
|
|
|
try {
|
|
|
|
var profile = JSON.parse(profile);
|
|
|
|
} catch (err) {
|
|
|
|
logger.error(err);
|
|
|
|
profile = null;
|
|
|
|
}
|
|
|
|
if (profile) {
|
|
|
|
profile = {
|
|
|
|
name: profile.displayName || profile.username,
|
|
|
|
photo: User.parsePhotoByProfile(profile)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return profile;
|
|
|
|
},
|
|
|
|
parsePhotoByProfile: function (profile) {
|
|
|
|
var photo = null;
|
|
|
|
switch (profile.provider) {
|
|
|
|
case "facebook":
|
2016-05-21 22:48:21 +08:00
|
|
|
photo = 'https://graph.facebook.com/' + profile.id + '/picture?width=96';
|
2016-04-20 18:03:55 +08:00
|
|
|
break;
|
|
|
|
case "twitter":
|
2016-05-20 02:13:22 +08:00
|
|
|
photo = 'https://twitter.com/' + profile.username + '/profile_image?size=bigger';
|
2016-04-20 18:03:55 +08:00
|
|
|
break;
|
|
|
|
case "github":
|
2016-05-20 02:13:22 +08:00
|
|
|
photo = 'https://avatars.githubusercontent.com/u/' + profile.id + '?s=96';
|
2016-04-20 18:03:55 +08:00
|
|
|
break;
|
2016-05-12 13:26:50 -04:00
|
|
|
case "gitlab":
|
2016-05-21 22:48:21 +08:00
|
|
|
photo = profile.avatarUrl.replace(/(\?s=)\d*$/i, '$196');
|
2016-05-12 13:26:50 -04:00
|
|
|
break;
|
2016-04-20 18:03:55 +08:00
|
|
|
case "dropbox":
|
|
|
|
//no image api provided, use gravatar
|
2016-05-21 22:48:21 +08:00
|
|
|
photo = 'https://www.gravatar.com/avatar/' + md5(profile.emails[0].value) + '?s=96';
|
2016-04-20 18:03:55 +08:00
|
|
|
break;
|
2016-05-21 22:48:00 +08:00
|
|
|
case "google":
|
|
|
|
photo = profile.photos[0].value.replace(/(\?sz=)\d*$/i, '$196');
|
|
|
|
break;
|
2017-01-06 05:37:40 +01:00
|
|
|
case "ldap":
|
|
|
|
//no image api provided,
|
|
|
|
//use gravatar if email exists,
|
|
|
|
//otherwise generate a letter avatar
|
|
|
|
if (profile.emails[0]) {
|
|
|
|
photo = 'https://www.gravatar.com/avatar/' + md5(profile.emails[0]) + '?s=96';
|
|
|
|
} else {
|
|
|
|
photo = letterAvatars(profile.username);
|
|
|
|
}
|
|
|
|
break;
|
2016-04-20 18:03:55 +08:00
|
|
|
}
|
|
|
|
return photo;
|
2016-12-02 01:58:14 +08:00
|
|
|
},
|
|
|
|
parseProfileByEmail: function (email) {
|
|
|
|
var photoUrl = 'https://www.gravatar.com/avatar/' + md5(email);
|
|
|
|
return {
|
|
|
|
name: email.substring(0, email.lastIndexOf("@")),
|
|
|
|
photo: photoUrl += '?s=96'
|
|
|
|
};
|
2016-04-20 18:03:55 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2016-05-11 17:04:45 -04:00
|
|
|
|
2016-04-20 18:03:55 +08:00
|
|
|
return User;
|
|
|
|
};
|