v1.18.x
Baris Soner Usakli 11 years ago
parent 042174290f
commit b717c74a81

@ -207,18 +207,22 @@ var winston = require('winston'),
}); });
}); });
Feed.updateTopic(postData.tid);
Feed.updateRecent();
db.searchIndex('post', postData.content, pid);
// Restore topic if it is the only post // Restore topic if it is the only post
topics.getTopicField(postData.tid, 'postcount', function(err, count) { topics.getTopicField(postData.tid, 'postcount', function(err, count) {
if (parseInt(count, 10) === 1) { if (parseInt(count, 10) === 1) {
threadTools.restore(postData.tid, uid); threadTools.restore(postData.tid, uid, function(err) {
if(err) {
winston.err(err);
}
});
} }
}); });
Feed.updateTopic(postData.tid);
Feed.updateRecent();
db.searchIndex('post', postData.content, pid);
callback(); callback();
}); });
}; };

@ -58,51 +58,69 @@ var winston = require('winston'),
} }
ThreadTools.delete = function(tid, uid, callback) { ThreadTools.delete = function(tid, uid, callback) {
topics.delete(tid); topics.getTopicField(tid, 'deleted', function(err, deleted) {
if(err) {
return callback(err);
}
if (parseInt(deleted, 10)) {
return callback(new Error('topic-already-deleted'));
}
db.decrObjectField('global', 'topicCount'); topics.delete(tid);
ThreadTools.lock(tid); db.decrObjectField('global', 'topicCount');
db.searchRemove('topic', tid); ThreadTools.lock(tid);
events.logTopicDelete(uid, tid); db.searchRemove('topic', tid);
websockets.emitTopicPostStats(); events.logTopicDelete(uid, tid);
websockets.in('topic_' + tid).emit('event:topic_deleted', { websockets.emitTopicPostStats();
tid: tid
}); websockets.in('topic_' + tid).emit('event:topic_deleted', {
tid: tid
});
if (callback) {
callback(null, { callback(null, {
tid: tid tid: tid
}); });
} });
} }
ThreadTools.restore = function(tid, uid, callback) { ThreadTools.restore = function(tid, uid, callback) {
topics.restore(tid); topics.getTopicField(tid, 'deleted', function(err, deleted) {
db.incrObjectField('global', 'topicCount'); if(err) {
ThreadTools.unlock(tid); return callback(err);
}
events.logTopicRestore(uid, tid); if (!parseInt(deleted, 10)) {
return callback(new Error('topic-already-restored'));
}
websockets.emitTopicPostStats(); topics.restore(tid);
websockets.in('topic_' + tid).emit('event:topic_restored', { db.incrObjectField('global', 'topicCount');
tid: tid
});
topics.getTopicField(tid, 'title', function(err, title) { ThreadTools.unlock(tid);
db.searchIndex('topic', title, tid);
}); events.logTopicRestore(uid, tid);
websockets.emitTopicPostStats();
websockets.in('topic_' + tid).emit('event:topic_restored', {
tid: tid
});
topics.getTopicField(tid, 'title', function(err, title) {
db.searchIndex('topic', title, tid);
});
if(callback) {
callback(null, { callback(null, {
tid:tid tid:tid
}); });
} });
} }
ThreadTools.lock = function(tid, uid, callback) { ThreadTools.lock = function(tid, uid, callback) {

Loading…
Cancel
Save