mirror of
https://github.com/yingziwu/mastodon.git
synced 2026-02-04 03:25:14 +00:00
Fix mentions of domain-blocked users being processed (#37257)
This commit is contained in:
parent
4eb0a506d3
commit
8233295e3b
2 changed files with 4 additions and 4 deletions
|
|
@ -71,7 +71,7 @@ class ProcessMentionsService < BaseService
|
||||||
# Make sure we never mention blocked accounts
|
# Make sure we never mention blocked accounts
|
||||||
unless @current_mentions.empty?
|
unless @current_mentions.empty?
|
||||||
mentioned_domains = @current_mentions.filter_map { |m| m.account.domain }.uniq
|
mentioned_domains = @current_mentions.filter_map { |m| m.account.domain }.uniq
|
||||||
blocked_domains = Set.new(mentioned_domains.empty? ? [] : AccountDomainBlock.where(account_id: @status.account_id, domain: mentioned_domains))
|
blocked_domains = Set.new(mentioned_domains.empty? ? [] : AccountDomainBlock.where(account_id: @status.account_id, domain: mentioned_domains).pluck(:domain))
|
||||||
mentioned_account_ids = @current_mentions.map(&:account_id)
|
mentioned_account_ids = @current_mentions.map(&:account_id)
|
||||||
blocked_account_ids = Set.new(@status.account.block_relationships.where(target_account_id: mentioned_account_ids).pluck(:target_account_id))
|
blocked_account_ids = Set.new(@status.account.block_relationships.where(target_account_id: mentioned_account_ids).pluck(:target_account_id))
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -8,9 +8,9 @@ RSpec.describe ProcessMentionsService do
|
||||||
let(:account) { Fabricate(:account, username: 'alice') }
|
let(:account) { Fabricate(:account, username: 'alice') }
|
||||||
|
|
||||||
context 'when mentions contain blocked accounts' do
|
context 'when mentions contain blocked accounts' do
|
||||||
let(:non_blocked_account) { Fabricate(:account) }
|
let!(:non_blocked_account) { Fabricate(:account) }
|
||||||
let(:individually_blocked_account) { Fabricate(:account) }
|
let!(:individually_blocked_account) { Fabricate(:account) }
|
||||||
let(:domain_blocked_account) { Fabricate(:account, domain: 'evil.com') }
|
let!(:domain_blocked_account) { Fabricate(:account, domain: 'evil.com', protocol: :activitypub) }
|
||||||
let(:status) { Fabricate(:status, account: account, text: "Hello @#{non_blocked_account.acct} @#{individually_blocked_account.acct} @#{domain_blocked_account.acct}", visibility: :public) }
|
let(:status) { Fabricate(:status, account: account, text: "Hello @#{non_blocked_account.acct} @#{individually_blocked_account.acct} @#{domain_blocked_account.acct}", visibility: :public) }
|
||||||
|
|
||||||
before do
|
before do
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue