Skip to content

Commit

Permalink
Return content of removed comments for admins (ref #5232) (#5245)
Browse files Browse the repository at this point in the history
* Return content of removed comments for admins (ref #5232)

* fmt

* remove dbg
  • Loading branch information
Nutomic committed Dec 3, 2024
1 parent db88ba3 commit cd7759b
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 12 deletions.
3 changes: 0 additions & 3 deletions api_tests/src/comment.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,6 @@ test("Delete a comment", async () => {
commentRes.comment_view.comment.id,
);
expect(deleteCommentRes.comment_view.comment.deleted).toBe(true);
expect(deleteCommentRes.comment_view.comment.content).toBe("");

// Make sure that comment is undefined on beta
await waitUntil(
Expand Down Expand Up @@ -255,7 +254,6 @@ test("Remove a comment from admin and community on different instance", async ()
betaComment.comment.id,
);
expect(removeCommentRes.comment_view.comment.removed).toBe(true);
expect(removeCommentRes.comment_view.comment.content).toBe("");

// Comment text is also hidden from list
let listComments = await getComments(
Expand All @@ -264,7 +262,6 @@ test("Remove a comment from admin and community on different instance", async ()
);
expect(listComments.comments.length).toBe(1);
expect(listComments.comments[0].comment.removed).toBe(true);
expect(listComments.comments[0].comment.content).toBe("");

// Make sure its not removed on alpha
let refetchedPostComments = await getComments(
Expand Down
4 changes: 2 additions & 2 deletions crates/db_schema/src/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ pub async fn get_conn<'a, 'b: 'a>(pool: &'a mut DbPool<'b>) -> Result<DbConn<'a>
})
}

impl<'a> Deref for DbConn<'a> {
impl Deref for DbConn<'_> {
type Target = AsyncPgConnection;

fn deref(&self) -> &Self::Target {
Expand All @@ -94,7 +94,7 @@ impl<'a> Deref for DbConn<'a> {
}
}

impl<'a> DerefMut for DbConn<'a> {
impl DerefMut for DbConn<'_> {
fn deref_mut(&mut self) -> &mut Self::Target {
match self {
DbConn::Pool(conn) => conn.deref_mut(),
Expand Down
62 changes: 55 additions & 7 deletions crates/db_views/src/comment_view.rs
Original file line number Diff line number Diff line change
Expand Up @@ -365,6 +365,7 @@ impl CommentView {
comment_id: CommentId,
my_local_user: Option<&'a LocalUser>,
) -> Result<Option<Self>, Error> {
let is_admin = my_local_user.map(|u| u.admin).unwrap_or(false);
// If a person is given, then my_vote (res.9), if None, should be 0, not null
// Necessary to differentiate between other person's votes
if let Ok(Some(res)) = queries().read(pool, (comment_id, my_local_user)).await {
Expand All @@ -375,7 +376,7 @@ impl CommentView {
if res.comment.deleted || res.comment.removed {
new_view.comment.content = String::new();
}
Ok(Some(new_view))
Ok(Some(handle_deleted(res, is_admin)))
} else {
Ok(None)
}
Expand All @@ -402,22 +403,25 @@ pub struct CommentQuery<'a> {

impl<'a> CommentQuery<'a> {
pub async fn list(self, pool: &mut DbPool<'_>) -> Result<Vec<CommentView>, Error> {
let is_admin = self.local_user.map(|u| u.admin).unwrap_or(false);
Ok(
queries()
.list(pool, self)
.await?
.into_iter()
.map(|mut c| {
if c.comment.deleted || c.comment.removed {
c.comment.content = String::new();
}
c
})
.map(|c| handle_deleted(c, is_admin))
.collect(),
)
}
}

fn handle_deleted(mut c: CommentView, is_admin: bool) -> CommentView {
if !is_admin && (c.comment.deleted || c.comment.removed) {
c.comment.content = String::new();
}
c
}

#[cfg(test)]
#[allow(clippy::indexing_slicing)]
mod tests {
Expand Down Expand Up @@ -1232,4 +1236,48 @@ mod tests {

cleanup(data, pool).await
}

#[tokio::test]
#[serial]
async fn comment_removed() -> LemmyResult<()> {
let pool = &build_db_pool_for_tests().await;
let pool = &mut pool.into();
let mut data = init_data(pool).await?;

// Mark a comment as removed
let form = CommentUpdateForm {
removed: Some(true),
..Default::default()
};
Comment::update(pool, data.inserted_comment_0.id, &form).await?;

// Read as normal user, content is cleared
data.timmy_local_user_view.local_user.admin = false;
let comment_listing = CommentQuery {
community_id: Some(data.inserted_community.id),
local_user: Some(&data.timmy_local_user_view.local_user),
sort: Some(CommentSortType::Old),
..Default::default()
}
.list(pool)
.await?;
assert_eq!("", comment_listing[0].comment.content);

// Read as admin, content is returned
data.timmy_local_user_view.local_user.admin = true;
let comment_listing = CommentQuery {
community_id: Some(data.inserted_community.id),
local_user: Some(&data.timmy_local_user_view.local_user),
sort: Some(CommentSortType::Old),
..Default::default()
}
.list(pool)
.await?;
assert_eq!(
data.inserted_comment_0.content,
comment_listing[0].comment.content
);

cleanup(data, pool).await
}
}

0 comments on commit cd7759b

Please sign in to comment.