mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-06 14:05:46 +01:00
refactor: move canPostTopic to privs and use on /unread /tag
This commit is contained in:
@@ -4,7 +4,6 @@
|
|||||||
const nconf = require('nconf');
|
const nconf = require('nconf');
|
||||||
|
|
||||||
const user = require('../user');
|
const user = require('../user');
|
||||||
const categories = require('../categories');
|
|
||||||
const topics = require('../topics');
|
const topics = require('../topics');
|
||||||
const meta = require('../meta');
|
const meta = require('../meta');
|
||||||
const helpers = require('./helpers');
|
const helpers = require('./helpers');
|
||||||
@@ -37,7 +36,7 @@ recentController.getData = async function (req, url, sort) {
|
|||||||
user.getSettings(req.uid),
|
user.getSettings(req.uid),
|
||||||
helpers.getSelectedCategory(cid),
|
helpers.getSelectedCategory(cid),
|
||||||
user.auth.getFeedToken(req.uid),
|
user.auth.getFeedToken(req.uid),
|
||||||
canPostTopic(req.uid),
|
privileges.categories.canPostTopic(req.uid),
|
||||||
user.isPrivileged(req.uid),
|
user.isPrivileged(req.uid),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@@ -90,10 +89,5 @@ recentController.getData = async function (req, url, sort) {
|
|||||||
return data;
|
return data;
|
||||||
};
|
};
|
||||||
|
|
||||||
async function canPostTopic(uid) {
|
|
||||||
let cids = await categories.getAllCidsFromSet('categories:cid');
|
|
||||||
cids = await privileges.categories.filterCids('topics:create', cids, uid);
|
|
||||||
return cids.length > 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
require('../promisify')(recentController, ['get']);
|
require('../promisify')(recentController, ['get']);
|
||||||
|
|||||||
@@ -25,10 +25,11 @@ tagsController.getTag = async function (req, res) {
|
|||||||
breadcrumbs: helpers.buildBreadcrumbs([{ text: '[[tags:tags]]', url: '/tags' }, { text: tag }]),
|
breadcrumbs: helpers.buildBreadcrumbs([{ text: '[[tags:tags]]', url: '/tags' }, { text: tag }]),
|
||||||
title: `[[pages:tag, ${tag}]]`,
|
title: `[[pages:tag, ${tag}]]`,
|
||||||
};
|
};
|
||||||
const [settings, cids, categoryData, isPrivileged] = await Promise.all([
|
const [settings, cids, categoryData, canPost, isPrivileged] = await Promise.all([
|
||||||
user.getSettings(req.uid),
|
user.getSettings(req.uid),
|
||||||
cid || categories.getCidsByPrivilege('categories:cid', req.uid, 'topics:read'),
|
cid || categories.getCidsByPrivilege('categories:cid', req.uid, 'topics:read'),
|
||||||
helpers.getSelectedCategory(cid),
|
helpers.getSelectedCategory(cid),
|
||||||
|
privileges.categories.canPostTopic(req.uid),
|
||||||
user.isPrivileged(req.uid),
|
user.isPrivileged(req.uid),
|
||||||
]);
|
]);
|
||||||
const start = Math.max(0, (page - 1) * settings.topicsPerPage);
|
const start = Math.max(0, (page - 1) * settings.topicsPerPage);
|
||||||
@@ -40,6 +41,7 @@ tagsController.getTag = async function (req, res) {
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
templateData.topics = await topics.getTopics(tids, req.uid);
|
templateData.topics = await topics.getTopics(tids, req.uid);
|
||||||
|
templateData.canPost = canPost;
|
||||||
templateData.showSelect = isPrivileged;
|
templateData.showSelect = isPrivileged;
|
||||||
templateData.showTopicTools = isPrivileged;
|
templateData.showTopicTools = isPrivileged;
|
||||||
templateData.allCategoriesUrl = `tags/${tag}${helpers.buildQueryString(req.query, 'cid', '')}`;
|
templateData.allCategoriesUrl = `tags/${tag}${helpers.buildQueryString(req.query, 'cid', '')}`;
|
||||||
|
|||||||
@@ -9,6 +9,7 @@ const pagination = require('../pagination');
|
|||||||
const user = require('../user');
|
const user = require('../user');
|
||||||
const topics = require('../topics');
|
const topics = require('../topics');
|
||||||
const helpers = require('./helpers');
|
const helpers = require('./helpers');
|
||||||
|
const privileges = require('../privileges');
|
||||||
|
|
||||||
const unreadController = module.exports;
|
const unreadController = module.exports;
|
||||||
const relative_path = nconf.get('relative_path');
|
const relative_path = nconf.get('relative_path');
|
||||||
@@ -17,9 +18,10 @@ unreadController.get = async function (req, res) {
|
|||||||
const { cid } = req.query;
|
const { cid } = req.query;
|
||||||
const filter = req.query.filter || '';
|
const filter = req.query.filter || '';
|
||||||
|
|
||||||
const [categoryData, userSettings, isPrivileged] = await Promise.all([
|
const [categoryData, userSettings, canPost, isPrivileged] = await Promise.all([
|
||||||
helpers.getSelectedCategory(cid),
|
helpers.getSelectedCategory(cid),
|
||||||
user.getSettings(req.uid),
|
user.getSettings(req.uid),
|
||||||
|
privileges.categories.canPostTopic(req.uid),
|
||||||
user.isPrivileged(req.uid),
|
user.isPrivileged(req.uid),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@@ -53,6 +55,7 @@ unreadController.get = async function (req, res) {
|
|||||||
req.query.page = Math.max(1, Math.min(data.pageCount, page));
|
req.query.page = Math.max(1, Math.min(data.pageCount, page));
|
||||||
return helpers.redirect(res, `/unread?${querystring.stringify(req.query)}`);
|
return helpers.redirect(res, `/unread?${querystring.stringify(req.query)}`);
|
||||||
}
|
}
|
||||||
|
data.canPost = canPost;
|
||||||
data.showSelect = true;
|
data.showSelect = true;
|
||||||
data.showTopicTools = isPrivileged;
|
data.showTopicTools = isPrivileged;
|
||||||
data.allCategoriesUrl = `${baseUrl}${helpers.buildQueryString(req.query, 'cid', '')}`;
|
data.allCategoriesUrl = `${baseUrl}${helpers.buildQueryString(req.query, 'cid', '')}`;
|
||||||
|
|||||||
@@ -208,6 +208,12 @@ privsCategories.canMoveAllTopics = async function (currentCid, targetCid, uid) {
|
|||||||
return isAdmin || !isModerators.includes(false);
|
return isAdmin || !isModerators.includes(false);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
privsCategories.canPostTopic = async function (uid) {
|
||||||
|
let cids = await categories.getAllCidsFromSet('categories:cid');
|
||||||
|
cids = await privsCategories.filterCids('topics:create', cids, uid);
|
||||||
|
return cids.length > 0;
|
||||||
|
};
|
||||||
|
|
||||||
privsCategories.userPrivileges = async function (cid, uid) {
|
privsCategories.userPrivileges = async function (cid, uid) {
|
||||||
const userPrivilegeList = await privsCategories.getUserPrivilegeList();
|
const userPrivilegeList = await privsCategories.getUserPrivilegeList();
|
||||||
return await helpers.userOrGroupPrivileges(cid, uid, userPrivilegeList);
|
return await helpers.userOrGroupPrivileges(cid, uid, userPrivilegeList);
|
||||||
|
|||||||
Reference in New Issue
Block a user