FIX: Hide links to muted topics and in categories list (#14761)

* FIX: Hide links to muted topics

* FIX: Hide muted topics in categories list on mobile
This commit is contained in:
Bianca Nenciu 2021-10-29 17:52:23 +03:00 committed by GitHub
parent 095421a1e1
commit cb0958fcea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 42 additions and 0 deletions

View File

@ -63,6 +63,13 @@ class CategoryList
category_featured_topics = CategoryFeaturedTopic.select([:category_id, :topic_id]).order(:rank) category_featured_topics = CategoryFeaturedTopic.select([:category_id, :topic_id]).order(:rank)
@all_topics = Topic.where(id: category_featured_topics.map(&:topic_id)) @all_topics = Topic.where(id: category_featured_topics.map(&:topic_id))
if @guardian.authenticated?
@all_topics = @all_topics
.joins("LEFT JOIN topic_users tu ON topics.id = tu.topic_id AND tu.user_id = #{@guardian.user.id.to_i}")
.where('COALESCE(tu.notification_level,1) > :muted', muted: TopicUser.notification_levels[:muted])
end
@all_topics = @all_topics.includes(:last_poster) if @options[:include_topics] @all_topics = @all_topics.includes(:last_poster) if @options[:include_topics]
@all_topics.each do |t| @all_topics.each do |t|
# hint for the serializer # hint for the serializer

View File

@ -85,12 +85,18 @@ class TopicLink < ActiveRecord::Base
FROM topic_links l FROM topic_links l
LEFT JOIN topics t ON t.id = l.link_topic_id LEFT JOIN topics t ON t.id = l.link_topic_id
LEFT JOIN categories AS c ON c.id = t.category_id LEFT JOIN categories AS c ON c.id = t.category_id
/*left_join*/
/*where*/ /*where*/
ORDER BY reflection ASC, clicks DESC") ORDER BY reflection ASC, clicks DESC")
builder.where('t.deleted_at IS NULL') builder.where('t.deleted_at IS NULL')
builder.where("COALESCE(t.archetype, 'regular') <> :archetype", archetype: Archetype.private_message) builder.where("COALESCE(t.archetype, 'regular') <> :archetype", archetype: Archetype.private_message)
if guardian.authenticated?
builder.left_join("topic_users AS tu ON (t.id = tu.topic_id AND tu.user_id = #{guardian.user.id.to_i})")
builder.where('COALESCE(tu.notification_level,1) > :muted', muted: TopicUser.notification_levels[:muted])
end
# not certain if pluck is right, cause it may interfere with caching # not certain if pluck is right, cause it may interfere with caching
builder.where('l.post_id in (:post_ids)', post_ids: posts.map(&:id)) builder.where('l.post_id in (:post_ids)', post_ids: posts.map(&:id))
builder.secure_category(guardian.secure_category_ids) builder.secure_category(guardian.secure_category_ids)

View File

@ -53,6 +53,19 @@ describe CategoryList do
expect(CategoryList.new(Guardian.new(nil), include_topics: true).categories.find { |x| x.name == private_cat.name }).to eq(nil) expect(CategoryList.new(Guardian.new(nil), include_topics: true).categories.find { |x| x.name == private_cat.name }).to eq(nil)
end end
it "doesn't show muted topics" do
cat = Fabricate(:category_with_definition) # public category
topic = Fabricate(:topic, category: cat)
CategoryFeaturedTopic.feature_topics
expect(CategoryList.new(Guardian.new(user), include_topics: true).categories.find { |x| x.name == cat.name }.displayable_topics.count).to eq(1)
TopicUser.change(user.id, topic.id, notification_level: TopicUser.notification_levels[:muted])
expect(CategoryList.new(Guardian.new(user), include_topics: true).categories.find { |x| x.name == cat.name }.displayable_topics.count).to eq(0)
end
end end
context "when mute_all_categories_by_default enabled" do context "when mute_all_categories_by_default enabled" do

View File

@ -472,6 +472,22 @@ describe TopicLink do
expect(TopicLink.topic_map(Guardian.new, post.topic_id).count).to eq(0) expect(TopicLink.topic_map(Guardian.new, post.topic_id).count).to eq(0)
end end
it 'secures internal links correctly' do
other_topic = Fabricate(:topic)
other_user = Fabricate(:user)
url = "http://#{test_uri.host}/t/topic-slug/#{other_topic.id}"
post = Fabricate(:post, raw: "hello test topic #{url}")
TopicLink.extract_from(post)
TopicLinkClick.create!(topic_link: post.topic.topic_links.first, ip_address: '192.168.1.1')
expect(TopicLink.counts_for(Guardian.new(other_user), post.topic, [post]).length).to eq(1)
TopicUser.change(other_user.id, other_topic.id, notification_level: TopicUser.notification_levels[:muted])
expect(TopicLink.counts_for(Guardian.new(other_user), post.topic, [post]).length).to eq(0)
end
end end
describe ".duplicate_lookup" do describe ".duplicate_lookup" do