mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	feat: remote group actors migrated to categories if they were previous asserted as remote users
This commit is contained in:
		| @@ -74,13 +74,24 @@ Actors.qualify = async (ids, options = {}) => { | |||||||
| 		ids = ids.filter(uri => uri !== 'loopback' && new URL(uri).host !== nconf.get('url_parsed').host); | 		ids = ids.filter(uri => uri !== 'loopback' && new URL(uri).host !== nconf.get('url_parsed').host); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	// Separate those who need migration from user to category | ||||||
|  | 	const migrate = new Set(); | ||||||
|  | 	if (options.qualifyGroup) { | ||||||
|  | 		const exists = await db.exists(ids.map(id => `userRemote:${id}`)); | ||||||
|  | 		ids.forEach((id, idx) => { | ||||||
|  | 			if (exists[idx]) { | ||||||
|  | 				migrate.add(id); | ||||||
|  | 			} | ||||||
|  | 		}); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	// Only assert those who haven't been seen recently (configurable), unless update flag passed in (force refresh) | 	// Only assert those who haven't been seen recently (configurable), unless update flag passed in (force refresh) | ||||||
| 	if (!options.update) { | 	if (!options.update) { | ||||||
| 		const upperBound = Date.now() - (1000 * 60 * 60 * 24 * meta.config.activitypubUserPruneDays); | 		const upperBound = Date.now() - (1000 * 60 * 60 * 24 * meta.config.activitypubUserPruneDays); | ||||||
| 		const lastCrawled = await db.sortedSetScores('usersRemote:lastCrawled', ids.map(id => ((typeof id === 'object' && id.hasOwnProperty('id')) ? id.id : id))); | 		const lastCrawled = await db.sortedSetScores('usersRemote:lastCrawled', ids.map(id => ((typeof id === 'object' && id.hasOwnProperty('id')) ? id.id : id))); | ||||||
| 		ids = ids.filter((id, idx) => { | 		ids = ids.filter((id, idx) => { | ||||||
| 			const timestamp = lastCrawled[idx]; | 			const timestamp = lastCrawled[idx]; | ||||||
| 			return !timestamp || timestamp < upperBound; | 			return migrate.has(id) || !timestamp || timestamp < upperBound; | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| @@ -267,7 +278,10 @@ Actors.assertGroup = async (ids, options = {}) => { | |||||||
| 	 *   - true: no new IDs processed; all passed-in IDs present. | 	 *   - true: no new IDs processed; all passed-in IDs present. | ||||||
| 	 */ | 	 */ | ||||||
|  |  | ||||||
| 	ids = await Actors.qualify(ids, options); | 	ids = await Actors.qualify(ids, { | ||||||
|  | 		qualifyGroup: true, | ||||||
|  | 		...options, | ||||||
|  | 	}); | ||||||
| 	if (!ids) { | 	if (!ids) { | ||||||
| 		return ids; | 		return ids; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -76,6 +76,20 @@ describe('Actor asserton', () => { | |||||||
| 			assert.strictEqual(assertion[0].cid, actor.id); | 			assert.strictEqual(assertion[0].cid, actor.id); | ||||||
| 		}); | 		}); | ||||||
|  |  | ||||||
|  | 		it('should not migrate a user to a category if .assert is called', async () => { | ||||||
|  | 			// ... because the user isn't due for an update and so is filtered out during qualification | ||||||
|  | 			const { id } = helpers.mocks.person(); | ||||||
|  | 			await activitypub.actors.assert([id]); | ||||||
|  |  | ||||||
|  | 			const { actor } = helpers.mocks.group({ id }); | ||||||
|  | 			const assertion = await activitypub.actors.assertGroup([id]); | ||||||
|  |  | ||||||
|  | 			assert(assertion.length, 0); | ||||||
|  |  | ||||||
|  | 			const exists = await user.exists(id); | ||||||
|  | 			assert.strictEqual(exists, false); | ||||||
|  | 		}); | ||||||
|  |  | ||||||
| 		it('should migrate a user to a category if on re-assertion it identifies as an as:Group', async () => { | 		it('should migrate a user to a category if on re-assertion it identifies as an as:Group', async () => { | ||||||
| 			// This is to handle previous behaviour that saved all as:Group actors as NodeBB users. | 			// This is to handle previous behaviour that saved all as:Group actors as NodeBB users. | ||||||
| 			const { id } = helpers.mocks.person(); | 			const { id } = helpers.mocks.person(); | ||||||
| @@ -91,7 +105,9 @@ describe('Actor asserton', () => { | |||||||
| 			} | 			} | ||||||
|  |  | ||||||
| 			const { actor } = helpers.mocks.group({ id }); | 			const { actor } = helpers.mocks.group({ id }); | ||||||
| 			const assertion = await activitypub.actors.assert([id], { update: true }); | 			const assertion = await activitypub.actors.assertGroup([id]); | ||||||
|  |  | ||||||
|  | 			assert(assertion && Array.isArray(assertion) && assertion.length === 1); | ||||||
|  |  | ||||||
| 			const { topic_count, post_count } = await categories.getCategoryData(id); | 			const { topic_count, post_count } = await categories.getCategoryData(id); | ||||||
| 			assert.strictEqual(topic_count, 2); | 			assert.strictEqual(topic_count, 2); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user