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:
parent
095421a1e1
commit
cb0958fcea
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue