mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-01-04 17:21:35 +00:00
1d38aad9d3
* a lot * merge * Fix stuff broken by merge * Get rid of repetitive `&mut *context.conn().await?` * Add blank lines under each line with `conn =` * Fix style mistakes (partial) * Revert "Fix style mistakes (partial)" This reverts commit48a033b87f
. * Revert "Add blank lines under each line with `conn =`" This reverts commit773a6d3beb
. * Revert "Get rid of repetitive `&mut *context.conn().await?`" This reverts commitd2c6263ea1
. * Use DbConn for CaptchaAnswer methods * DbConn trait * Remove more `&mut *` * Fix stuff * Re-run CI * try to make ci start * fix * fix * Fix api_common::utils * Fix apub::activities::block * Fix apub::api::resolve_object * Fix some things * Revert "Fix some things" This reverts commit2bf8574bc8
. * Revert "Fix apub::api::resolve_object" This reverts commit3e4059aabb
. * Revert "Fix apub::activities::block" This reverts commit3b02389abd
. * Revert "Fix api_common::utils" This reverts commit7dc73de613
. * Revert "Revert "Fix api_common::utils"" This reverts commitf740f115e5
. * Revert "Revert "Fix apub::activities::block"" This reverts commit2ee206af7c
. * Revert "Revert "Fix apub::api::resolve_object"" This reverts commit96ed8bf2e9
. * Fix fetch_local_site_data * Fix get_comment_parent_creator * Remove unused perma deleted text * Fix routes::feeds * Fix lib.rs * Update lib.rs * rerun ci * Attempt to create custom GetConn and RunQueryDsl traits * Start over * Add GetConn trait * aaaa * Revert "aaaa" This reverts commitacc9ca1aed
. * Revert "Revert "aaaa"" This reverts commit443a2a00a5
. * still aaaaaaaaaaaaa * Return to earlier thing Revert "Add GetConn trait" This reverts commitab4e94aea5
. * Try to use DbPool enum * Revert "Try to use DbPool enum" This reverts commite4d1712646
. * DbConn and DbPool enums (db_schema only fails to compile for tests) * fmt * Make functions take `&mut DbPool<'_>` and make db_schema tests compile * Add try_join_with_pool macro and run fix-clippy on more crates * Fix some errors * I did it * Remove function variants that take connection * rerun ci * rerun ci * rerun ci
66 lines
2.2 KiB
Rust
66 lines
2.2 KiB
Rust
use crate::{check_report_reason, Perform};
|
|
use actix_web::web::Data;
|
|
use lemmy_api_common::{
|
|
context::LemmyContext,
|
|
post::{CreatePostReport, PostReportResponse},
|
|
utils::{check_community_ban, local_user_view_from_jwt, send_new_report_email_to_admins},
|
|
};
|
|
use lemmy_db_schema::{
|
|
source::{
|
|
local_site::LocalSite,
|
|
post_report::{PostReport, PostReportForm},
|
|
},
|
|
traits::Reportable,
|
|
};
|
|
use lemmy_db_views::structs::{PostReportView, PostView};
|
|
use lemmy_utils::error::{LemmyError, LemmyErrorExt, LemmyErrorType};
|
|
|
|
/// Creates a post report and notifies the moderators of the community
|
|
#[async_trait::async_trait(?Send)]
|
|
impl Perform for CreatePostReport {
|
|
type Response = PostReportResponse;
|
|
|
|
#[tracing::instrument(skip(context))]
|
|
async fn perform(&self, context: &Data<LemmyContext>) -> Result<PostReportResponse, LemmyError> {
|
|
let data: &CreatePostReport = self;
|
|
let local_user_view = local_user_view_from_jwt(&data.auth, context).await?;
|
|
let local_site = LocalSite::read(&mut context.pool()).await?;
|
|
|
|
let reason = self.reason.trim();
|
|
check_report_reason(reason, &local_site)?;
|
|
|
|
let person_id = local_user_view.person.id;
|
|
let post_id = data.post_id;
|
|
let post_view = PostView::read(&mut context.pool(), post_id, None, None).await?;
|
|
|
|
check_community_ban(person_id, post_view.community.id, &mut context.pool()).await?;
|
|
|
|
let report_form = PostReportForm {
|
|
creator_id: person_id,
|
|
post_id,
|
|
original_post_name: post_view.post.name,
|
|
original_post_url: post_view.post.url,
|
|
original_post_body: post_view.post.body,
|
|
reason: reason.to_owned(),
|
|
};
|
|
|
|
let report = PostReport::report(&mut context.pool(), &report_form)
|
|
.await
|
|
.with_lemmy_type(LemmyErrorType::CouldntCreateReport)?;
|
|
|
|
let post_report_view = PostReportView::read(&mut context.pool(), report.id, person_id).await?;
|
|
|
|
// Email the admins
|
|
if local_site.reports_email_admins {
|
|
send_new_report_email_to_admins(
|
|
&post_report_view.creator.name,
|
|
&post_report_view.post_creator.name,
|
|
&mut context.pool(),
|
|
context.settings(),
|
|
)
|
|
.await?;
|
|
}
|
|
|
|
Ok(PostReportResponse { post_report_view })
|
|
}
|
|
}
|