FIX: watched topic overcome muted category (#18480)

Previously, when categories were not muted by default, we were sending message about unmuted topics (topics which user explicitly set notification level to watching)

The same mechanism can be used to fix a bug. When the user was explicitly watching topic, but category was muted, then the user was not informed about new reply.
This commit is contained in:
Krzysztof Kotlarek 2022-10-06 11:10:43 +11:00 committed by GitHub
parent 89ac01704e
commit d5f6262c4f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 32 additions and 5 deletions

View File

@ -866,7 +866,8 @@ const TopicTrackingState = EmberObject.extend({
if ( if (
mutedCategoryIds && mutedCategoryIds &&
mutedCategoryIds.includes(data.payload.category_id) mutedCategoryIds.includes(data.payload.category_id) &&
!this.isUnmutedTopic(data.topic_id)
) { ) {
return; return;
} }

View File

@ -760,6 +760,33 @@ discourseModule("Unit | Model | topic-tracking-state", function (hooks) {
); );
}); });
test("watched topics in muted categories are added to the state", async function (assert) {
trackingState.currentUser.setProperties({
muted_category_ids: [123],
});
trackingState.trackMutedOrUnmutedTopic({
topic_id: 222,
message_type: "unmuted",
});
await publishToMessageBus("/new", newTopicPayload);
assert.deepEqual(
trackingState.findState(222),
{
category_id: 123,
topic_tag_ids: [44],
tags: ["pending"],
last_read_post_number: null,
highest_post_number: 1,
created_at: "2012-11-31 12:00:00 UTC",
archetype: "regular",
},
"topic state updated"
);
});
test("topics in muted tags do not get added to the state", async function (assert) { test("topics in muted tags do not get added to the state", async function (assert) {
trackingState.currentUser.set("muted_tags", ["pending"]); trackingState.currentUser.set("muted_tags", ["pending"]);

View File

@ -69,7 +69,7 @@ module Jobs
end end
if SiteSetting.mute_all_categories_by_default if SiteSetting.mute_all_categories_by_default
users = users.watching_topic_when_mute_categories_by_default(post.topic) users = users.watching_topic(post.topic)
end end
DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post) DiscourseEvent.trigger(:notify_mailing_list_subscribers, users, post)

View File

@ -118,8 +118,7 @@ class TopicTrackingState
end end
def self.publish_unmuted(topic) def self.publish_unmuted(topic)
return if !SiteSetting.mute_all_categories_by_default user_ids = User.watching_topic(topic)
user_ids = User.watching_topic_when_mute_categories_by_default(topic)
.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

@ -265,7 +265,7 @@ class User < ActiveRecord::Base
end end
end end
scope :watching_topic_when_mute_categories_by_default, ->(topic) do scope :watching_topic, ->(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 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(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'})") .joins("LEFT JOIN tag_users ON tag_users.user_id = users.id AND tag_users.tag_id IN (#{topic.tag_ids.join(",").presence || 'NULL'})")