mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-12-23 00:40:23 +01:00
feat: support remote Dislike activity, federate out a Dislike on downvote, bwahahah
This commit is contained in:
@@ -352,6 +352,26 @@ inbox.like = async (req) => {
|
|||||||
socketHelpers.upvote(result, 'notifications:upvoted-your-post-in');
|
socketHelpers.upvote(result, 'notifications:upvoted-your-post-in');
|
||||||
};
|
};
|
||||||
|
|
||||||
|
inbox.dislike = async (req) => {
|
||||||
|
const { actor, object } = req.body;
|
||||||
|
const { type, id } = await activitypub.helpers.resolveLocalId(object.id);
|
||||||
|
|
||||||
|
if (type !== 'post' || !(await posts.exists(id))) {
|
||||||
|
return reject('Dislike', object, actor);
|
||||||
|
}
|
||||||
|
|
||||||
|
const allowed = await privileges.posts.can('posts:downvote', id, activitypub._constants.uid);
|
||||||
|
if (!allowed) {
|
||||||
|
activitypub.helpers.log(`[activitypub/inbox.like] ${id} not allowed to be downvoted.`);
|
||||||
|
return reject('Dislike', object, actor);
|
||||||
|
}
|
||||||
|
|
||||||
|
activitypub.helpers.log(`[activitypub/inbox/dislike] id ${id} via ${actor}`);
|
||||||
|
|
||||||
|
await posts.downvote(id, actor);
|
||||||
|
await activitypub.feps.announce(object.id, req.body);
|
||||||
|
};
|
||||||
|
|
||||||
inbox.announce = async (req) => {
|
inbox.announce = async (req) => {
|
||||||
let { actor, object, published, to, cc } = req.body;
|
let { actor, object, published, to, cc } = req.body;
|
||||||
activitypub.helpers.log(`[activitypub/inbox/announce] Parsing Announce(${object.type}) from ${actor}`);
|
activitypub.helpers.log(`[activitypub/inbox/announce] Parsing Announce(${object.type}) from ${actor}`);
|
||||||
|
|||||||
@@ -277,6 +277,32 @@ Out.like.note = enabledCheck(async (uid, pid) => {
|
|||||||
]);
|
]);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Out.dislike = {};
|
||||||
|
|
||||||
|
Out.dislike.note = enabledCheck(async (uid, pid) => {
|
||||||
|
const payload = {
|
||||||
|
id: `${nconf.get('url')}/uid/${uid}#activity/dislike/${encodeURIComponent(pid)}`,
|
||||||
|
type: 'Dislike',
|
||||||
|
actor: `${nconf.get('url')}/uid/${uid}`,
|
||||||
|
object: utils.isNumber(pid) ? `${nconf.get('url')}/post/${pid}` : pid,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (!activitypub.helpers.isUri(pid)) { // only 1b12 announce for local likes
|
||||||
|
await activitypub.feps.announce(pid, payload);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const recipient = await posts.getPostField(pid, 'uid');
|
||||||
|
if (!activitypub.helpers.isUri(recipient)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
await Promise.all([
|
||||||
|
activitypub.send('uid', uid, [recipient], payload),
|
||||||
|
activitypub.feps.announce(pid, payload),
|
||||||
|
]);
|
||||||
|
});
|
||||||
|
|
||||||
Out.announce = {};
|
Out.announce = {};
|
||||||
|
|
||||||
Out.announce.topic = enabledCheck(async (tid) => {
|
Out.announce.topic = enabledCheck(async (tid) => {
|
||||||
|
|||||||
@@ -147,14 +147,34 @@ async function executeCommand(caller, command, eventName, notification, data) {
|
|||||||
websockets.in(`uid_${caller.uid}`).emit(`posts.${command}`, result);
|
websockets.in(`uid_${caller.uid}`).emit(`posts.${command}`, result);
|
||||||
websockets.in(data.room_id).emit(`event:${eventName}`, result);
|
websockets.in(data.room_id).emit(`event:${eventName}`, result);
|
||||||
}
|
}
|
||||||
if (result && command === 'upvote') {
|
|
||||||
socketHelpers.upvote(result, notification);
|
if (result) {
|
||||||
await activitypub.out.like.note(caller.uid, data.pid);
|
switch (command) {
|
||||||
} else if (result && notification) {
|
case 'upvote': {
|
||||||
socketHelpers.sendNotificationToPostOwner(data.pid, caller.uid, command, notification);
|
socketHelpers.upvote(result, notification);
|
||||||
} else if (result && command === 'unvote') {
|
await activitypub.out.like.note(caller.uid, data.pid);
|
||||||
socketHelpers.rescindUpvoteNotification(data.pid, caller.uid);
|
break;
|
||||||
await activitypub.out.undo.like(caller.uid, data.pid);
|
}
|
||||||
|
|
||||||
|
case 'downvote': {
|
||||||
|
await activitypub.out.dislike.note(caller.uid, data.pid);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 'unvote': {
|
||||||
|
socketHelpers.rescindUpvoteNotification(data.pid, caller.uid);
|
||||||
|
await activitypub.out.undo.like(caller.uid, data.pid);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
default: {
|
||||||
|
if (notification) {
|
||||||
|
socketHelpers.sendNotificationToPostOwner(data.pid, caller.uid, command, notification);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user