mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-11-16 01:14:02 +00:00
c9f1407429
* Initial commit to bump diesel to 2.0.0-rc.0 and see what happens * Add chrono feature from diesel * db_schema crate is close to building? * Upgrade diesel-derive-newtype * Mostly modifying references to connections to be mutable ones; also used new way to do migrations as suggested by the migration guide; a lot more compiles now, though I can't figure out this tricky ToSql issue at the moment * Running clippy --fix * Trying to fix drone clippy 1 * Fix clippy * Upgrade clux-musl * Trying to fix drone clippy 2 * Trying to fix drone clippy 3 * Trying to fix drone clippy 5 * Adding diesel table aliases, removing sql view hack. Fixes #2101 Co-authored-by: Steven Chu <stevenc1@gmail.com> Co-authored-by: Nutomic <me@nutomic.com>
65 lines
1.8 KiB
Rust
65 lines
1.8 KiB
Rust
use crate::{
|
|
newtypes::{CommentReportId, PersonId},
|
|
source::comment_report::{CommentReport, CommentReportForm},
|
|
traits::Reportable,
|
|
utils::naive_now,
|
|
};
|
|
use diesel::{dsl::*, result::Error, *};
|
|
|
|
impl Reportable for CommentReport {
|
|
type Form = CommentReportForm;
|
|
type IdType = CommentReportId;
|
|
/// creates a comment report and returns it
|
|
///
|
|
/// * `conn` - the postgres connection
|
|
/// * `comment_report_form` - the filled CommentReportForm to insert
|
|
fn report(
|
|
conn: &mut PgConnection,
|
|
comment_report_form: &CommentReportForm,
|
|
) -> Result<Self, Error> {
|
|
use crate::schema::comment_report::dsl::*;
|
|
insert_into(comment_report)
|
|
.values(comment_report_form)
|
|
.get_result::<Self>(conn)
|
|
}
|
|
|
|
/// 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
|
|
fn resolve(
|
|
conn: &mut PgConnection,
|
|
report_id: Self::IdType,
|
|
by_resolver_id: PersonId,
|
|
) -> Result<usize, Error> {
|
|
use crate::schema::comment_report::dsl::*;
|
|
update(comment_report.find(report_id))
|
|
.set((
|
|
resolved.eq(true),
|
|
resolver_id.eq(by_resolver_id),
|
|
updated.eq(naive_now()),
|
|
))
|
|
.execute(conn)
|
|
}
|
|
|
|
/// 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
|
|
fn unresolve(
|
|
conn: &mut PgConnection,
|
|
report_id: Self::IdType,
|
|
by_resolver_id: PersonId,
|
|
) -> Result<usize, Error> {
|
|
use crate::schema::comment_report::dsl::*;
|
|
update(comment_report.find(report_id))
|
|
.set((
|
|
resolved.eq(false),
|
|
resolver_id.eq(by_resolver_id),
|
|
updated.eq(naive_now()),
|
|
))
|
|
.execute(conn)
|
|
}
|
|
}
|