mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	fix: #13622, WordPress blog URLs not asserting properly
This commit is contained in:
		| @@ -563,6 +563,43 @@ ActivityPub.buildRecipients = async function (object, { pid, uid, cid }) { | ||||
| 	}; | ||||
| }; | ||||
|  | ||||
| ActivityPub.checkHeader = async (url, timeout) => { | ||||
| 	timeout = timeout || meta.config.activitypubProbeTimeout || 2000; | ||||
| 	const { response } = await request.head(url, { | ||||
| 		timeout, | ||||
| 	}); | ||||
| 	const { headers } = response; | ||||
| 	if (headers && headers.link) { | ||||
| 		// Multiple link headers could be combined | ||||
| 		const links = headers.link.split(','); | ||||
| 		let apLink = false; | ||||
|  | ||||
| 		links.forEach((link) => { | ||||
| 			let parts = link.split(';'); | ||||
| 			const url = parts.shift().match(/<(.+)>/)[1]; | ||||
| 			if (!url || apLink) { | ||||
| 				return; | ||||
| 			} | ||||
|  | ||||
| 			parts = parts | ||||
| 				.map(p => p.trim()) | ||||
| 				.reduce((memo, cur) => { | ||||
| 					cur = cur.split('='); | ||||
| 					memo[cur[0]] = cur[1].slice(1, -1); | ||||
| 					return memo; | ||||
| 				}, {}); | ||||
|  | ||||
| 			if (parts.rel === 'alternate' && parts.type === 'application/activity+json') { | ||||
| 				apLink = url; | ||||
| 			} | ||||
| 		}); | ||||
|  | ||||
| 		return apLink; | ||||
| 	} | ||||
|  | ||||
| 	return false; | ||||
| }; | ||||
|  | ||||
| ActivityPub.probe = async ({ uid, url }) => { | ||||
| 	/** | ||||
| 	 * Checks whether a passed-in id or URL is an ActivityPub object and can be mapped to a local representation | ||||
| @@ -629,37 +666,18 @@ ActivityPub.probe = async ({ uid, url }) => { | ||||
| 	} | ||||
|  | ||||
| 	// Opportunistic HEAD | ||||
| 	async function checkHeader(timeout) { | ||||
| 		const { response } = await request.head(url, { | ||||
| 			timeout, | ||||
| 		}); | ||||
| 		const { headers } = response; | ||||
| 		if (headers && headers.link) { | ||||
| 			let parts = headers.link.split(';'); | ||||
| 			parts.shift(); | ||||
| 			parts = parts | ||||
| 				.map(p => p.trim()) | ||||
| 				.reduce((memo, cur) => { | ||||
| 					cur = cur.split('='); | ||||
| 					memo[cur[0]] = cur[1].slice(1, -1); | ||||
| 					return memo; | ||||
| 				}, {}); | ||||
|  | ||||
| 			if (parts.rel === 'alternate' && parts.type === 'application/activity+json') { | ||||
| 				probeCache.set(url, true); | ||||
| 				return true; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 	} | ||||
| 	try { | ||||
| 		probeRateLimit.set(uid, true); | ||||
| 		return await checkHeader(meta.config.activitypubProbeTimeout || 2000); | ||||
| 		const probe = await ActivityPub.checkHeader(url).then((result) => { | ||||
| 			probeCache.set(url, result); | ||||
| 			return !!result; | ||||
| 		}); | ||||
|  | ||||
| 		return !!probe; | ||||
| 	} catch (e) { | ||||
| 		if (e.name === 'TimeoutError') { | ||||
| 			// Return early but retry for caching purposes | ||||
| 			checkHeader(1000 * 60).then((result) => { | ||||
| 			ActivityPub.checkHeader(url, 1000 * 60).then((result) => { | ||||
| 				probeCache.set(url, result); | ||||
| 			}).catch(err => ActivityPub.helpers.log(err.stack)); | ||||
| 			return false; | ||||
|   | ||||
| @@ -56,13 +56,15 @@ Notes.assert = async (uid, input, options = { skipChecks: false }) => { | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	const id = !activitypub.helpers.isUri(input) ? input.id : input; | ||||
| 	let id = !activitypub.helpers.isUri(input) ? input.id : input; | ||||
| 	const lockStatus = await lock(id); | ||||
| 	if (!lockStatus) { // unable to achieve lock, stop processing. | ||||
| 		winston.warn('[activitypub/notes.assert] Unable to acquire lock, skipping processing of', id); | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	id = await activitypub.checkHeader(id); | ||||
|  | ||||
| 	let chain; | ||||
| 	let context = await activitypub.contexts.get(uid, id); | ||||
| 	if (context.tid) { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user