]> Untitled Git - lemmy.git/blobdiff - crates/db_schema/src/source/post_report.rs
Automatically resolve report when post/comment is removed (#3850)
[lemmy.git] / crates / db_schema / src / source / post_report.rs
index abee0f32f19b2c4e1277419ea48ea5635601e41d..74e4186702e6e68866b3efdf052cc567a172eb51 100644 (file)
@@ -1,19 +1,27 @@
 use crate::newtypes::{DbUrl, PersonId, PostId, PostReportId};
-use serde::{Deserialize, Serialize};
-
 #[cfg(feature = "full")]
 use crate::schema::post_report;
+use serde::{Deserialize, Serialize};
+use serde_with::skip_serializing_none;
+#[cfg(feature = "full")]
+use ts_rs::TS;
 
+#[skip_serializing_none]
 #[derive(PartialEq, Eq, Serialize, Deserialize, Debug, Clone)]
-#[cfg_attr(feature = "full", derive(Identifiable, Queryable, Associations))]
+#[cfg_attr(feature = "full", derive(Identifiable, Queryable, Associations, TS))]
 #[cfg_attr(feature = "full", diesel(belongs_to(crate::source::post::Post)))] // Is this the right assoc?
 #[cfg_attr(feature = "full", diesel(table_name = post_report))]
+#[cfg_attr(feature = "full", ts(export))]
+/// A post report.
 pub struct PostReport {
   pub id: PostReportId,
   pub creator_id: PersonId,
   pub post_id: PostId,
+  /// The original post title.
   pub original_post_name: String,
+  /// The original post url.
   pub original_post_url: Option<DbUrl>,
+  /// The original post body.
   pub original_post_body: Option<String>,
   pub reason: String,
   pub resolved: bool,
@@ -22,7 +30,7 @@ pub struct PostReport {
   pub updated: Option<chrono::NaiveDateTime>,
 }
 
-#[derive(Clone)]
+#[derive(Clone, Default)]
 #[cfg_attr(feature = "full", derive(Insertable, AsChangeset))]
 #[cfg_attr(feature = "full", diesel(table_name = post_report))]
 pub struct PostReportForm {