use crate::{ newtypes::{CommentId, CommentReportId, PersonId}, schema::comment_report::{ comment_id, dsl::{comment_report, resolved, resolver_id, updated}, }, source::comment_report::{CommentReport, CommentReportForm}, traits::Reportable, utils::{get_conn, DbPool}, }; use chrono::Utc; use diesel::{ dsl::{insert_into, update}, result::Error, ExpressionMethods, QueryDsl, }; use diesel_async::RunQueryDsl; #[async_trait] impl Reportable for CommentReport { type Form = CommentReportForm; type IdType = CommentReportId; type ObjectIdType = CommentId; /// creates a comment report and returns it /// /// * `conn` - the postgres connection /// * `comment_report_form` - the filled CommentReportForm to insert async fn report( pool: &mut DbPool<'_>, comment_report_form: &CommentReportForm, ) -> Result { let conn = &mut get_conn(pool).await?; insert_into(comment_report) .values(comment_report_form) .get_result::(conn) .await } /// resolve a comment report /// /// * `conn` - the postgres connection /// * `report_id` - the id of the report to resolve /// * `by_resolver_id` - the id of the user resolving the report async fn resolve( pool: &mut DbPool<'_>, report_id_: Self::IdType, by_resolver_id: PersonId, ) -> Result { let conn = &mut get_conn(pool).await?; update(comment_report.find(report_id_)) .set(( resolved.eq(true), resolver_id.eq(by_resolver_id), updated.eq(Utc::now()), )) .execute(conn) .await } async fn resolve_all_for_object( pool: &mut DbPool<'_>, comment_id_: CommentId, by_resolver_id: PersonId, ) -> Result { let conn = &mut get_conn(pool).await?; update(comment_report.filter(comment_id.eq(comment_id_))) .set(( resolved.eq(true), resolver_id.eq(by_resolver_id), updated.eq(Utc::now()), )) .execute(conn) .await } /// unresolve a comment report /// /// * `conn` - the postgres connection /// * `report_id` - the id of the report to unresolve /// * `by_resolver_id` - the id of the user unresolving the report async fn unresolve( pool: &mut DbPool<'_>, report_id_: Self::IdType, by_resolver_id: PersonId, ) -> Result { let conn = &mut get_conn(pool).await?; update(comment_report.find(report_id_)) .set(( resolved.eq(false), resolver_id.eq(by_resolver_id), updated.eq(Utc::now()), )) .execute(conn) .await } }