mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-06-01 00:28:05 +00:00
35cbae61bc
* Respond directly with LemmyError Instrument Perform implementations for more precise traces Use ApiError to format JSON errors when messages are present Keep SpanTrace output in LemmyError Display impl * Hide SpanTrace debug output from LemmyError * Don't log when entering spans, only when leaving * Update actix-web * Update actix-rt * Add newline after error info in LemmyError Display impl * Propogate span information to blocking operations * Instrument apub functions * Use skip_all for more instrument attributes, don't skip 'self' in some api actions * Make message a static string * Send proper JSON over websocket * Add 'message' to LemmyError display if present * Use a quieter root span builder, don't pretty-print logs * Keep passwords and emails out of logs * Re-enable logging Login * Instrument feeds * Emit our own errors * Move error log after status code recording * Make Sensitive generic over the inner type * Remove line that logged secrets
106 lines
2.5 KiB
Rust
106 lines
2.5 KiB
Rust
use lemmy_api_common::blocking;
|
|
use lemmy_db_schema::{
|
|
source::{
|
|
comment::{CommentLike, CommentLikeForm},
|
|
post::{PostLike, PostLikeForm},
|
|
},
|
|
traits::Likeable,
|
|
};
|
|
use lemmy_utils::LemmyError;
|
|
use lemmy_websocket::{
|
|
send::{send_comment_ws_message_simple, send_post_ws_message},
|
|
LemmyContext,
|
|
UserOperation,
|
|
};
|
|
|
|
use crate::{
|
|
objects::{comment::ApubComment, person::ApubPerson, post::ApubPost},
|
|
protocol::activities::voting::vote::VoteType,
|
|
};
|
|
|
|
pub mod undo_vote;
|
|
pub mod vote;
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn vote_comment(
|
|
vote_type: &VoteType,
|
|
actor: ApubPerson,
|
|
comment: &ApubComment,
|
|
context: &LemmyContext,
|
|
) -> Result<(), LemmyError> {
|
|
let comment_id = comment.id;
|
|
let like_form = CommentLikeForm {
|
|
comment_id,
|
|
post_id: comment.post_id,
|
|
person_id: actor.id,
|
|
score: vote_type.into(),
|
|
};
|
|
let person_id = actor.id;
|
|
blocking(context.pool(), move |conn| {
|
|
CommentLike::remove(conn, person_id, comment_id)?;
|
|
CommentLike::like(conn, &like_form)
|
|
})
|
|
.await??;
|
|
|
|
send_comment_ws_message_simple(comment_id, UserOperation::CreateCommentLike, context).await?;
|
|
Ok(())
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn vote_post(
|
|
vote_type: &VoteType,
|
|
actor: ApubPerson,
|
|
post: &ApubPost,
|
|
context: &LemmyContext,
|
|
) -> Result<(), LemmyError> {
|
|
let post_id = post.id;
|
|
let like_form = PostLikeForm {
|
|
post_id: post.id,
|
|
person_id: actor.id,
|
|
score: vote_type.into(),
|
|
};
|
|
let person_id = actor.id;
|
|
blocking(context.pool(), move |conn| {
|
|
PostLike::remove(conn, person_id, post_id)?;
|
|
PostLike::like(conn, &like_form)
|
|
})
|
|
.await??;
|
|
|
|
send_post_ws_message(post.id, UserOperation::CreatePostLike, None, None, context).await?;
|
|
Ok(())
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn undo_vote_comment(
|
|
actor: ApubPerson,
|
|
comment: &ApubComment,
|
|
context: &LemmyContext,
|
|
) -> Result<(), LemmyError> {
|
|
let comment_id = comment.id;
|
|
let person_id = actor.id;
|
|
blocking(context.pool(), move |conn| {
|
|
CommentLike::remove(conn, person_id, comment_id)
|
|
})
|
|
.await??;
|
|
|
|
send_comment_ws_message_simple(comment_id, UserOperation::CreateCommentLike, context).await?;
|
|
Ok(())
|
|
}
|
|
|
|
#[tracing::instrument(skip_all)]
|
|
async fn undo_vote_post(
|
|
actor: ApubPerson,
|
|
post: &ApubPost,
|
|
context: &LemmyContext,
|
|
) -> Result<(), LemmyError> {
|
|
let post_id = post.id;
|
|
let person_id = actor.id;
|
|
blocking(context.pool(), move |conn| {
|
|
PostLike::remove(conn, person_id, post_id)
|
|
})
|
|
.await??;
|
|
|
|
send_post_ws_message(post_id, UserOperation::CreatePostLike, None, None, context).await?;
|
|
Ok(())
|
|
}
|