You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

219 lines
6.0 KiB
JavaScript

'use strict';
var async = require('async'),
10 years ago
winston = require('winston'),
db = require('../database'),
topics = require('../topics'),
user = require('../user'),
helpers = require('./helpers'),
groups = require('../groups'),
categories = require('../categories'),
plugins = require('../plugins');
module.exports = function(privileges) {
privileges.topics = {};
privileges.topics.get = function(tid, uid, callback) {
10 years ago
var topic;
async.waterfall([
10 years ago
async.apply(topics.getTopicFields, tid, ['cid', 'uid', 'locked']),
function(_topic, next) {
topic = _topic;
async.parallel({
'topics:reply': async.apply(helpers.isUserAllowedTo, 'topics:reply', uid, [topic.cid]),
read: async.apply(helpers.isUserAllowedTo, 'read', uid, [topic.cid]),
isOwner: function(next) {
next(null, parseInt(uid, 10) === parseInt(topic.uid, 10));
},
isAdministrator: async.apply(user.isAdministrator, uid),
isModerator: async.apply(user.isModerator, uid, topic.cid),
disabled: async.apply(categories.getCategoryField, topic.cid, 'disabled')
}, next);
}
], function(err, results) {
11 years ago
if (err) {
return callback(err);
}
var disabled = parseInt(results.disabled, 10) === 1;
10 years ago
var locked = parseInt(topic.locked, 10) === 1;
var isAdminOrMod = results.isAdministrator || results.isModerator;
10 years ago
var editable = isAdminOrMod;
var deletable = isAdminOrMod || results.isOwner;
plugins.fireHook('filter:privileges.topics.get', {
10 years ago
'topics:reply': (results['topics:reply'][0] && !locked) || isAdminOrMod,
read: results.read[0] || isAdminOrMod,
view_thread_tools: editable || deletable,
editable: editable,
deletable: deletable,
10 years ago
view_deleted: isAdminOrMod || results.isOwner,
disabled: disabled,
tid: tid,
uid: uid
}, callback);
});
};
privileges.topics.can = function(privilege, tid, uid, callback) {
topics.getTopicField(tid, 'cid', function(err, cid) {
if (err) {
return callback(err);
}
privileges.categories.can(privilege, cid, uid, callback);
});
};
privileges.topics.filterTids = function(privilege, tids, uid, callback) {
if (!Array.isArray(tids) || !tids.length) {
return callback(null, []);
}
10 years ago
async.waterfall([
function(next) {
topics.getTopicsFields(tids, ['tid', 'cid', 'deleted'], next);
},
function(topicsData, next) {
var cids = topicsData.map(function(topic) {
return topic.cid;
}).filter(function(cid, index, array) {
10 years ago
return cid && array.indexOf(cid) === index;
});
10 years ago
async.parallel({
categories: function(next) {
10 years ago
categories.getCategoriesFields(cids, ['disabled'], next);
10 years ago
},
allowedTo: function(next) {
helpers.isUserAllowedTo(privilege, uid, cids, next);
},
isModerators: function(next) {
user.isModerator(uid, cids, next);
},
isAdmin: function(next) {
user.isAdministrator(uid, next);
}
}, function(err, results) {
if (err) {
return next(err);
10 years ago
}
var isModOf = {};
cids = cids.filter(function(cid, index) {
isModOf[cid] = results.isModerators[index];
10 years ago
return !results.categories[index].disabled &&
10 years ago
(results.allowedTo[index] || results.isAdmin || results.isModerators[index]);
});
tids = topicsData.filter(function(topic) {
return cids.indexOf(topic.cid) !== -1 &&
(parseInt(topic.deleted, 10) !== 1 || results.isAdmin || isModOf[topic.cid]);
}).map(function(topic) {
return topic.tid;
});
plugins.fireHook('filter:privileges.topics.filter', {
privilege: privilege,
uid: uid,
tids: tids
}, function(err, data) {
next(err, data ? data.tids : null);
});
});
10 years ago
}
], callback);
};
privileges.topics.filterUids = function(privilege, tid, uids, callback) {
if (!Array.isArray(uids) || !uids.length) {
return callback(null, []);
}
uids = uids.filter(function(uid, index, array) {
return array.indexOf(uid) === index;
});
async.waterfall([
function(next) {
topics.getTopicFields(tid, ['tid', 'cid', 'deleted'], next);
},
function(topicData, next) {
async.parallel({
disabled: function(next) {
categories.getCategoryField(topicData.cid, 'disabled', next);
},
allowedTo: function(next) {
helpers.isUsersAllowedTo(privilege, uids, topicData.cid, next);
},
isModerators: function(next) {
user.isModerator(uids, topicData.cid, next);
},
isAdmins: function(next) {
user.isAdministrator(uids, next);
}
}, function(err, results) {
if (err) {
return next(err);
}
uids = uids.filter(function(uid, index) {
return parseInt(results.disabled, 10) !== 1 &&
((results.allowedTo[index] && parseInt(topicData.deleted, 10) !== 1) || results.isAdmins[index] || results.isModerators[index]);
});
next(null, uids);
});
}
], callback);
};
10 years ago
privileges.topics.canPurge = function(tid, uid, callback) {
async.waterfall([
function (next) {
topics.getTopicField(tid, 'cid', next);
},
function (cid, next) {
async.parallel({
purge: async.apply(privileges.categories.isUserAllowedTo, 'purge', cid, uid),
owner: async.apply(topics.isOwner, tid, uid),
isAdminOrMod: async.apply(privileges.categories.isAdminOrMod, cid, uid)
}, next);
},
function (results, next) {
next(null, results.isAdminOrMod || (results.purge && results.owner));
}
], callback);
};
10 years ago
privileges.topics.isOwnerOrAdminOrMod = function(tid, uid, callback) {
helpers.some([
function(next) {
11 years ago
topics.isOwner(tid, uid, next);
},
function(next) {
10 years ago
privileges.topics.isAdminOrMod(tid, uid, next);
}
], callback);
};
11 years ago
10 years ago
privileges.topics.isAdminOrMod = function(tid, uid, callback) {
helpers.some([
function(next) {
topics.getTopicField(tid, 'cid', function(err, cid) {
if (err) {
return next(err);
}
user.isModerator(uid, cid, next);
});
},
function(next) {
user.isAdministrator(uid, next);
}
], callback);
10 years ago
};
};