Files
NodeBB/src/privileges/topics.js

141 lines
3.3 KiB
JavaScript
Raw Normal View History

'use strict';
var async = require('async'),
db = require('../database'),
topics = require('../topics'),
user = require('../user'),
helpers = require('./helpers'),
groups = require('../groups'),
categories = require('../categories');
module.exports = function(privileges) {
privileges.topics = {};
privileges.topics.get = function(tid, uid, callback) {
2014-05-15 10:49:53 -04:00
topics.getTopicField(tid, 'cid', function(err, cid) {
if (err) {
return callback(err);
}
2014-05-15 10:49:53 -04:00
async.parallel({
'topics:reply': function(next) {
helpers.allowedTo('topics:reply', uid, cid, next);
},
read: function(next) {
helpers.allowedTo('read', uid, cid, next);
},
2014-06-23 17:26:02 -04:00
isOwner: function(next) {
topics.isOwner(tid, uid, next);
},
manage_topic: function(next) {
helpers.hasEnoughReputationFor('privileges:manage_topic', uid, next);
},
isAdministrator: function(next) {
user.isAdministrator(uid, next);
},
isModerator: function(next) {
user.isModerator(uid, cid, next);
2014-07-30 15:14:04 -04:00
},
disabled: function(next) {
categories.getCategoryField(cid, 'disabled', next);
}
}, function(err, results) {
if(err) {
return callback(err);
}
2014-07-30 15:14:04 -04:00
var disabled = parseInt(results.disabled, 10) === 1;
2014-06-23 17:26:02 -04:00
var isAdminOrMod = results.isAdministrator || results.isModerator;
2014-07-30 15:14:04 -04:00
var editable = isAdminOrMod || results.manage_topic;
2014-06-23 17:26:02 -04:00
var deletable = isAdminOrMod || results.isOwner;
callback(null, {
2014-05-22 14:56:15 -04:00
'topics:reply': results['topics:reply'],
2014-06-23 17:26:02 -04:00
read: results.read,
view_thread_tools: editable || deletable,
2014-05-22 14:56:15 -04:00
editable: editable,
2014-06-23 17:26:02 -04:00
deletable: deletable,
2014-07-30 15:14:04 -04:00
view_deleted: isAdminOrMod || results.manage_topic || results.isOwner,
disabled: disabled
});
});
});
};
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.filter = function(privilege, tids, uid, callback) {
var keys = tids.map(function(tid) {
return 'topic:' + tid;
});
db.getObjectsFields(keys, ['tid', 'cid'], function(err, topics) {
if (err) {
return callback(err);
}
var cids = topics.map(function(topic) {
return topic.cid;
});
privileges.categories.filter(privilege, cids, uid, function(err, cids) {
if (err) {
return callback(err);
}
tids = topics.filter(function(topic) {
return cids.indexOf(topic.cid) !== -1;
}).map(function(topic) {
return topic.tid;
});
callback(null, tids);
});
});
};
privileges.topics.canEdit = function(tid, uid, callback) {
helpers.some([
function(next) {
2014-06-23 17:26:02 -04:00
topics.isOwner(tid, uid, next);
},
function(next) {
2014-06-23 17:26:02 -04:00
helpers.hasEnoughReputationFor('privileges:manage_topic', uid, next);
},
function(next) {
2014-06-23 17:26:02 -04:00
isAdminOrMod(tid, uid, next);
}
], callback);
};
privileges.topics.canMove = function(tid, uid, callback) {
2014-06-23 17:26:02 -04:00
isAdminOrMod(tid, uid, callback);
};
function isAdminOrMod(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);
2014-06-23 17:26:02 -04:00
}
};