mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
fix: flawed logic in generating topic context collection
This commit is contained in:
@@ -386,7 +386,7 @@ Helpers.generateCollection = async ({ set, method, page, perPage, url }) => {
|
||||
totalItems: count,
|
||||
};
|
||||
|
||||
if (items) {
|
||||
if (items.length) {
|
||||
object.orderedItems = items;
|
||||
|
||||
if (paginate) {
|
||||
|
||||
@@ -90,7 +90,7 @@ Actors.replies = async function (req, res) {
|
||||
res.status(200).json(object);
|
||||
};
|
||||
|
||||
Actors.topic = async function (req, res) {
|
||||
Actors.topic = async function (req, res, next) {
|
||||
const allowed = await privileges.topics.can('topics:read', req.params.tid, activitypub._constants.uid);
|
||||
if (!allowed) {
|
||||
return res.sendStatus(404);
|
||||
@@ -99,6 +99,7 @@ Actors.topic = async function (req, res) {
|
||||
const page = parseInt(req.query.page, 10);
|
||||
const perPage = meta.config.postsPerPage;
|
||||
const { cid, titleRaw: name, mainPid, slug } = await topics.getTopicFields(req.params.tid, ['cid', 'title', 'mainPid', 'slug']);
|
||||
try {
|
||||
const collection = await activitypub.helpers.generateCollection({
|
||||
set: `tid:${req.params.tid}:posts`,
|
||||
method: posts.getPidsFromSet,
|
||||
@@ -108,10 +109,11 @@ Actors.topic = async function (req, res) {
|
||||
});
|
||||
|
||||
// Convert pids to urls
|
||||
if (collection.orderedItems) {
|
||||
if (page === 1) {
|
||||
collection.totalItems += 1;
|
||||
if (page || collection.totalItems < meta.config.postsPerPage) {
|
||||
collection.orderedItems = collection.orderedItems || [];
|
||||
if (!page || page === 1) { // add OP to collection
|
||||
collection.orderedItems.unshift(mainPid);
|
||||
collection.orderedItems.length = Math.min(collection.orderedItems.length, meta.config.postsPerPage);
|
||||
}
|
||||
collection.orderedItems = collection.orderedItems.map(pid => (utils.isNumber(pid) ? `${nconf.get('url')}/post/${pid}` : pid));
|
||||
}
|
||||
@@ -127,6 +129,9 @@ Actors.topic = async function (req, res) {
|
||||
};
|
||||
|
||||
res.status(200).json(object);
|
||||
} catch (e) {
|
||||
return next();
|
||||
}
|
||||
};
|
||||
|
||||
Actors.category = async function (req, res, next) {
|
||||
|
||||
Reference in New Issue
Block a user