|
|
|
@ -31,7 +31,6 @@ class Status < ApplicationRecord |
|
|
|
|
|
|
|
|
|
scope :remote, -> { where.not(uri: nil) } |
|
|
|
|
scope :local, -> { where(uri: nil) } |
|
|
|
|
scope :permitted_for, ->(target_account, account) { account&.id == target_account.id || account&.following?(target_account) ? where('1=1') : where.not(visibility: :private) } |
|
|
|
|
|
|
|
|
|
cache_associated :account, :media_attachments, :tags, :stream_entry, mentions: :account, reblog: [:account, :stream_entry, :tags, :media_attachments, mentions: :account], thread: :account |
|
|
|
|
|
|
|
|
@ -72,7 +71,7 @@ class Status < ApplicationRecord |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
def permitted?(other_account = nil) |
|
|
|
|
private_visibility? ? (account.id == other_account&.id || other_account&.following?(account)) : true |
|
|
|
|
private_visibility? ? (account.id == other_account&.id || other_account&.following?(account)) : other_account.nil? || !account.blocking?(other_account) |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
def ancestors(account = nil) |
|
|
|
@ -145,6 +144,16 @@ class Status < ApplicationRecord |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
def permitted_for(target_account, account) |
|
|
|
|
if account&.id == target_account.id || account&.following?(target_account) |
|
|
|
|
where('1 = 1') |
|
|
|
|
elsif !account.nil? && target_account.blocking?(account) |
|
|
|
|
where('1 = 0') |
|
|
|
|
else |
|
|
|
|
where.not(visibility: :private) |
|
|
|
|
end |
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
private |
|
|
|
|
|
|
|
|
|
def filter_timeline(query, account) |
|
|
|
|