Change delivering to misskey setting to send as private
This commit is contained in:
parent
29180de672
commit
a4332babb5
10 changed files with 133 additions and 12 deletions
|
@ -124,6 +124,25 @@ class ActivityPub::TagManager
|
|||
cc << COLLECTIONS[:public]
|
||||
end
|
||||
|
||||
cc = cc + cc_private_visibility(status)
|
||||
|
||||
cc
|
||||
end
|
||||
|
||||
def cc_for_misskey(status)
|
||||
case status.visibility
|
||||
when 'unlisted'
|
||||
status.account.user&.reject_unlisted_subscription? ? cc_private_visibility(status) : cc(status)
|
||||
when 'public_unlisted'
|
||||
status.account.user&.reject_public_unlisted_subscription? ? cc_private_visibility(status) : cc(status)
|
||||
else
|
||||
cc(status)
|
||||
end
|
||||
end
|
||||
|
||||
def cc_private_visibility(status)
|
||||
cc = []
|
||||
|
||||
unless status.direct_visibility? || status.limited_visibility?
|
||||
if status.account.silenced?
|
||||
# Only notify followers if the account is locally silenced
|
||||
|
|
|
@ -13,6 +13,10 @@ class StatusReachFinder
|
|||
(reached_account_inboxes + followers_inboxes + relay_inboxes).uniq
|
||||
end
|
||||
|
||||
def inboxes_for_misskey
|
||||
(reached_account_inboxes_for_misskey + followers_inboxes_for_misskey).uniq
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def reached_account_inboxes
|
||||
|
@ -26,6 +30,14 @@ class StatusReachFinder
|
|||
end
|
||||
end
|
||||
|
||||
def reached_account_inboxes_for_misskey
|
||||
if @status.reblog?
|
||||
[]
|
||||
else
|
||||
Account.where(id: reached_account_ids).where(domain: banned_domains_for_misskey).inboxes
|
||||
end
|
||||
end
|
||||
|
||||
def reached_account_ids
|
||||
[
|
||||
replied_to_account_id,
|
||||
|
@ -70,7 +82,7 @@ class StatusReachFinder
|
|||
|
||||
def followers_inboxes
|
||||
if @status.in_reply_to_local_account? && distributable?
|
||||
@status.account.followers.or(@status.thread.account.followers.not_domain_blocked_by_account(@status.account)).inboxes
|
||||
@status.account.followers.or(@status.thread.account.followers.not_domain_blocked_by_account(@status.account)).where.not(domain: banned_domains).inboxes
|
||||
elsif @status.direct_visibility? || @status.limited_visibility?
|
||||
[]
|
||||
else
|
||||
|
@ -78,6 +90,16 @@ class StatusReachFinder
|
|||
end
|
||||
end
|
||||
|
||||
def followers_inboxes_for_misskey
|
||||
if @status.in_reply_to_local_account? && distributable?
|
||||
@status.account.followers.or(@status.thread.account.followers.not_domain_blocked_by_account(@status.account)).where(domain: banned_domains_for_misskey).inboxes
|
||||
elsif @status.direct_visibility? || @status.limited_visibility?
|
||||
[]
|
||||
else
|
||||
@status.account.followers.where(domain: banned_domains_for_misskey).inboxes
|
||||
end
|
||||
end
|
||||
|
||||
def relay_inboxes
|
||||
if @status.public_visibility?
|
||||
Relay.enabled.pluck(:inbox_url)
|
||||
|
@ -98,8 +120,8 @@ class StatusReachFinder
|
|||
return @banned_domains if @banned_domains
|
||||
|
||||
domains = banned_domains_of_status(@status)
|
||||
domains = domains + banned_domains_of_status(@status.reblog) if @status.reblog? && @status.reblog.status.local?
|
||||
return @banned_domains = domains
|
||||
domains = domains + banned_domains_of_status(@status.reblog) if @status.reblog? && @status.reblog.local?
|
||||
return @banned_domains = domains.uniq
|
||||
end
|
||||
|
||||
def banned_domains_of_status(status)
|
||||
|
@ -107,10 +129,25 @@ class StatusReachFinder
|
|||
blocks = blocks.or(DomainBlock.where(reject_send_not_public_searchability: true)) if status.compute_searchability != 'public'
|
||||
blocks = blocks.or(DomainBlock.where(reject_send_public_unlisted: true)) if status.public_unlisted_visibility?
|
||||
blocks = blocks.or(DomainBlock.where(reject_send_dissubscribable: true)) if status.account.dissubscribable
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.public_unlisted_visibility? && status.account.user&.setting_reject_public_unlisted_subscription
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.unlisted_visibility? && status.account.user&.setting_reject_unlisted_subscription
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.public_unlisted_visibility? && status.account.user&.reject_public_unlisted_subscription?
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.unlisted_visibility? && status.account.user&.reject_unlisted_subscription?
|
||||
blocks = blocks.or(DomainBlock.where(reject_send_media: true)) if status.with_media?
|
||||
blocks = blocks.or(DomainBlock.where(reject_send_sensitive: true)) if (status.with_media? && status.sensitive) || status.spoiler_text?
|
||||
blocks.pluck(:domain).uniq
|
||||
end
|
||||
|
||||
def banned_domains_for_misskey
|
||||
return @banned_domains_for_misskey if @banned_domains_for_misskey
|
||||
|
||||
domains = banned_domains_for_misskey_of_status(@status)
|
||||
domains = domains + banned_domains_for_misskey_of_status(@status.reblog) if @status.reblog? && @status.reblog.local?
|
||||
return @banned_domains_for_misskey = domains.uniq
|
||||
end
|
||||
|
||||
def banned_domains_for_misskey_of_status(status)
|
||||
blocks = DomainBlock.where(domain: nil)
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.public_unlisted_visibility? && status.account.user&.reject_public_unlisted_subscription?
|
||||
blocks = blocks.or(DomainBlock.where(detect_invalid_subscription: true)) if status.unlisted_visibility? && status.account.user&.reject_unlisted_subscription?
|
||||
blocks.pluck(:domain).uniq
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue