mirror of
https://github.com/discourse/discourse.git
synced 2025-02-25 18:55:32 -06:00
SECURITY: Respect topic permissions when loading bookmark metadata
Co-authored-by: Martin Brennan <martin@discourse.org> Co-authored-by: Sam Saffron <sam.saffron@gmail.com>
This commit is contained in:
@@ -18,18 +18,22 @@ class BookmarkQuery
|
||||
end
|
||||
end
|
||||
|
||||
def initialize(user, params = {})
|
||||
def initialize(user:, guardian: nil, params: {})
|
||||
@user = user
|
||||
@params = params
|
||||
@guardian = guardian || Guardian.new(@user)
|
||||
end
|
||||
|
||||
def list_all
|
||||
results = user_bookmarks
|
||||
.joins('INNER JOIN topics ON topics.id = bookmarks.topic_id')
|
||||
.joins('INNER JOIN posts ON posts.id = bookmarks.post_id')
|
||||
.joins('INNER JOIN users ON users.id = posts.user_id')
|
||||
.order('bookmarks.created_at DESC')
|
||||
|
||||
topics = Topic.listable_topics.secured(@guardian)
|
||||
pms = Topic.private_messages_for_user(@user)
|
||||
results = results.merge(topics.or(pms))
|
||||
|
||||
results = results.merge(Post.secured(@guardian))
|
||||
|
||||
if @params[:limit]
|
||||
results = results.limit(@params[:limit])
|
||||
end
|
||||
@@ -42,7 +46,7 @@ class BookmarkQuery
|
||||
|
||||
BookmarkQuery.preload(results, self)
|
||||
|
||||
results
|
||||
@guardian.filter_allowed_categories(results)
|
||||
end
|
||||
|
||||
private
|
||||
@@ -51,5 +55,7 @@ class BookmarkQuery
|
||||
Bookmark.where(user: @user)
|
||||
.includes(topic: :tags)
|
||||
.includes(post: :user)
|
||||
.references(:topic)
|
||||
.references(:post)
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user