* Add: `conversations`テーブルに`ancestor_status`プロパティ * Fix test * Fix test more * Add: `limited_visibility`に`Reply`を追加、`context`のURI * Add: 外部からの`context`受信処理 * Fix test * Add: 公開範囲「返信」 * Fix test * Fix: 返信に返信以外の公開範囲を設定できない問題 * Add: ローカル投稿時にメンション追加・他サーバーへの転送 * Fix test * Fix test * Test: ローカルスレッドへの返信投稿の転送 * Test: 未知のアカウントからのメンション * Add: 編集・削除の連合に対応 * Remove: 重複テスト * Fix: 改善 * Add: 編集削除の転送処理・返信なのにsilentなメンションでの通知 * Fix: リプライが第三者に届かない問題 * Add: `always_sign_unsafe` * Add: Subject * Remove space * Fix: 他人のスレッドの送信先一覧を非表示 * Fix: おかしいコード
149 lines
4.4 KiB
Ruby
149 lines
4.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class StatusPolicy < ApplicationPolicy
|
|
def initialize(current_account, record, preloaded_relations = {}, preloaded_status_relations = {})
|
|
super(current_account, record)
|
|
|
|
@preloaded_relations = preloaded_relations
|
|
@preloaded_status_relations = preloaded_status_relations
|
|
end
|
|
|
|
delegate :reply?, :expired?, to: :record
|
|
|
|
def show?
|
|
return false if author.suspended?
|
|
|
|
if requires_mention?
|
|
owned? || mention_exists?
|
|
elsif login?
|
|
owned? || !current_account.nil?
|
|
elsif private?
|
|
owned? || following_author? || mention_exists?
|
|
else
|
|
current_account.nil? || (!author_blocking? && !author_blocking_domain? && !server_blocking_domain?)
|
|
end
|
|
end
|
|
|
|
def show_mentioned_users?
|
|
record.limited_visibility? ? owned_conversation? : owned?
|
|
end
|
|
|
|
def reblog?
|
|
!requires_mention? && (!private? || owned?) && show? && !blocking_author?
|
|
end
|
|
|
|
def favourite?
|
|
show? && !blocking_author?
|
|
end
|
|
|
|
def emoji_reaction?
|
|
show? && !blocking_author?
|
|
end
|
|
|
|
def quote?
|
|
%i(public public_unlisted unlisted).include?(record.visibility.to_sym) && show? && !blocking_author?
|
|
end
|
|
|
|
def destroy?
|
|
owned?
|
|
end
|
|
|
|
alias unreblog? destroy?
|
|
|
|
def update?
|
|
owned?
|
|
end
|
|
|
|
private
|
|
|
|
def requires_mention?
|
|
record.direct_visibility? || record.limited_visibility?
|
|
end
|
|
|
|
def owned?
|
|
author.id == current_account&.id
|
|
end
|
|
|
|
def owned_conversation?
|
|
record.conversation&.local? &&
|
|
(record.conversation.ancestor_status.nil? ? owned? : record.conversation.ancestor_status.account_id == current_account&.id)
|
|
end
|
|
|
|
def private?
|
|
record.private_visibility?
|
|
end
|
|
|
|
def login?
|
|
record.login_visibility?
|
|
end
|
|
|
|
def public?
|
|
record.public_visibility? || record.public_unlisted_visibility?
|
|
end
|
|
|
|
def mention_exists?
|
|
return false if current_account.nil?
|
|
|
|
if record.mentions.loaded?
|
|
record.mentions.any? { |mention| mention.account_id == current_account.id }
|
|
else
|
|
record.mentions.where(account: current_account).exists?
|
|
end
|
|
end
|
|
|
|
def author_blocking_domain?
|
|
return false if current_account.nil? || current_account.domain.nil?
|
|
|
|
author.domain_blocking?(current_account.domain)
|
|
end
|
|
|
|
def blocking_author?
|
|
return false if current_account.nil?
|
|
|
|
@preloaded_relations[:blocking] ? @preloaded_relations[:blocking][author.id] : current_account.blocking?(author)
|
|
end
|
|
|
|
def author_blocking?
|
|
return false if current_account.nil?
|
|
|
|
@preloaded_relations[:blocked_by] ? @preloaded_relations[:blocked_by][author.id] : author.blocking?(current_account)
|
|
end
|
|
|
|
def following_author?
|
|
return false if current_account.nil?
|
|
|
|
@preloaded_relations[:following] ? @preloaded_relations[:following][author.id] : current_account.following?(author)
|
|
end
|
|
|
|
def author
|
|
record.account
|
|
end
|
|
|
|
def server_blocking_domain?
|
|
if record.reblog? && record.reblog.local?
|
|
server_blocking_domain_of_status?(record) || server_blocking_domain_of_status?(record.reblog)
|
|
else
|
|
server_blocking_domain_of_status?(record)
|
|
end
|
|
end
|
|
|
|
def server_blocking_domain_of_status?(status)
|
|
@domain_block ||= DomainBlock.find_by(domain: current_account&.domain)
|
|
if @domain_block
|
|
if status.account.user&.setting_send_without_domain_blocks
|
|
(@domain_block.detect_invalid_subscription && status.public_unlisted_visibility? && status.account.user&.setting_reject_public_unlisted_subscription) ||
|
|
(@domain_block.detect_invalid_subscription && status.public_visibility? && status.account.user&.setting_reject_unlisted_subscription)
|
|
else
|
|
(@domain_block.reject_send_not_public_searchability && status.compute_searchability != 'public') ||
|
|
(@domain_block.reject_send_public_unlisted && status.public_unlisted_visibility?) ||
|
|
(@domain_block.reject_send_dissubscribable && !status.account.all_subscribable?) ||
|
|
(@domain_block.detect_invalid_subscription && status.public_unlisted_visibility? && status.account.user&.setting_reject_public_unlisted_subscription) ||
|
|
(@domain_block.detect_invalid_subscription && status.public_visibility? && status.account.user&.setting_reject_unlisted_subscription) ||
|
|
(@domain_block.reject_send_media && status.with_media?) ||
|
|
(@domain_block.reject_send_sensitive && ((status.with_media? && status.sensitive) || status.spoiler_text?))
|
|
end
|
|
else
|
|
false
|
|
end
|
|
end
|
|
end
|