mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-29 18:16:17 +01:00
more topic tests
This commit is contained in:
@@ -1,12 +1,14 @@
|
||||
'use strict';
|
||||
|
||||
var async = require('async');
|
||||
|
||||
var topics = require('../topics');
|
||||
var websockets = require('./index');
|
||||
var user = require('../user');
|
||||
var apiController = require('../controllers/api');
|
||||
var socketHelpers = require('./helpers');
|
||||
|
||||
var SocketTopics = {};
|
||||
var SocketTopics = module.exports;
|
||||
|
||||
require('./topics/unread')(SocketTopics);
|
||||
require('./topics/move')(SocketTopics);
|
||||
@@ -23,18 +25,19 @@ SocketTopics.post = function (socket, data, callback) {
|
||||
data.req = websockets.reqFromSocket(socket);
|
||||
data.timestamp = Date.now();
|
||||
|
||||
topics.post(data, function (err, result) {
|
||||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
topics.post(data, next);
|
||||
},
|
||||
function (result, next) {
|
||||
next(null, result.topicData);
|
||||
|
||||
callback(null, result.topicData);
|
||||
socket.emit('event:new_post', { posts: [result.postData] });
|
||||
socket.emit('event:new_topic', result.topicData);
|
||||
|
||||
socket.emit('event:new_post', { posts: [result.postData] });
|
||||
socket.emit('event:new_topic', result.topicData);
|
||||
|
||||
socketHelpers.notifyNew(socket.uid, 'newTopic', { posts: [result.postData], topic: result.topicData });
|
||||
});
|
||||
socketHelpers.notifyNew(socket.uid, 'newTopic', { posts: [result.postData], topic: result.topicData });
|
||||
},
|
||||
], callback);
|
||||
};
|
||||
|
||||
SocketTopics.postcount = function (socket, tid, callback) {
|
||||
@@ -61,7 +64,7 @@ SocketTopics.createTopicFromPosts = function (socket, data, callback) {
|
||||
};
|
||||
|
||||
SocketTopics.changeWatching = function (socket, data, callback) {
|
||||
if (!data.tid || !data.type) {
|
||||
if (!data || !data.tid || !data.type) {
|
||||
return callback(new Error('[[error:invalid-data]]'));
|
||||
}
|
||||
var commands = ['follow', 'unfollow', 'ignore'];
|
||||
@@ -90,20 +93,23 @@ SocketTopics.isFollowed = function (socket, tid, callback) {
|
||||
};
|
||||
|
||||
SocketTopics.search = function (socket, data, callback) {
|
||||
if (!data) {
|
||||
return callback(new Error('[[error:invalid-data]]'));
|
||||
}
|
||||
topics.search(data.tid, data.term, callback);
|
||||
};
|
||||
|
||||
SocketTopics.isModerator = function (socket, tid, callback) {
|
||||
topics.getTopicField(tid, 'cid', function (err, cid) {
|
||||
if (err) {
|
||||
return callback(err);
|
||||
}
|
||||
user.isModerator(socket.uid, cid, callback);
|
||||
});
|
||||
async.waterfall([
|
||||
function (next) {
|
||||
topics.getTopicField(tid, 'cid', next);
|
||||
},
|
||||
function (cid, next) {
|
||||
user.isModerator(socket.uid, cid, next);
|
||||
},
|
||||
], callback);
|
||||
};
|
||||
|
||||
SocketTopics.getTopic = function (socket, tid, callback) {
|
||||
apiController.getTopicData(tid, socket.uid, callback);
|
||||
};
|
||||
|
||||
module.exports = SocketTopics;
|
||||
|
||||
Reference in New Issue
Block a user