forked from cybrespace/mastodon
Handle ActivityPub follows correctly (#4571)
* Handle ActivityPub follows correctly ActivityPub follows are follow-requests. Always require an Accept. If account is not locked, auto-accept. * Handle ActivityPub Accept/Reject-Follow * Fix wrong method * Fix wrong class
This commit is contained in:
parent
4b8e4dca26
commit
81c1303cd6
|
@ -39,6 +39,10 @@ class ActivityPub::Activity
|
||||||
ActivityPub::Activity::Update
|
ActivityPub::Activity::Update
|
||||||
when 'Undo'
|
when 'Undo'
|
||||||
ActivityPub::Activity::Undo
|
ActivityPub::Activity::Undo
|
||||||
|
when 'Accept'
|
||||||
|
ActivityPub::Activity::Accept
|
||||||
|
when 'Reject'
|
||||||
|
ActivityPub::Activity::Reject
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class ActivityPub::Activity::Accept < ActivityPub::Activity
|
||||||
|
def perform
|
||||||
|
case @object['type']
|
||||||
|
when 'Follow'
|
||||||
|
accept_follow
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def accept_follow
|
||||||
|
target_account = account_from_uri(target_uri)
|
||||||
|
|
||||||
|
return if target_account.nil? || !target_account.local?
|
||||||
|
|
||||||
|
follow_request = FollowRequest.find_by(account: target_account, target_account: @account)
|
||||||
|
follow_request&.authorize!
|
||||||
|
end
|
||||||
|
|
||||||
|
def target_uri
|
||||||
|
@target_uri ||= @object['object'].is_a?(String) ? @object['object'] : @object['object']['id']
|
||||||
|
end
|
||||||
|
end
|
|
@ -6,7 +6,13 @@ class ActivityPub::Activity::Follow < ActivityPub::Activity
|
||||||
|
|
||||||
return if target_account.nil? || !target_account.local? || delete_arrived_first?(@json['id'])
|
return if target_account.nil? || !target_account.local? || delete_arrived_first?(@json['id'])
|
||||||
|
|
||||||
follow = @account.follow!(target_account)
|
follow_request = FollowRequest.create!(account: @account, target_account: target_account)
|
||||||
NotifyService.new.call(target_account, follow)
|
|
||||||
|
if target_account.locked?
|
||||||
|
NotifyService.new.call(target_account, follow_request)
|
||||||
|
else
|
||||||
|
AuthorizeFollowService.new.call(@account, target_account)
|
||||||
|
NotifyService.new.call(target_account, ::Follow.find_by(account: @account, target_account: target_account))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class ActivityPub::Activity::Reject < ActivityPub::Activity
|
||||||
|
def perform
|
||||||
|
case @object['type']
|
||||||
|
when 'Follow'
|
||||||
|
reject_follow
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def reject_follow
|
||||||
|
target_account = account_from_uri(target_uri)
|
||||||
|
|
||||||
|
return if target_account.nil? || !target_account.local?
|
||||||
|
|
||||||
|
follow_request = FollowRequest.find_by(account: target_account, target_account: @account)
|
||||||
|
follow_request&.reject!
|
||||||
|
end
|
||||||
|
|
||||||
|
def target_uri
|
||||||
|
@target_uri ||= @object['object'].is_a?(String) ? @object['object'] : @object['object']['id']
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue