fix: 'unread' postIndex regression closes #10607

This commit is contained in:
Barış Soner Uşaklı
2022-05-12 11:33:11 -04:00
parent 70ad4a5222
commit 0e60a704a5

View File

@@ -58,12 +58,12 @@ topicsController.get = async function getTopic(req, res, next) {
return helpers.notAllowed(req, res); return helpers.notAllowed(req, res);
} }
if (!res.locals.isAPI && (!req.params.slug || topicData.slug !== `${tid}/${req.params.slug}`) && (topicData.slug && topicData.slug !== `${tid}/`)) { if (req.params.post_index === 'unread') {
return helpers.redirect(res, `/topic/${topicData.slug}${postIndex ? `/${postIndex}` : ''}${generateQueryString(req.query)}`, true); postIndex = await topics.getUserBookmark(tid, req.uid);
} }
if (postIndex === 'unread') { if (!res.locals.isAPI && (!req.params.slug || topicData.slug !== `${tid}/${req.params.slug}`) && (topicData.slug && topicData.slug !== `${tid}/`)) {
postIndex = await topics.getUserBookmark(tid, req.uid); return helpers.redirect(res, `/topic/${topicData.slug}${postIndex ? `/${postIndex}` : ''}${generateQueryString(req.query)}`, true);
} }
if (utils.isNumber(postIndex) && topicData.postcount > 0 && (postIndex < 1 || postIndex > topicData.postcount)) { if (utils.isNumber(postIndex) && topicData.postcount > 0 && (postIndex < 1 || postIndex > topicData.postcount)) {