FIX: no email when the category is muted and mailing list is on (#11490)

When `mute_all_categories_by_default` setting is enabled we should not send mailing list until category, tag or topic is explicitly watched.
This commit is contained in:
Krzysztof Kotlarek 2020-12-16 09:30:21 +11:00 committed by GitHub
parent 7588910ee6
commit 6dd3f986b2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 41 additions and 5 deletions

View File

@ -65,6 +65,10 @@ module Jobs
users = users.where(approved: true) users = users.where(approved: true)
end end
if SiteSetting.mute_all_categories_by_default
users = users.watching_topic_when_mute_categories_by_default(post.topic)
end
DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post) DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post)
users.find_each do |user| users.find_each do |user|
if Guardian.new(user).can_see?(post) if Guardian.new(user).can_see?(post)

View File

@ -107,11 +107,7 @@ class TopicTrackingState
def self.publish_unmuted(topic) def self.publish_unmuted(topic)
return if !SiteSetting.mute_all_categories_by_default return if !SiteSetting.mute_all_categories_by_default
user_ids = User user_ids = User.watching_topic_when_mute_categories_by_default(topic)
.joins(DB.sql_fragment("LEFT JOIN category_users ON category_users.user_id = users.id AND category_users.category_id = :category_id", category_id: topic.category_id))
.joins(DB.sql_fragment("LEFT JOIN topic_users ON topic_users.user_id = users.id AND topic_users.topic_id = :topic_id", topic_id: topic.id))
.joins("LEFT JOIN tag_users ON tag_users.user_id = users.id AND tag_users.tag_id IN (#{topic.tag_ids.join(",").presence || 'NULL'})")
.where("category_users.notification_level > 0 OR topic_users.notification_level > 0 OR tag_users.notification_level > 0")
.where("users.last_seen_at > ?", 7.days.ago) .where("users.last_seen_at > ?", 7.days.ago)
.order("users.last_seen_at DESC") .order("users.last_seen_at DESC")
.limit(100) .limit(100)

View File

@ -234,6 +234,13 @@ class User < ActiveRecord::Base
end end
end end
scope :watching_topic_when_mute_categories_by_default, ->(topic) do
joins(DB.sql_fragment("LEFT JOIN category_users ON category_users.user_id = users.id AND category_users.category_id = :category_id", category_id: topic.category_id))
.joins(DB.sql_fragment("LEFT JOIN topic_users ON topic_users.user_id = users.id AND topic_users.topic_id = :topic_id", topic_id: topic.id))
.joins("LEFT JOIN tag_users ON tag_users.user_id = users.id AND tag_users.tag_id IN (#{topic.tag_ids.join(",").presence || 'NULL'})")
.where("category_users.notification_level > 0 OR topic_users.notification_level > 0 OR tag_users.notification_level > 0")
end
module NewTopicDuration module NewTopicDuration
ALWAYS = -1 ALWAYS = -1
LAST_VISIT = -2 LAST_VISIT = -2

View File

@ -137,6 +137,35 @@ describe Jobs::NotifyMailingListSubscribers do
include_examples "no emails" include_examples "no emails"
end end
context "mute all categories by default setting" do
before { SiteSetting.mute_all_categories_by_default = true }
include_examples "no emails"
end
context "mute all categories by default setting but user is watching category" do
before do
SiteSetting.mute_all_categories_by_default = true
CategoryUser.create(user: mailing_list_user, category: post.topic.category, notification_level: CategoryUser.notification_levels[:watching])
end
include_examples "one email"
end
context "mute all categories by default setting but user is watching tag" do
before do
SiteSetting.mute_all_categories_by_default = true
TagUser.create(user: mailing_list_user, tag: tag, notification_level: TagUser.notification_levels[:watching])
end
include_examples "one email"
end
context "mute all categories by default setting but user is watching topic" do
before do
SiteSetting.mute_all_categories_by_default = true
TopicUser.create(user: mailing_list_user, topic: post.topic, notification_level: TopicUser.notification_levels[:watching])
end
include_examples "one email"
end
context "from a muted tag" do context "from a muted tag" do
before { TagUser.create(user: mailing_list_user, tag: tag, notification_level: TagUser.notification_levels[:muted]) } before { TagUser.create(user: mailing_list_user, tag: tag, notification_level: TagUser.notification_levels[:muted]) }
include_examples "no emails" include_examples "no emails"