mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2024-11-27 03:51:08 +00:00
Privacy filter for thread
This commit is contained in:
parent
7caaddbb22
commit
cd57161489
1 changed files with 10 additions and 3 deletions
|
@ -109,24 +109,31 @@ class Status(View):
|
||||||
status.to_activity(pure=not is_bookwyrm_request(request))
|
status.to_activity(pure=not is_bookwyrm_request(request))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
visible_thread = privacy_filter(
|
||||||
|
request.user,
|
||||||
|
models.Status.objects.filter(thread_id=status.thread_id)
|
||||||
|
).values_list("id", flat=True)
|
||||||
|
visible_thread = list(visible_thread)
|
||||||
|
|
||||||
children = models.Status.objects.select_subclasses().raw("""
|
children = models.Status.objects.select_subclasses().raw("""
|
||||||
WITH RECURSIVE get_thread(depth, id, path) AS (
|
WITH RECURSIVE get_thread(depth, id, path) AS (
|
||||||
|
|
||||||
SELECT 1, st.id, ARRAY[st.id]
|
SELECT 1, st.id, ARRAY[st.id]
|
||||||
FROM bookwyrm_status st
|
FROM bookwyrm_status st
|
||||||
WHERE reply_parent_id = '%s'
|
WHERE reply_parent_id = '%s' AND id = ANY(%s)
|
||||||
|
|
||||||
UNION
|
UNION
|
||||||
|
|
||||||
SELECT (gt.depth + 1), st.id, path || st.id
|
SELECT (gt.depth + 1), st.id, path || st.id
|
||||||
FROM get_thread gt, bookwyrm_status st
|
FROM get_thread gt, bookwyrm_status st
|
||||||
|
|
||||||
WHERE st.reply_parent_id = gt.id AND depth < 5
|
WHERE st.reply_parent_id = gt.id AND depth < 5 AND st.id = ANY(%s)
|
||||||
|
|
||||||
)
|
)
|
||||||
|
|
||||||
SELECT * FROM get_thread ORDER BY path;
|
SELECT * FROM get_thread ORDER BY path;
|
||||||
""", params=[status.id])
|
""", params=[status.id, visible_thread, visible_thread])
|
||||||
|
|
||||||
|
|
||||||
data = {
|
data = {
|
||||||
**feed_page_data(request.user),
|
**feed_page_data(request.user),
|
||||||
|
|
Loading…
Reference in a new issue