From b8dd1214af53a4c5f1a0ddaa06772db6632e9728 Mon Sep 17 00:00:00 2001 From: yufushiro <62991447+yufushiro@users.noreply.github.com> Date: Tue, 31 Oct 2023 02:33:09 +0900 Subject: [PATCH] =?UTF-8?q?[yufushiro]=20=E6=81=92=E4=B9=85=E7=9A=84?= =?UTF-8?q?=E3=81=A7=E3=81=AA=E3=81=84=E3=82=A2=E3=82=AB=E3=82=A6=E3=83=B3?= =?UTF-8?q?=E3=83=88=E5=87=8D=E7=B5=90=E3=81=ABDelete=20activity=E3=82=92?= =?UTF-8?q?=E4=BD=BF=E7=94=A8=E3=81=99=E3=82=8B=E5=AE=9F=E8=A3=85=E3=81=AB?= =?UTF-8?q?=E5=AF=BE=E3=81=99=E3=82=8B=E5=9B=9E=E9=81=BF=E7=AD=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/lib/activitypub/activity/delete.rb | 10 +++++++--- app/lib/activitypub/activity/undo.rb | 15 +++++++++++++++ 2 files changed, 22 insertions(+), 3 deletions(-) diff --git a/app/lib/activitypub/activity/delete.rb b/app/lib/activitypub/activity/delete.rb index 871eb39667af64..08087ce6964992 100644 --- a/app/lib/activitypub/activity/delete.rb +++ b/app/lib/activitypub/activity/delete.rb @@ -12,9 +12,13 @@ def perform private def delete_person - with_lock("delete_in_progress:#{@account.id}", autorelease: 2.hours, raise_on_failure: false) do - DeleteAccountService.new.call(@account, reserve_username: false, skip_activitypub: true) - end + # Workaround for some implementations (such as Misskey) that send Delete activity for non-permanent account suspension. + @account.silence! + AccountModerationNote.create!( + account: Account.local.find_by!(username: 'yufushiro'), + target_account: @account, + content: 'Delete activity has been received.' + ) end def delete_note diff --git a/app/lib/activitypub/activity/undo.rb b/app/lib/activitypub/activity/undo.rb index 9eff1b71c9db36..3690ca06e190cb 100644 --- a/app/lib/activitypub/activity/undo.rb +++ b/app/lib/activitypub/activity/undo.rb @@ -13,6 +13,8 @@ def perform undo_like when 'Block' undo_block + when 'Delete' + undo_delete when nil handle_reference end @@ -125,6 +127,19 @@ def undo_block end end + def undo_delete + target_account = account_from_uri(target_uri) + + return if target_account.nil? + + target_account.unsilence! + AccountModerationNote.create!( + account: Account.local.find_by!(username: 'yufushiro'), + target_account: target_account, + content: 'Undo Delete activity has been received.' + ) + end + def target_uri @target_uri ||= value_or_id(@object['object']) end