From 0bb782d8d89d31a95cec641c0cbeac443ef79b91 Mon Sep 17 00:00:00 2001 From: fef Date: Tue, 29 Nov 2022 05:21:53 +0000 Subject: [PATCH] handle misskey reactions properly misskey federates emoji reactions as likes. --- app/lib/activitypub/activity/emoji_react.rb | 4 +++- app/lib/activitypub/activity/like.rb | 14 +++++++++++++- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/app/lib/activitypub/activity/emoji_react.rb b/app/lib/activitypub/activity/emoji_react.rb index 82c098f56e..595751aaae 100644 --- a/app/lib/activitypub/activity/emoji_react.rb +++ b/app/lib/activitypub/activity/emoji_react.rb @@ -9,6 +9,8 @@ class ActivityPub::Activity::EmojiReact < ActivityPub::Activity delete_arrived_first?(@json['id']) || @account.reacted?(original_status, name) - original_status.status_reactions.create!(account: @account, name: name) + reaction = original_status.status_reactions.create!(account: @account, name: name) + + LocalNotificationWorker.perform_async(original_status.account_id, reaction.id, 'StatusReaction', 'reaction') end end diff --git a/app/lib/activitypub/activity/like.rb b/app/lib/activitypub/activity/like.rb index aa1dc30403..6af516d109 100644 --- a/app/lib/activitypub/activity/like.rb +++ b/app/lib/activitypub/activity/like.rb @@ -3,8 +3,20 @@ class ActivityPub::Activity::Like < ActivityPub::Activity def perform original_status = status_from_uri(object_uri) + return if original_status.nil? || !original_status.account.local? || delete_arrived_first?(@json['id']) - return if original_status.nil? || !original_status.account.local? || delete_arrived_first?(@json['id']) || @account.favourited?(original_status) + # misskey delivers reactions as likes and attaches the emoji in _misskey_reaction + mk_reaction = @json['_misskey_reaction'] + unless mk_reaction.nil? + custom_emoji = CustomEmoji.find_by(shortcode: mk_reaction, domain: @account.domain) + return if @account.reacted?(original_status, mk_reaction, custom_emoji) + + reaction = original_status.status_reactions.create!(account: @account, name: mk_reaction, custom_emoji: custom_emoji) + LocalNotificationWorker.perform_async(original_status.account_id, reaction.id, 'StatusReaction', 'reaction') + return + end + + return if @account.favourited?(original_status) favourite = original_status.favourites.create!(account: @account)