flat is good

v1.18.x
barisusakli 10 years ago
parent 768c17263c
commit 9865f78cbb

@ -2,6 +2,7 @@
var async = require('async'), var async = require('async'),
nconf = require('nconf'), nconf = require('nconf'),
winston = require('winston'),
db = require('../database'), db = require('../database'),
posts = require('../posts'), posts = require('../posts'),
@ -46,25 +47,28 @@ SocketPosts.reply = function(socket, data, callback) {
socket.emit('event:new_post', result); socket.emit('event:new_post', result);
user.getUidsFromSet('users:online', 0, -1, function(err, uids) { async.waterfall([
function(next) {
user.getUidsFromSet('users:online', 0, -1, next);
},
function(uids, next) {
privileges.categories.filterUids('read', postData.topic.cid, uids, next);
},
function(uids, next) {
plugins.fireHook('filter:sockets.sendNewPostToUids', {uidsTo: uids, uidFrom: data.uid, type: 'newPost'}, next);
}
], function(err, data) {
if (err) { if (err) {
return; return winston.error(err.stack);
} }
privileges.categories.filterUids('read', postData.topic.cid, uids, function(err, uids) {
if (err) {
return;
}
plugins.fireHook('filter:sockets.sendNewPostToUids', {uidsTo: uids, uidFrom: data.uid, type: "newPost"}, function(err, data) { var uids = data.uidsTo;
uids = data.uidsTo;
for(var i=0; i<uids.length; ++i) { for(var i=0; i<uids.length; ++i) {
if (parseInt(uids[i], 10) !== socket.uid) { if (parseInt(uids[i], 10) !== socket.uid) {
websockets.in('uid_' + uids[i]).emit('event:new_post', result); websockets.in('uid_' + uids[i]).emit('event:new_post', result);
} }
} }
});
});
}); });
}); });
}; };

@ -3,6 +3,7 @@
var nconf = require('nconf'), var nconf = require('nconf'),
async = require('async'), async = require('async'),
winston = require('winston'),
topics = require('../topics'), topics = require('../topics'),
categories = require('../categories'), categories = require('../categories'),
@ -41,27 +42,29 @@ SocketTopics.post = function(socket, data, callback) {
socket.emit('event:new_post', {posts: [result.postData]}); socket.emit('event:new_post', {posts: [result.postData]});
socket.emit('event:new_topic', result.topicData); socket.emit('event:new_topic', result.topicData);
user.getUidsFromSet('users:online', 0, -1, function(err, uids) { async.waterfall([
function(next) {
user.getUidsFromSet('users:online', 0, -1, next);
},
function(uids, next) {
privileges.categories.filterUids('read', result.topicData.cid, uids, next);
},
function(uids, next) {
plugins.fireHook('filter:sockets.sendNewPostToUids', {uidsTo: uids, uidFrom: data.uid, type: 'newTopic'}, next);
}
], function(err, data) {
if (err) { if (err) {
return; return winston.error(err.stack);
} }
privileges.categories.filterUids('read', result.topicData.cid, uids, function(err, uids) { var uids = data.uidsTo;
if (err) {
return;
}
plugins.fireHook('filter:sockets.sendNewPostToUids', {uidsTo: uids, uidFrom: data.uid, type: "newTopic"}, function(err, data) {
uids = data.uidsTo;
for(var i=0; i<uids.length; ++i) { for(var i=0; i<uids.length; ++i) {
if (parseInt(uids[i], 10) !== socket.uid) { if (parseInt(uids[i], 10) !== socket.uid) {
websockets.in('uid_' + uids[i]).emit('event:new_post', {posts: [result.postData]}); websockets.in('uid_' + uids[i]).emit('event:new_post', {posts: [result.postData]});
websockets.in('uid_' + uids[i]).emit('event:new_topic', result.topicData); websockets.in('uid_' + uids[i]).emit('event:new_topic', result.topicData);
} }
} }
});
});
}); });
}); });
}; };

Loading…
Cancel
Save