Merge branch 'master' of github.com:designcreateplay/NodeBB

This commit is contained in:
Julian Lam
2014-01-24 08:18:02 -05:00
18 changed files with 189 additions and 193 deletions

View File

@@ -348,6 +348,23 @@ var bcrypt = require('bcrypt'),
}
};
User.isReadyToPost = function(uid, callback) {
User.getUserField(uid, 'lastposttime', function(err, lastposttime) {
if(err) {
return callback(err);
}
if(!lastposttime) {
lastposttime = 0;
}
if (Date.now() - parseInt(lastposttime, 10) < parseInt(meta.config.postDelay, 10) * 1000) {
return callback(new Error('too-many-posts'));
}
callback();
});
}
User.isEmailAvailable = function(email, callback) {
db.isObjectField('email:uid', email, function(err, exists) {
callback(err, !exists);
@@ -473,34 +490,36 @@ var bcrypt = require('bcrypt'),
User.search = function(query, callback) {
if (!query || query.length === 0) {
return callback(null, []);
return callback(null, {timing:0, users:[]});
}
var start = process.hrtime();
// TODO: Have this use db.getObjectKeys (doesn't exist yet)
db.getObject('username:uid', function(err, usernamesHash) {
if (err) {
return callback(null, []);
return callback(null, {timing: 0, users:[]});
}
query = query.toLowerCase();
var usernames = Object.keys(usernamesHash),
results = [];
results = usernames.filter(function(username) { // Remove non-matches
return username.indexOf(query) === 0;
}).sort(function(a, b) { // Sort alphabetically
results = usernames.filter(function(username) {
return username.toLowerCase().indexOf(query) === 0;
})
.slice(0, 10)
.sort(function(a, b) {
return a > b;
}).slice(0, 5) // Limit 5
.map(function(username) { // Translate to uids
})
.map(function(username) {
return usernamesHash[username];
});
if (results && results.length) {
User.getDataForUsers(results, function(userdata) {
callback(null, userdata);
});
} else {
callback(null, []);
}
User.getDataForUsers(results, function(userdata) {
var diff = process.hrtime(start);
var timing = (diff[0] * 1e3 + diff[1] / 1e6).toFixed(1);
callback(null, {timing: timing, users: userdata});
});
});
};