mirror of
				https://github.com/NodeBB/NodeBB.git
				synced 2025-10-26 16:46:12 +01:00 
			
		
		
		
	fix: data schema of reject activities
This commit is contained in:
		| @@ -50,7 +50,11 @@ inbox.update = async (req) => { | |||||||
| 				winston.info(`[activitypub/inbox.update] ${object.id} not allowed to be edited.`); | 				winston.info(`[activitypub/inbox.update] ${object.id} not allowed to be edited.`); | ||||||
| 				return activitypub.send('uid', 0, actor, { | 				return activitypub.send('uid', 0, actor, { | ||||||
| 					type: 'Reject', | 					type: 'Reject', | ||||||
|  | 					object: { | ||||||
|  | 						type: 'Update', | ||||||
|  | 						actor, | ||||||
| 						object, | 						object, | ||||||
|  | 					}, | ||||||
| 				}); | 				}); | ||||||
| 			} | 			} | ||||||
|  |  | ||||||
| @@ -75,17 +79,25 @@ inbox.update = async (req) => { | |||||||
| inbox.like = async (req) => { | inbox.like = async (req) => { | ||||||
| 	const { actor, object } = req.body; | 	const { actor, object } = req.body; | ||||||
| 	const { type, id } = await activitypub.helpers.resolveLocalId(object); | 	const { type, id } = await activitypub.helpers.resolveLocalId(object); | ||||||
|  | 	const reject = () => { | ||||||
|  | 		activitypub.send('uid', 0, actor, { | ||||||
|  | 			type: 'Reject', | ||||||
|  | 			object: { | ||||||
|  | 				type: 'Like', | ||||||
|  | 				actor, | ||||||
|  | 				object, | ||||||
|  | 			}, | ||||||
|  | 		}); | ||||||
|  | 	}; | ||||||
|  |  | ||||||
| 	if (type !== 'post' || !(await posts.exists(id))) { | 	if (type !== 'post' || !(await posts.exists(id))) { | ||||||
| 		throw new Error('[[error:activitypub.invalid-id]]'); | 		return reject(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	const allowed = await privileges.posts.can('posts:upvote', id, activitypub._constants.uid); | 	const allowed = await privileges.posts.can('posts:upvote', id, activitypub._constants.uid); | ||||||
| 	if (!allowed) { | 	if (!allowed) { | ||||||
| 		winston.info(`[activitypub/inbox.like] ${id} not allowed to be upvoted.`); | 		winston.info(`[activitypub/inbox.like] ${id} not allowed to be upvoted.`); | ||||||
| 		return activitypub.send('uid', 0, actor, { | 		return reject(); | ||||||
| 			type: 'Reject', |  | ||||||
| 			object, |  | ||||||
| 		}); |  | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	winston.info(`[activitypub/inbox/like] id ${id} via ${actor}`); | 	winston.info(`[activitypub/inbox/like] id ${id} via ${actor}`); | ||||||
| @@ -156,13 +168,14 @@ inbox.announce = async (req) => { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| inbox.follow = async (req) => { | inbox.follow = async (req) => { | ||||||
|  | 	const { actor, object } = req.body; | ||||||
| 	// Sanity checks | 	// Sanity checks | ||||||
| 	const { type, id } = await helpers.resolveLocalId(req.body.object); | 	const { type, id } = await helpers.resolveLocalId(object); | ||||||
| 	if (!['category', 'user'].includes(type)) { | 	if (!['category', 'user'].includes(type)) { | ||||||
| 		throw new Error('[[error:activitypub.invalid-id]]'); | 		throw new Error('[[error:activitypub.invalid-id]]'); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	const assertion = await activitypub.actors.assert(req.body.actor); | 	const assertion = await activitypub.actors.assert(actor); | ||||||
| 	if (!assertion) { | 	if (!assertion) { | ||||||
| 		throw new Error('[[error:activitypub.invalid-id]]'); | 		throw new Error('[[error:activitypub.invalid-id]]'); | ||||||
| 	} | 	} | ||||||
| @@ -173,24 +186,24 @@ inbox.follow = async (req) => { | |||||||
| 			throw new Error('[[error:invalid-uid]]'); | 			throw new Error('[[error:invalid-uid]]'); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		const isFollowed = await inbox.isFollowed(req.body.actor, id); | 		const isFollowed = await inbox.isFollowed(actor, id); | ||||||
| 		if (isFollowed) { | 		if (isFollowed) { | ||||||
| 			// No additional parsing required | 			// No additional parsing required | ||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		const now = Date.now(); | 		const now = Date.now(); | ||||||
| 		await db.sortedSetAdd(`followersRemote:${id}`, now, req.body.actor); | 		await db.sortedSetAdd(`followersRemote:${id}`, now, actor); | ||||||
|  |  | ||||||
| 		const followerRemoteCount = await db.sortedSetCard(`followersRemote:${id}`); | 		const followerRemoteCount = await db.sortedSetCard(`followersRemote:${id}`); | ||||||
| 		await user.setUserField(id, 'followerRemoteCount', followerRemoteCount); | 		await user.setUserField(id, 'followerRemoteCount', followerRemoteCount); | ||||||
|  |  | ||||||
| 		user.onFollow(req.body.actor, id); | 		user.onFollow(actor, id); | ||||||
| 		activitypub.send('uid', id, req.body.actor, { | 		activitypub.send('uid', id, actor, { | ||||||
| 			type: 'Accept', | 			type: 'Accept', | ||||||
| 			object: { | 			object: { | ||||||
| 				type: 'Follow', | 				type: 'Follow', | ||||||
| 				actor: req.body.actor, | 				actor, | ||||||
| 			}, | 			}, | ||||||
| 		}); | 		}); | ||||||
| 	} else if (type === 'category') { | 	} else if (type === 'category') { | ||||||
| @@ -202,25 +215,27 @@ inbox.follow = async (req) => { | |||||||
| 			throw new Error('[[error:invalid-cid]]'); | 			throw new Error('[[error:invalid-cid]]'); | ||||||
| 		} | 		} | ||||||
| 		if (!allowed) { | 		if (!allowed) { | ||||||
| 			return activitypub.send('uid', 0, req.body.actor, { | 			return activitypub.send('uid', 0, actor, { | ||||||
| 				type: 'Reject', | 				type: 'Reject', | ||||||
| 				object: { | 				object: { | ||||||
| 					type: 'Follow', | 					type: 'Follow', | ||||||
| 					actor: req.body.actor, | 					actor, | ||||||
|  | 					object, | ||||||
| 				}, | 				}, | ||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		const watchState = await categories.getWatchState([id], req.body.actor); | 		const watchState = await categories.getWatchState([id], actor); | ||||||
| 		if (watchState[0] !== categories.watchStates.tracking) { | 		if (watchState[0] !== categories.watchStates.tracking) { | ||||||
| 			await user.setCategoryWatchState(req.body.actor, id, categories.watchStates.tracking); | 			await user.setCategoryWatchState(actor, id, categories.watchStates.tracking); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		activitypub.send('cid', id, req.body.actor, { | 		activitypub.send('cid', id, actor, { | ||||||
| 			type: 'Accept', | 			type: 'Accept', | ||||||
| 			object: { | 			object: { | ||||||
| 				type: 'Follow', | 				type: 'Follow', | ||||||
| 				actor: req.body.actor, | 				actor, | ||||||
|  | 				object, | ||||||
| 			}, | 			}, | ||||||
| 		}); | 		}); | ||||||
| 	} | 	} | ||||||
| @@ -315,7 +330,11 @@ inbox.undo = async (req) => { | |||||||
| 				winston.info(`[activitypub/inbox.like] ${id} not allowed to be upvoted.`); | 				winston.info(`[activitypub/inbox.like] ${id} not allowed to be upvoted.`); | ||||||
| 				activitypub.send('uid', 0, actor, { | 				activitypub.send('uid', 0, actor, { | ||||||
| 					type: 'Reject', | 					type: 'Reject', | ||||||
|  | 					object: { | ||||||
|  | 						type: 'Like', | ||||||
|  | 						actor, | ||||||
| 						object, | 						object, | ||||||
|  | 					}, | ||||||
| 				}); | 				}); | ||||||
| 				break; | 				break; | ||||||
| 			} | 			} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user