|
|
@ -1,17 +1,17 @@
|
|
|
|
var db = require('./database'),
|
|
|
|
var winston = require('winston'),
|
|
|
|
|
|
|
|
async = require('async'),
|
|
|
|
|
|
|
|
nconf = require('nconf'),
|
|
|
|
|
|
|
|
validator = require('validator'),
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
db = require('./database'),
|
|
|
|
posts = require('./posts'),
|
|
|
|
posts = require('./posts'),
|
|
|
|
topics = require('./topics'),
|
|
|
|
topics = require('./topics'),
|
|
|
|
threadTools = require('./threadTools'),
|
|
|
|
threadTools = require('./threadTools'),
|
|
|
|
user = require('./user'),
|
|
|
|
user = require('./user'),
|
|
|
|
websockets = require('./websockets'),
|
|
|
|
websockets = require('./websockets'),
|
|
|
|
async = require('async'),
|
|
|
|
|
|
|
|
nconf = require('nconf'),
|
|
|
|
|
|
|
|
validator = require('validator'),
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
utils = require('../public/src/utils'),
|
|
|
|
utils = require('../public/src/utils'),
|
|
|
|
plugins = require('./plugins'),
|
|
|
|
plugins = require('./plugins'),
|
|
|
|
|
|
|
|
events = require('./events'),
|
|
|
|
winston = require('winston'),
|
|
|
|
|
|
|
|
meta = require('./meta'),
|
|
|
|
meta = require('./meta'),
|
|
|
|
Feed = require('./feed');
|
|
|
|
Feed = require('./feed');
|
|
|
|
|
|
|
|
|
|
|
@ -70,20 +70,13 @@ var db = require('./database'),
|
|
|
|
PostTools.edit = function(uid, pid, title, content) {
|
|
|
|
PostTools.edit = function(uid, pid, title, content) {
|
|
|
|
|
|
|
|
|
|
|
|
var success = function() {
|
|
|
|
var success = function() {
|
|
|
|
async.waterfall([
|
|
|
|
posts.setPostFields(pid, {
|
|
|
|
function(next) {
|
|
|
|
edited: Date.now(),
|
|
|
|
posts.setPostField(pid, 'edited', Date.now());
|
|
|
|
editor: uid,
|
|
|
|
next(null);
|
|
|
|
content: content
|
|
|
|
},
|
|
|
|
});
|
|
|
|
function(next) {
|
|
|
|
|
|
|
|
posts.setPostField(pid, 'editor', uid);
|
|
|
|
events.logPostEdit(uid, pid);
|
|
|
|
next(null);
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
function(next) {
|
|
|
|
|
|
|
|
posts.setPostField(pid, 'content', content);
|
|
|
|
|
|
|
|
next(null);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
db.searchRemove('post', pid, function() {
|
|
|
|
db.searchRemove('post', pid, function() {
|
|
|
|
db.searchIndex('post', content, pid);
|
|
|
|
db.searchIndex('post', content, pid);
|
|
|
@ -136,6 +129,8 @@ var db = require('./database'),
|
|
|
|
db.decrObjectField('global', 'postCount');
|
|
|
|
db.decrObjectField('global', 'postCount');
|
|
|
|
db.searchRemove('post', pid);
|
|
|
|
db.searchRemove('post', pid);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
events.logPostDelete(uid, pid);
|
|
|
|
|
|
|
|
|
|
|
|
posts.getPostFields(pid, ['tid', 'uid'], function(err, postData) {
|
|
|
|
posts.getPostFields(pid, ['tid', 'uid'], function(err, postData) {
|
|
|
|
db.incrObjectFieldBy('topic:' + postData.tid, 'postcount', -1);
|
|
|
|
db.incrObjectFieldBy('topic:' + postData.tid, 'postcount', -1);
|
|
|
|
|
|
|
|
|
|
|
@ -190,6 +185,8 @@ var db = require('./database'),
|
|
|
|
posts.setPostField(pid, 'deleted', 0);
|
|
|
|
posts.setPostField(pid, 'deleted', 0);
|
|
|
|
db.incrObjectField('global', 'postCount');
|
|
|
|
db.incrObjectField('global', 'postCount');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
events.logPostRestore(uid, pid);
|
|
|
|
|
|
|
|
|
|
|
|
posts.getPostFields(pid, ['tid', 'uid', 'content'], function(err, postData) {
|
|
|
|
posts.getPostFields(pid, ['tid', 'uid', 'content'], function(err, postData) {
|
|
|
|
db.incrObjectFieldBy('topic:' + postData.tid, 'postcount', 1);
|
|
|
|
db.incrObjectFieldBy('topic:' + postData.tid, 'postcount', 1);
|
|
|
|
|
|
|
|
|
|
|
|