mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
fix: #8320, dont load moderators separately for each category
This commit is contained in:
@@ -1,8 +1,11 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
const _ = require('lodash');
|
||||||
|
|
||||||
const groups = require('../../groups');
|
const groups = require('../../groups');
|
||||||
const categories = require('../../categories');
|
const categories = require('../../categories');
|
||||||
const privileges = require('../../privileges');
|
const privileges = require('../../privileges');
|
||||||
|
const user = require('../../user');
|
||||||
|
|
||||||
const AdminsMods = module.exports;
|
const AdminsMods = module.exports;
|
||||||
|
|
||||||
@@ -23,9 +26,12 @@ AdminsMods.get = async function (req, res) {
|
|||||||
|
|
||||||
async function getModeratorsOfCategories(uid) {
|
async function getModeratorsOfCategories(uid) {
|
||||||
const categoryData = await categories.buildForSelect(uid, 'find', ['depth']);
|
const categoryData = await categories.buildForSelect(uid, 'find', ['depth']);
|
||||||
const moderators = await Promise.all(categoryData.map(c => categories.getModerators(c.cid)));
|
const moderatorUids = await categories.getModeratorUids(categoryData.map(c => c.cid));
|
||||||
|
const uids = _.uniq(_.flatten(moderatorUids));
|
||||||
|
const moderatorData = await user.getUsersFields(uids, ['uid', 'username', 'userslug', 'picture']);
|
||||||
|
const moderatorMap = _.zipObject(uids, moderatorData);
|
||||||
categoryData.forEach((c, index) => {
|
categoryData.forEach((c, index) => {
|
||||||
c.moderators = moderators[index];
|
c.moderators = moderatorUids[index].map(uid => moderatorMap[uid]);
|
||||||
});
|
});
|
||||||
return categoryData;
|
return categoryData;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user