FIX: don't offer the "Something Else" flag reason to TL0 users since they don't have permission to send private messages

This commit is contained in:
Neil Lalonde 2017-10-24 11:47:41 -04:00
parent ad9553ff86
commit fb5b9b6d06
2 changed files with 5 additions and 4 deletions

View File

@ -35,8 +35,9 @@ module PostGuardian
# don't like your own stuff # don't like your own stuff
not(action_key == :like && is_my_own?(post)) && not(action_key == :like && is_my_own?(post)) &&
# new users can't notify_user because they are not allowed to send private messages # new users can't notify_user or notify_moderators because they are not allowed to send private messages
not(action_key == :notify_user && !@user.has_trust_level?(SiteSetting.min_trust_to_send_messages)) && not((action_key == :notify_user || action_key == :notify_moderators) &&
!@user.has_trust_level?(SiteSetting.min_trust_to_send_messages)) &&
# no voting more than once on single vote topics # no voting more than once on single vote topics
not(action_key == :vote && opts[:voted_in_topic] && post.topic.has_meta_data_boolean?(:single_vote)) not(action_key == :vote && opts[:voted_in_topic] && post.topic.has_meta_data_boolean?(:single_vote))

View File

@ -75,12 +75,12 @@ describe Guardian do
expect(Guardian.new(user).post_can_act?(post, :notify_moderators)).to be_falsey expect(Guardian.new(user).post_can_act?(post, :notify_moderators)).to be_falsey
end end
it "returns false for notify_user if private messages are enabled but threshold not met" do it "returns false for notify_user and notify_moderators if private messages are enabled but threshold not met" do
SiteSetting.enable_private_messages = true SiteSetting.enable_private_messages = true
SiteSetting.min_trust_to_send_messages = 2 SiteSetting.min_trust_to_send_messages = 2
user.trust_level = TrustLevel[1] user.trust_level = TrustLevel[1]
expect(Guardian.new(user).post_can_act?(post, :notify_user)).to be_falsey expect(Guardian.new(user).post_can_act?(post, :notify_user)).to be_falsey
expect(Guardian.new(user).post_can_act?(post, :notify_moderators)).to be_truthy expect(Guardian.new(user).post_can_act?(post, :notify_moderators)).to be_falsey
end end
describe "trust levels" do describe "trust levels" do