diff --git a/app/lib/activitypub/activity/emoji_react.rb b/app/lib/activitypub/activity/emoji_react.rb index 82c098f56..595751aaa 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 aa1dc3040..6af516d10 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)