mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 08:36:12 +01:00 
			
		
		
		
	fix: use view_deleted when filtering, closes #8137
This commit is contained in:
		| @@ -110,6 +110,7 @@ module.exports = function (privileges) { | |||||||
| 		return await utils.promiseParallel({ | 		return await utils.promiseParallel({ | ||||||
| 			categories: categories.getCategoriesFields(cids, ['disabled']), | 			categories: categories.getCategoriesFields(cids, ['disabled']), | ||||||
| 			allowedTo: helpers.isUserAllowedTo(privilege, uid, cids), | 			allowedTo: helpers.isUserAllowedTo(privilege, uid, cids), | ||||||
|  | 			view_deleted: helpers.isUserAllowedTo('posts:view_deleted', uid, cids), | ||||||
| 			isAdmin: user.isAdministrator(uid), | 			isAdmin: user.isAdministrator(uid), | ||||||
| 		}); | 		}); | ||||||
| 	}; | 	}; | ||||||
|   | |||||||
| @@ -88,16 +88,17 @@ module.exports = function (privileges) { | |||||||
| 		cids = _.uniq(cids); | 		cids = _.uniq(cids); | ||||||
|  |  | ||||||
| 		const results = await privileges.categories.getBase(privilege, cids, uid); | 		const results = await privileges.categories.getBase(privilege, cids, uid); | ||||||
| 		cids = cids.filter(function (cid, index) { | 		const allowedCids = cids.filter(function (cid, index) { | ||||||
| 			return !results.categories[index].disabled && | 			return !results.categories[index].disabled && | ||||||
| 				(results.allowedTo[index] || results.isAdmin); | 				(results.allowedTo[index] || results.isAdmin); | ||||||
| 		}); | 		}); | ||||||
|  |  | ||||||
| 		const cidsSet = new Set(cids); | 		const cidsSet = new Set(allowedCids); | ||||||
|  | 		const canViewDeleted = _.zipObject(cids, results.view_deleted); | ||||||
|  |  | ||||||
| 		pids = postData.filter(function (post) { | 		pids = postData.filter(function (post) { | ||||||
| 			return post.topic && cidsSet.has(post.topic.cid) && | 			return post.topic && cidsSet.has(post.topic.cid) && | ||||||
| 				((!post.topic.deleted && !post.deleted) || results.isAdmin); | 				((!post.topic.deleted && !post.deleted) || canViewDeleted[post.topic.cid] || results.isAdmin); | ||||||
| 		}).map(post => post.pid); | 		}).map(post => post.pid); | ||||||
|  |  | ||||||
| 		const data = await plugins.fireHook('filter:privileges.posts.filter', { | 		const data = await plugins.fireHook('filter:privileges.posts.filter', { | ||||||
|   | |||||||
| @@ -68,14 +68,15 @@ module.exports = function (privileges) { | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		const topicsData = await topics.getTopicsFields(tids, ['tid', 'cid', 'deleted']); | 		const topicsData = await topics.getTopicsFields(tids, ['tid', 'cid', 'deleted']); | ||||||
| 		let cids = _.uniq(topicsData.map(topic => topic.cid)); | 		const cids = _.uniq(topicsData.map(topic => topic.cid)); | ||||||
| 		const results = await privileges.categories.getBase(privilege, cids, uid); | 		const results = await privileges.categories.getBase(privilege, cids, uid); | ||||||
|  |  | ||||||
| 		cids = cids.filter((cid, index) => !results.categories[index].disabled && (results.allowedTo[index] || results.isAdmin)); | 		const allowedCids = cids.filter((cid, index) => !results.categories[index].disabled && (results.allowedTo[index] || results.isAdmin)); | ||||||
|  |  | ||||||
| 		const cidsSet = new Set(cids); | 		const cidsSet = new Set(allowedCids); | ||||||
|  | 		const canViewDeleted = _.zipObject(cids, results.view_deleted); | ||||||
|  |  | ||||||
| 		tids = topicsData.filter(t => cidsSet.has(t.cid) &&	(!t.deleted || results.isAdmin)).map(t => t.tid); | 		tids = topicsData.filter(t => cidsSet.has(t.cid) &&	(!t.deleted || canViewDeleted[t.cid] || results.isAdmin)).map(t => t.tid); | ||||||
|  |  | ||||||
| 		const data = await plugins.fireHook('filter:privileges.topics.filter', { | 		const data = await plugins.fireHook('filter:privileges.topics.filter', { | ||||||
| 			privilege: privilege, | 			privilege: privilege, | ||||||
|   | |||||||
| @@ -50,8 +50,7 @@ Topics.getTopics = async function (tids, options) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	tids = await privileges.topics.filterTids('topics:read', tids, uid); | 	tids = await privileges.topics.filterTids('topics:read', tids, uid); | ||||||
| 	const topics = await Topics.getTopicsByTids(tids, options); | 	return await Topics.getTopicsByTids(tids, options); | ||||||
| 	return topics; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| Topics.getTopicsByTids = async function (tids, options) { | Topics.getTopicsByTids = async function (tids, options) { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user