-use crate::Perform;
+use crate::{check_report_reason, Perform};
use actix_web::web::Data;
use lemmy_api_common::{
- blocking,
- check_community_ban,
comment::{CommentReportResponse, CreateCommentReport},
- get_local_user_view_from_jwt,
+ context::LemmyContext,
+ utils::{check_community_ban, get_local_user_view_from_jwt, send_new_report_email_to_admins},
+ websocket::UserOperation,
};
-use lemmy_apub::protocol::activities::community::report::Report;
-use lemmy_apub_lib::object_id::ObjectId;
use lemmy_db_schema::{
- source::comment_report::{CommentReport, CommentReportForm},
+ source::{
+ comment_report::{CommentReport, CommentReportForm},
+ local_site::LocalSite,
+ },
traits::Reportable,
};
-use lemmy_db_views::{comment_report_view::CommentReportView, comment_view::CommentView};
-use lemmy_utils::{ConnectionId, LemmyError};
-use lemmy_websocket::{messages::SendModRoomMessage, LemmyContext, UserOperation};
+use lemmy_db_views::structs::{CommentReportView, CommentView};
+use lemmy_utils::{error::LemmyError, ConnectionId};
/// Creates a comment report and notifies the moderators of the community
#[async_trait::async_trait(?Send)]
let data: &CreateCommentReport = self;
let local_user_view =
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
+ let local_site = LocalSite::read(context.pool()).await?;
- // check size of report and check for whitespace
- let reason = data.reason.trim();
- if reason.is_empty() {
- return Err(LemmyError::from_message("report_reason_required"));
- }
- if reason.chars().count() > 1000 {
- return Err(LemmyError::from_message("report_too_long"));
- }
+ let reason = self.reason.trim();
+ check_report_reason(reason, &local_site)?;
let person_id = local_user_view.person.id;
let comment_id = data.comment_id;
- let comment_view = blocking(context.pool(), move |conn| {
- CommentView::read(conn, comment_id, None)
- })
- .await??;
+ let comment_view = CommentView::read(context.pool(), comment_id, None).await?;
check_community_ban(person_id, comment_view.community.id, context.pool()).await?;
creator_id: person_id,
comment_id,
original_comment_text: comment_view.comment.content,
- reason: data.reason.to_owned(),
+ reason: reason.to_owned(),
};
- let report = blocking(context.pool(), move |conn| {
- CommentReport::report(conn, &report_form)
- })
- .await?
- .map_err(|e| LemmyError::from_error_message(e, "couldnt_create_report"))?;
+ let report = CommentReport::report(context.pool(), &report_form)
+ .await
+ .map_err(|e| LemmyError::from_error_message(e, "couldnt_create_report"))?;
- let comment_report_view = blocking(context.pool(), move |conn| {
- CommentReportView::read(conn, report.id, person_id)
- })
- .await??;
+ let comment_report_view = CommentReportView::read(context.pool(), report.id, person_id).await?;
+
+ // Email the admins
+ if local_site.reports_email_admins {
+ send_new_report_email_to_admins(
+ &comment_report_view.creator.name,
+ &comment_report_view.comment_creator.name,
+ context.pool(),
+ context.settings(),
+ )
+ .await?;
+ }
let res = CommentReportResponse {
comment_report_view,
};
- context.chat_server().do_send(SendModRoomMessage {
- op: UserOperation::CreateCommentReport,
- response: res.clone(),
- community_id: comment_view.community.id,
- websocket_id,
- });
-
- Report::send(
- ObjectId::new(comment_view.comment.ap_id),
- &local_user_view.person.into(),
- ObjectId::new(comment_view.community.actor_id),
- reason.to_string(),
- context,
- )
- .await?;
+ context
+ .chat_server()
+ .send_mod_room_message(
+ UserOperation::CreateCommentReport,
+ &res,
+ comment_view.community.id,
+ websocket_id,
+ )
+ .await?;
Ok(res)
}