FEATURE: Block muted users from sending you PMs

This commit is contained in:
Robin Ward 2017-01-03 14:51:35 -05:00
parent b58a6804c2
commit cf7774bdd9
3 changed files with 47 additions and 0 deletions

View File

@ -199,6 +199,7 @@ en:
spamming_host: "Sorry you cannot post a link to that host." spamming_host: "Sorry you cannot post a link to that host."
user_is_suspended: "Suspended users are not allowed to post." user_is_suspended: "Suspended users are not allowed to post."
topic_not_found: "Something has gone wrong. Perhaps this topic was closed or deleted while you were looking at it?" topic_not_found: "Something has gone wrong. Perhaps this topic was closed or deleted while you were looking at it?"
not_accepting_pms: "Sorry, %{username} is not accepting messages at the moment."
just_posted_that: "is too similar to what you recently posted" just_posted_that: "is too similar to what you recently posted"
invalid_characters: "contains invalid characters" invalid_characters: "contains invalid characters"

View File

@ -92,6 +92,17 @@ class PostCreator
return false return false
end end
# Make sure none of the users have muted the creator
names = @opts[:target_usernames]
if names.present? && !skip_validations? && !@user.staff?
users = User.where(username: names.split(',').flatten).pluck(:id, :username).to_h
MutedUser.where(user_id: users.keys, muted_user_id: @user.id).pluck(:user_id).each do |m|
errors[:base] << I18n.t(:not_accepting_pms, username: users[m])
end
return false if errors[:base].present?
end
if new_topic? if new_topic?
topic_creator = TopicCreator.new(@user, guardian, @opts) topic_creator = TopicCreator.new(@user, guardian, @opts)
return false unless skip_validations? || validate_child(topic_creator) return false unless skip_validations? || validate_child(topic_creator)

View File

@ -904,4 +904,39 @@ describe PostCreator do
end end
end end
context "private message to a muted user" do
let(:muted_me) { Fabricate(:evil_trout) }
it 'should fail' do
updater = UserUpdater.new(muted_me, muted_me)
updater.update_muted_users("#{user.username}")
pc = PostCreator.new(
user,
title: 'this message is to someone who muted me!',
raw: "you will have to see this even if you muted me!",
archetype: Archetype.private_message,
target_usernames: "#{muted_me.username}"
)
expect(pc).not_to be_valid
expect(pc.errors).to be_present
end
let(:staff_user) { Fabricate(:admin) }
it 'succeeds if the user is staff' do
updater = UserUpdater.new(muted_me, muted_me)
updater.update_muted_users("#{staff_user.username}")
pc = PostCreator.new(
staff_user,
title: 'this message is to someone who muted me!',
raw: "you will have to see this even if you muted me!",
archetype: Archetype.private_message,
target_usernames: "#{muted_me.username}"
)
expect(pc).to be_valid
expect(pc.errors).to be_blank
end
end
end end