FIX: notifications inconsistencies + never notify system user
This commit is contained in:
parent
6137a5f00b
commit
eec1921ba9
|
@ -188,7 +188,7 @@ class PostAction < ActiveRecord::Base
|
||||||
return if staff_already_replied?(related_post.topic)
|
return if staff_already_replied?(related_post.topic)
|
||||||
message_key = "flags_dispositions.#{disposition}"
|
message_key = "flags_dispositions.#{disposition}"
|
||||||
message_key << "_and_deleted" if delete_post
|
message_key << "_and_deleted" if delete_post
|
||||||
related_post.topic.add_moderator_post(moderator, I18n.t(message_key), skip_notifications: true)
|
related_post.topic.add_moderator_post(moderator, I18n.t(message_key))
|
||||||
end
|
end
|
||||||
|
|
||||||
def staff_already_replied?(topic)
|
def staff_already_replied?(topic)
|
||||||
|
|
|
@ -10,14 +10,14 @@ class PostAlerter
|
||||||
def after_create_post(post)
|
def after_create_post(post)
|
||||||
if post.topic.private_message?
|
if post.topic.private_message?
|
||||||
# If it's a private message, notify the topic_allowed_users
|
# If it's a private message, notify the topic_allowed_users
|
||||||
post.topic.all_allowed_users.reject{ |user| user.id == post.user_id }.each do |user|
|
post.topic.all_allowed_users.reject do |user|
|
||||||
next if user.blank?
|
user.blank? ||
|
||||||
|
user.id == Discourse::SYSTEM_USER_ID ||
|
||||||
|
user.id == post.user_id
|
||||||
|
end.each do |user|
|
||||||
if TopicUser.get(post.topic, user).try(:notification_level) == TopicUser.notification_levels[:tracking]
|
if TopicUser.get(post.topic, user).try(:notification_level) == TopicUser.notification_levels[:tracking]
|
||||||
next unless post.reply_to_post_number
|
next unless post.reply_to_post_number || post.reply_to_post.user_id == user.id
|
||||||
next unless post.reply_to_post.user_id == user.id
|
|
||||||
end
|
end
|
||||||
|
|
||||||
create_notification(user, Notification.types[:private_message], post)
|
create_notification(user, Notification.types[:private_message], post)
|
||||||
end
|
end
|
||||||
elsif post.post_type != Post.types[:moderator_action]
|
elsif post.post_type != Post.types[:moderator_action]
|
||||||
|
@ -82,6 +82,7 @@ class PostAlerter
|
||||||
|
|
||||||
def create_notification(user, type, post, opts={})
|
def create_notification(user, type, post, opts={})
|
||||||
return if user.blank?
|
return if user.blank?
|
||||||
|
return if user.id == Discourse::SYSTEM_USER_ID
|
||||||
|
|
||||||
# Make sure the user can see the post
|
# Make sure the user can see the post
|
||||||
return unless Guardian.new(user).can_see?(post)
|
return unless Guardian.new(user).can_see?(post)
|
||||||
|
|
|
@ -97,7 +97,7 @@ class PostCreator
|
||||||
|
|
||||||
if @post && @post.errors.empty?
|
if @post && @post.errors.empty?
|
||||||
publish
|
publish
|
||||||
PostAlerter.post_created(@post) unless @opts[:import_mode] || @opts[:skip_notifications]
|
PostAlerter.post_created(@post) unless @opts[:import_mode]
|
||||||
|
|
||||||
track_latest_on_category
|
track_latest_on_category
|
||||||
enqueue_jobs
|
enqueue_jobs
|
||||||
|
|
|
@ -507,15 +507,6 @@ describe PostAction do
|
||||||
expect(topic.posts.count).to eq(1)
|
expect(topic.posts.count).to eq(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
it "should not generate a notification for auto-message" do
|
|
||||||
post = create_post
|
|
||||||
PostAction.act(moderator, post, PostActionType.types[:spam], message: "WAT")
|
|
||||||
|
|
||||||
PostAlerter.expects(:post_created).never
|
|
||||||
|
|
||||||
PostAction.agree_flags!(post, admin)
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue