|
|
@ -33,6 +33,8 @@ class ProcessInteractionService < BaseService |
|
|
|
follow_request!(account, target_account) unless !target_account.locked? || target_account.blocking?(account) |
|
|
|
when :authorize |
|
|
|
authorize_follow_request!(account, target_account) |
|
|
|
when :reject |
|
|
|
reject_follow_request!(account, target_account) |
|
|
|
when :unfollow |
|
|
|
unfollow!(account, target_account) |
|
|
|
when :favorite |
|
|
@ -76,14 +78,20 @@ class ProcessInteractionService < BaseService |
|
|
|
NotifyService.new.call(target_account, follow) |
|
|
|
end |
|
|
|
|
|
|
|
def follow_request(account, target_account) |
|
|
|
def follow_request!(account, target_account) |
|
|
|
follow_request = FollowRequest.create!(account: account, target_account: target_account) |
|
|
|
NotifyService.new.call(target_account, follow_request) |
|
|
|
end |
|
|
|
|
|
|
|
def authorize_target_account!(account, target_account) |
|
|
|
def authorize_follow_request!(account, target_account) |
|
|
|
follow_request = FollowRequest.find_by(account: target_account, target_account: account) |
|
|
|
follow_request&.authorize! |
|
|
|
SubscribeService.new.call(account) unless account.subscribed? |
|
|
|
end |
|
|
|
|
|
|
|
def reject_follow_request!(account, target_account) |
|
|
|
follow_request = FollowRequest.find_by(account: target_account, target_account: account) |
|
|
|
follow_request&.reject! |
|
|
|
end |
|
|
|
|
|
|
|
def unfollow!(account, target_account) |
|
|
|