Add: フレンドサーバー (#61)
* Fix mastodon version * テーブル作成 * Wip: フレンドサーバーフォローの承認を受信 * Wip: フレンド申請拒否を受信 * Wip: フォローリクエストを受理 * Wip: 相手からのフォロー・アンフォローを受理 * 普通のフォローとフレンドサーバーのフォローを区別するテストを追加 * ドメインブロックによるフォロー拒否 * ドメインブロックしたあと、申請中のフォロリクを取り下げる処理 * スタブに条件を追加 * Wip: 相手からのDelete信号に対応 * DB定義が消えていたので修正 * Wip: ローカル公開投稿をフレンドに送信する処理など * Wip: 未収載+誰でもの投稿をフレンドに送る設定 * Wip: ローカル公開をそのまま送信する設定を考慮 * Fix test * Wip: 他サーバーからのローカル公開投稿の受け入れ * Wip: Web画面作成 * Fix test * Wip: ローカル公開を連合TLに流す * Wip: フレンドサーバーの削除ボタン * Wip: メール通知や設定のテストなど * Wip: 翻訳を作成 * Fix: 却下されたあとフォローボタンが表示されない問題 * Wip: 編集できない問題 * 有効にしていないフレンドサーバーをリストで無効表示
This commit is contained in:
parent
acb29e5b11
commit
87e858a202
66 changed files with 1638 additions and 51 deletions
|
@ -4,6 +4,8 @@ class ActivityPub::Activity::Follow < ActivityPub::Activity
|
|||
include Payloadable
|
||||
|
||||
def perform
|
||||
return request_follow_for_friend if friend_follow?
|
||||
|
||||
target_account = account_from_uri(object_uri)
|
||||
|
||||
return if target_account.nil? || !target_account.local? || delete_arrived_first?(@json['id'])
|
||||
|
@ -43,6 +45,36 @@ class ActivityPub::Activity::Follow < ActivityPub::Activity
|
|||
ActivityPub::DeliveryWorker.perform_async(json, target_account.id, @account.inbox_url)
|
||||
end
|
||||
|
||||
def request_follow_for_friend
|
||||
already_accepted = false
|
||||
|
||||
if friend.present?
|
||||
already_accepted = friend.they_are_accepted?
|
||||
friend.update!(passive_state: :pending, passive_follow_activity_id: @json['id'])
|
||||
else
|
||||
@friend = FriendDomain.create!(domain: @account.domain, passive_state: :pending, passive_follow_activity_id: @json['id'])
|
||||
end
|
||||
|
||||
if already_accepted || friend.unlocked || Setting.unlocked_friend
|
||||
friend.accept!
|
||||
else
|
||||
# Notify for admin even if unlocked
|
||||
notify_staff_about_pending_friend_server!
|
||||
end
|
||||
end
|
||||
|
||||
def friend
|
||||
@friend ||= FriendDomain.find_by(domain: @account.domain) if @account.domain.present?
|
||||
end
|
||||
|
||||
def friend_follow?
|
||||
@json['object'] == ActivityPub::TagManager::COLLECTIONS[:public] && !block_friend?
|
||||
end
|
||||
|
||||
def block_friend?
|
||||
@block_friend ||= DomainBlock.reject_friend?(@account.domain) || DomainBlock.blocked?(@account.domain)
|
||||
end
|
||||
|
||||
def block_straight_follow?
|
||||
@block_straight_follow ||= DomainBlock.reject_straight_follow?(@account.domain)
|
||||
end
|
||||
|
@ -73,4 +105,12 @@ class ActivityPub::Activity::Follow < ActivityPub::Activity
|
|||
def instance_info
|
||||
@instance_info ||= InstanceInfo.find_by(domain: @account.domain)
|
||||
end
|
||||
|
||||
def notify_staff_about_pending_friend_server!
|
||||
User.those_who_can(:manage_federation).includes(:account).find_each do |u|
|
||||
next unless u.allows_pending_friend_server_emails?
|
||||
|
||||
AdminMailer.with(recipient: u.account).new_pending_friend_server(friend).deliver_later
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue