2015-04-22 07:50:11 +09:00
|
|
|
///////////////////
|
|
|
|
// Users Helpers //
|
|
|
|
///////////////////
|
|
|
|
|
|
|
|
|
2015-04-25 13:11:28 +09:00
|
|
|
|
2015-04-22 07:50:11 +09:00
|
|
|
Users.updateAdmin = function (userId, admin) {
|
|
|
|
this.update(userId, {$set: {isAdmin: admin}});
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
Users.adminUsers = function () {
|
|
|
|
return this.find({isAdmin : true}).fetch();
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getUserName = function (user) {
|
|
|
|
try{
|
|
|
|
if (user.username)
|
|
|
|
return user.username;
|
|
|
|
if (user && user.services && user.services.twitter && user.services.twitter.screenName)
|
2015-05-01 18:22:00 +02:00
|
|
|
return user.services.twitter.screenName;
|
2015-04-22 07:50:11 +09:00
|
|
|
}
|
|
|
|
catch (error){
|
|
|
|
console.log(error);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getDisplayName = function (user) {
|
2015-05-08 11:45:09 +09:00
|
|
|
return (user.telescope && user.telescope.displayName) ? user.telescope.displayName : Users.getUserName(user);
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.getDisplayNameById = function (userId) {
|
|
|
|
return this.getDisplayName(Meteor.users.findOne(userId));
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getAuthorName = function(item) {
|
|
|
|
var user = Meteor.users.findOne(item.userId);
|
|
|
|
return typeof user === 'undefined' ? '' : Users.getDisplayName(user);
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getProfileUrl = function (user) {
|
2015-04-28 15:54:19 +09:00
|
|
|
return this.getProfileUrlBySlugOrId(user.telescope.slug);
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.getProfileUrlBySlugOrId = function (slugOrId) {
|
|
|
|
return Telescope.utils.getRouteUrl('user_profile', {_idOrSlug: slugOrId});
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.hasPassword = function (user) {
|
|
|
|
return !!user.services.password;
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getTwitterName = function (user) {
|
|
|
|
// return twitter name provided by user, or else the one used for twitter login
|
|
|
|
if(Telescope.utils.checkNested(user, 'profile', 'twitter')){
|
|
|
|
return user.profile.twitter;
|
|
|
|
}else if(Telescope.utils.checkNested(user, 'services', 'twitter', 'screenName')){
|
|
|
|
return user.services.twitter.screenName;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getGitHubName = function (user) {
|
|
|
|
// return twitter name provided by user, or else the one used for twitter login
|
|
|
|
if(Telescope.utils.checkNested(user, 'profile', 'github')){
|
|
|
|
return user.profile.github;
|
|
|
|
}else if(Telescope.utils.checkNested(user, 'services', 'github', 'screenName')){ // TODO: double-check this with GitHub login
|
|
|
|
return user.services.github.screenName;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getTwitterNameById = function (userId) {
|
|
|
|
var user = Meteor.users.findOne(userId);
|
|
|
|
if (user)
|
2015-04-23 10:39:58 +09:00
|
|
|
return Users.getTwitterName(user);
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.getEmail = function (user) {
|
2015-05-06 12:16:50 +09:00
|
|
|
if(user.telescope && user.telescope.email){
|
|
|
|
return user.telescope.email;
|
2015-04-22 07:50:11 +09:00
|
|
|
}else{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getEmailHash = function (user) {
|
|
|
|
// has to be this way to work with Gravatar
|
2015-04-28 11:32:53 +09:00
|
|
|
return Gravatar.hash(Users.getEmail(user));
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.getAvatarUrl = function (user) {
|
2015-05-01 18:22:00 +02:00
|
|
|
console.warn('FUNCTION getAvatarUrl() IS DEPRECATED -- package bengott:avatar is used instead.');
|
2015-04-22 07:50:11 +09:00
|
|
|
return Avatar.getUrl(user);
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getCurrentUserEmail = function () {
|
2015-04-28 11:32:53 +09:00
|
|
|
return Meteor.user() ? Users.getEmail(Meteor.user()) : '';
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.userProfileComplete = function (user) {
|
2015-04-23 17:45:37 +09:00
|
|
|
for (var i = 0; i < Telescope.callbacks.profileCompletedChecks.length; i++) {
|
|
|
|
if (!Telescope.callbacks.profileCompletedChecks[i](user)) {
|
2015-04-22 07:50:11 +09:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.findLast = function (user, collection) {
|
|
|
|
return collection.findOne({userId: user._id}, {sort: {createdAt: -1}});
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.timeSinceLast = function (user, collection){
|
|
|
|
var now = new Date().getTime();
|
|
|
|
var last = this.findLast(user, collection);
|
|
|
|
if(!last)
|
|
|
|
return 999; // if this is the user's first post or comment ever, stop here
|
|
|
|
return Math.abs(Math.floor((now-last.createdAt)/1000));
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.numberOfItemsInPast24Hours = function (user, collection) {
|
|
|
|
var mNow = moment();
|
|
|
|
var items = collection.find({
|
|
|
|
userId: user._id,
|
|
|
|
createdAt: {
|
|
|
|
$gte: mNow.subtract(24, 'hours').toDate()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return items.count();
|
|
|
|
};
|
|
|
|
|
|
|
|
Users.getUserSetting = function (setting, defaultValue, user) {
|
2015-05-01 18:22:00 +02:00
|
|
|
user = user || Meteor.user();
|
|
|
|
defaultValue = defaultValue || null;
|
2015-04-28 15:54:19 +09:00
|
|
|
var settingValue = this.getProperty(user.telescope, setting);
|
2015-05-01 18:22:00 +02:00
|
|
|
return (settingValue === null) ? defaultValue : settingValue;
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.setUserSetting = function (setting, value, userArgument) {
|
|
|
|
// note: for some very weird reason, doesn't work when called from Accounts.onCreateUser
|
|
|
|
|
|
|
|
var user;
|
|
|
|
|
|
|
|
if(Meteor.isClient){
|
|
|
|
user = Meteor.user(); // on client, default to current user
|
|
|
|
}else if (Meteor.isServer){
|
|
|
|
user = userArgument; // on server, use argument
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!user)
|
|
|
|
throw new Meteor.Error(500, 'User not defined');
|
|
|
|
|
2015-04-22 11:49:42 +09:00
|
|
|
console.log('Setting user setting "' + setting + '" to "' + value + '" for ' + Users.getUserName(user));
|
2015-04-22 07:50:11 +09:00
|
|
|
var find = {_id: user._id};
|
|
|
|
var field = {};
|
2015-04-28 15:54:19 +09:00
|
|
|
field['telescope.'+setting] = value;
|
2015-04-22 07:50:11 +09:00
|
|
|
var options = {$set: field};
|
2015-05-01 18:22:00 +02:00
|
|
|
Meteor.users.update(find, options, {validate: false});
|
2015-04-22 07:50:11 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
Users.getProperty = function (object, property) {
|
|
|
|
// recursive function to get nested properties
|
|
|
|
var array = property.split('.');
|
|
|
|
if(array.length > 1){
|
|
|
|
var parent = array.shift();
|
|
|
|
// if our property is not at this level, call function again one level deeper if we can go deeper, else return null
|
2015-05-01 18:22:00 +02:00
|
|
|
return (typeof object[parent] === "undefined") ? null : this.getProperty(object[parent], array.join('.'));
|
2015-04-22 07:50:11 +09:00
|
|
|
}else{
|
|
|
|
// else return property
|
|
|
|
return object[array[0]];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Build Users subscription with filter, sort, and limit args.
|
2015-05-04 10:19:50 +09:00
|
|
|
* @param {String} filterBy
|
|
|
|
* @param {String} sortBy
|
|
|
|
* @param {Number} limit
|
2015-04-22 07:50:11 +09:00
|
|
|
*/
|
|
|
|
Users.getSubParams = function(filterBy, sortBy, limit) {
|
|
|
|
var find = {},
|
|
|
|
sort = {createdAt: -1};
|
|
|
|
|
|
|
|
switch(filterBy){
|
|
|
|
case 'invited':
|
|
|
|
// consider admins as invited
|
|
|
|
find = { $or: [{ isInvited: true }, { isAdmin: true }]};
|
|
|
|
break;
|
|
|
|
case 'uninvited':
|
|
|
|
find = { $and: [{ isInvited: false }, { isAdmin: false }]};
|
|
|
|
break;
|
|
|
|
case 'admin':
|
|
|
|
find = { isAdmin: true };
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch(sortBy){
|
|
|
|
case 'username':
|
|
|
|
sort = { username: 1 };
|
|
|
|
break;
|
|
|
|
case 'karma':
|
|
|
|
sort = { karma: -1 };
|
|
|
|
break;
|
|
|
|
case 'postCount':
|
|
|
|
sort = { postCount: -1 };
|
|
|
|
break;
|
|
|
|
case 'commentCount':
|
|
|
|
sort = { commentCount: -1 };
|
2015-05-01 18:22:00 +02:00
|
|
|
break;
|
2015-04-22 07:50:11 +09:00
|
|
|
case 'invitedCount':
|
|
|
|
sort = { invitedCount: -1 };
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
find: find,
|
|
|
|
options: { sort: sort, limit: limit }
|
|
|
|
};
|
|
|
|
};
|