mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-12-24 01:10:31 +01:00
send new post/topic to users who can read it
This commit is contained in:
@@ -31,30 +31,34 @@ SocketPosts.reply = function(socket, data, callback) {
|
||||
return callback(err);
|
||||
}
|
||||
|
||||
if (postData) {
|
||||
var privileges = {
|
||||
var result = {
|
||||
posts: [postData],
|
||||
privileges: {
|
||||
'topics:reply': true
|
||||
},
|
||||
'reputation:disabled': parseInt(meta.config['reputation:disabled'], 10) === 1,
|
||||
'downvote:disabled': parseInt(meta.config['downvote:disabled'], 10) === 1,
|
||||
};
|
||||
|
||||
callback();
|
||||
|
||||
socket.emit('event:new_post', {
|
||||
posts: [postData],
|
||||
privileges: privileges,
|
||||
'reputation:disabled': parseInt(meta.config['reputation:disabled'], 10) === 1,
|
||||
'downvote:disabled': parseInt(meta.config['downvote:disabled'], 10) === 1,
|
||||
});
|
||||
socket.emit('event:new_post', result);
|
||||
|
||||
socket.broadcast.emit('event:new_post', {
|
||||
posts: [postData],
|
||||
privileges: privileges,
|
||||
'reputation:disabled': parseInt(meta.config['reputation:disabled'], 10) === 1,
|
||||
'downvote:disabled': parseInt(meta.config['downvote:disabled'], 10) === 1,
|
||||
var uids = websockets.getConnectedClients();
|
||||
|
||||
privileges.categories.filterUids('read', postData.topic.cid, uids, function(err, uids) {
|
||||
if (err) {
|
||||
return;
|
||||
}
|
||||
for(var i=0; i<uids.length; ++i) {
|
||||
if (uids[i] !== socket.uid) {
|
||||
websockets.in('uid_' + uids[i]).emit('event:new_post', result);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
websockets.emitTopicPostStats();
|
||||
topics.pushUnreadCount();
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
@@ -19,7 +19,6 @@ var nconf = require('nconf'),
|
||||
SocketTopics = {};
|
||||
|
||||
SocketTopics.post = function(socket, data, callback) {
|
||||
|
||||
if(!data) {
|
||||
return callback(new Error('[[error:invalid-data]]'));
|
||||
}
|
||||
@@ -37,23 +36,26 @@ SocketTopics.post = function(socket, data, callback) {
|
||||
return callback(err);
|
||||
}
|
||||
|
||||
if (result) {
|
||||
callback(null, result.topicData);
|
||||
socket.emit('event:new_post', {posts: result.postData});
|
||||
socket.emit('event:new_topic', result.topicData);
|
||||
|
||||
websockets.server.sockets.in('category_' + data.category_id).emit('event:new_topic', result.topicData);
|
||||
websockets.server.sockets.in('recent_posts').emit('event:new_topic', result.topicData);
|
||||
websockets.server.sockets.in('home').emit('event:new_topic', result.topicData);
|
||||
websockets.server.sockets.in('home').emit('event:new_post', {
|
||||
posts: result.postData
|
||||
});
|
||||
websockets.server.sockets.in('user/' + socket.uid).emit('event:new_post', {
|
||||
posts: result.postData
|
||||
var uids = websockets.getConnectedClients();
|
||||
|
||||
privileges.categories.filterUids('read', result.topicData.cid, uids, function(err, uids) {
|
||||
if (err) {
|
||||
return;
|
||||
}
|
||||
for(var i=0; i<uids.length; ++i) {
|
||||
if (uids[i] !== socket.uid) {
|
||||
websockets.in('uid_' + uids[i]).emit('event:new_post', result.postData);
|
||||
websockets.in('uid_' + uids[i]).emit('event:new_topic', result.topicData);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
websockets.emitTopicPostStats();
|
||||
topics.pushUnreadCount();
|
||||
|
||||
callback(null, result.topicData);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user