Merge remote-tracking branch 'origin' into notifications
Conflicts: public/css/style.less public/src/app.js src/websockets.jsv1.18.x
commit
ffbafc99c4
@ -0,0 +1,92 @@
|
|||||||
|
var RDB = require('./redis.js'),
|
||||||
|
posts = require('./posts.js'),
|
||||||
|
threadTools = require('./threadTools.js'),
|
||||||
|
user = require('./user.js'),
|
||||||
|
config = require('../config.js'),
|
||||||
|
async = require('async'),
|
||||||
|
marked = require('marked');
|
||||||
|
|
||||||
|
marked.setOptions({
|
||||||
|
breaks: true
|
||||||
|
});
|
||||||
|
|
||||||
|
(function(PostTools) {
|
||||||
|
|
||||||
|
PostTools.privileges = function(pid, uid, callback) {
|
||||||
|
//todo: break early if one condition is true
|
||||||
|
|
||||||
|
function getThreadPrivileges(next) {
|
||||||
|
posts.get_tid_by_pid(pid, function(tid) {
|
||||||
|
threadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
next(null, privileges);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function isOwnPost(next) {
|
||||||
|
RDB.get('pid:' + pid + ':uid', function(err, author) {
|
||||||
|
if (author && parseInt(author) > 0) next(null, author === uid);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function hasEnoughRep(next) {
|
||||||
|
// DRY fail in threadTools.
|
||||||
|
|
||||||
|
user.getUserField(uid, 'reputation', function(reputation) {
|
||||||
|
next(null, reputation >= config.privilege_thresholds.manage_content);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async.parallel([getThreadPrivileges, isOwnPost, hasEnoughRep], function(err, results) {
|
||||||
|
callback({
|
||||||
|
editable: results[0].editable || (results.slice(1).indexOf(true) !== -1 ? true : false),
|
||||||
|
view_deleted: results[0].view_deleted || (results.slice(1).indexOf(true) !== -1 ? true : false)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
PostTools.edit = function(uid, pid, content) {
|
||||||
|
var success = function() {
|
||||||
|
RDB.set('pid:' + pid + ':content', content);
|
||||||
|
RDB.set('pid:' + pid + ':edited', new Date().getTime());
|
||||||
|
RDB.set('pid:' + pid + ':editor', uid);
|
||||||
|
|
||||||
|
posts.get_tid_by_pid(pid, function(tid) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:post_edited', { pid: pid, content: marked(content || '') });
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
PostTools.privileges(pid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) success();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
PostTools.delete = function(uid, pid) {
|
||||||
|
var success = function() {
|
||||||
|
RDB.set('pid:' + pid + ':deleted', 1);
|
||||||
|
|
||||||
|
posts.get_tid_by_pid(pid, function(tid) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:post_deleted', { pid: pid });
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
PostTools.privileges(pid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) success();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
PostTools.restore = function(uid, pid) {
|
||||||
|
var success = function() {
|
||||||
|
RDB.del('pid:' + pid + ':deleted');
|
||||||
|
|
||||||
|
posts.get_tid_by_pid(pid, function(tid) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:post_restored', { pid: pid });
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
PostTools.privileges(pid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) success();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}(exports));
|
@ -0,0 +1,157 @@
|
|||||||
|
var RDB = require('./redis.js'),
|
||||||
|
topics = require('./topics.js'),
|
||||||
|
categories = require('./categories.js'),
|
||||||
|
user = require('./user.js'),
|
||||||
|
config = require('../config.js'),
|
||||||
|
async = require('async');
|
||||||
|
|
||||||
|
|
||||||
|
(function(ThreadTools) {
|
||||||
|
|
||||||
|
ThreadTools.privileges = function(tid, uid, callback) {
|
||||||
|
//todo: break early if one condition is true
|
||||||
|
|
||||||
|
function getCategoryPrivileges(next) {
|
||||||
|
topics.get_cid_by_tid(tid, function(cid) {
|
||||||
|
categories.privileges(cid, uid, function(privileges) {
|
||||||
|
next(null, privileges);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function hasEnoughRep(next) {
|
||||||
|
// DRY fail in postTools
|
||||||
|
|
||||||
|
user.getUserField(uid, 'reputation', function(reputation) {
|
||||||
|
next(null, reputation >= config.privilege_thresholds.manage_thread);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
async.parallel([getCategoryPrivileges, hasEnoughRep], function(err, results) {
|
||||||
|
callback({
|
||||||
|
editable: results[0].editable || (results.slice(1).indexOf(true) !== -1 ? true : false),
|
||||||
|
view_deleted: results[0].view_deleted || (results.slice(1).indexOf(true) !== -1 ? true : false)
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.lock = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as locked
|
||||||
|
RDB.set('tid:' + tid + ':locked', 1);
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_locked', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.unlock = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as unlocked
|
||||||
|
RDB.del('tid:' + tid + ':locked');
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_unlocked', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.delete = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as deleted
|
||||||
|
RDB.set('tid:' + tid + ':deleted', 1);
|
||||||
|
ThreadTools.lock(tid, uid);
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_deleted', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.restore = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as restored
|
||||||
|
RDB.del('tid:' + tid + ':deleted');
|
||||||
|
ThreadTools.unlock(tid, uid);
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_restored', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.pin = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as pinned
|
||||||
|
RDB.set('tid:' + tid + ':pinned', 1);
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_pinned', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.unpin = function(tid, uid, socket) {
|
||||||
|
ThreadTools.privileges(tid, uid, function(privileges) {
|
||||||
|
if (privileges.editable) {
|
||||||
|
// Mark thread as unpinned
|
||||||
|
RDB.del('tid:' + tid + ':pinned');
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_unpinned', {
|
||||||
|
tid: tid,
|
||||||
|
status: 'ok'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
ThreadTools.move = function(tid, cid, socket) {
|
||||||
|
RDB.get('tid:' + tid + ':cid', function(err, oldCid) {
|
||||||
|
RDB.handle(err);
|
||||||
|
|
||||||
|
RDB.smove('categories:' + oldCid + ':tid', 'categories:' + cid + ':tid', tid, function(err, result) {
|
||||||
|
if (!err && result === 1) {
|
||||||
|
RDB.set('tid:' + tid + ':cid', cid);
|
||||||
|
categories.get_category([cid], function(data) {
|
||||||
|
RDB.set('tid:' + tid + ':category_name', data.categories[0].name);
|
||||||
|
RDB.set('tid:' + tid + ':category_slug', data.categories[0].slug);
|
||||||
|
});
|
||||||
|
socket.emit('api:topic.move', { status: 'ok' });
|
||||||
|
io.sockets.in('topic_' + tid).emit('event:topic_moved', { tid: tid });
|
||||||
|
} else {
|
||||||
|
socket.emit('api:topic.move', { status: 'error' });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}(exports));
|
Loading…
Reference in New Issue