refactor: move canPostTopic to privs and use on /unread /tag

This commit is contained in:
Barış Soner Uşaklı
2022-12-13 11:05:06 -05:00
parent b2a59900e3
commit 9b3616b103
4 changed files with 14 additions and 9 deletions

View File

@@ -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']);

View File

@@ -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', '')}`;

View File

@@ -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', '')}`;

View File

@@ -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);