1 use crate::{ApubObject, Crud, Likeable, Saveable};
2 use diesel::{dsl::*, result::Error, *};
17 fn update_ap_id(conn: &PgConnection, comment_id: i32, apub_id: Url) -> Result<Comment, Error>;
18 fn permadelete_for_creator(
21 ) -> Result<Vec<Comment>, Error>;
26 ) -> Result<Comment, Error>;
31 ) -> Result<Comment, Error>;
32 fn update_removed_for_creator(
36 ) -> Result<Vec<Comment>, Error>;
37 fn update_read(conn: &PgConnection, comment_id: i32, new_read: bool) -> Result<Comment, Error>;
42 ) -> Result<Comment, Error>;
45 impl Comment_ for Comment {
46 fn update_ap_id(conn: &PgConnection, comment_id: i32, apub_id: Url) -> Result<Self, Error> {
47 use lemmy_db_schema::schema::comment::dsl::*;
49 diesel::update(comment.find(comment_id))
50 .set(ap_id.eq(apub_id))
51 .get_result::<Self>(conn)
54 fn permadelete_for_creator(conn: &PgConnection, for_creator_id: i32) -> Result<Vec<Self>, Error> {
55 use lemmy_db_schema::schema::comment::dsl::*;
56 diesel::update(comment.filter(creator_id.eq(for_creator_id)))
58 content.eq("*Permananently Deleted*"),
60 updated.eq(naive_now()),
62 .get_results::<Self>(conn)
69 ) -> Result<Self, Error> {
70 use lemmy_db_schema::schema::comment::dsl::*;
71 diesel::update(comment.find(comment_id))
72 .set((deleted.eq(new_deleted), updated.eq(naive_now())))
73 .get_result::<Self>(conn)
80 ) -> Result<Self, Error> {
81 use lemmy_db_schema::schema::comment::dsl::*;
82 diesel::update(comment.find(comment_id))
83 .set((removed.eq(new_removed), updated.eq(naive_now())))
84 .get_result::<Self>(conn)
87 fn update_removed_for_creator(
91 ) -> Result<Vec<Self>, Error> {
92 use lemmy_db_schema::schema::comment::dsl::*;
93 diesel::update(comment.filter(creator_id.eq(for_creator_id)))
94 .set((removed.eq(new_removed), updated.eq(naive_now())))
95 .get_results::<Self>(conn)
98 fn update_read(conn: &PgConnection, comment_id: i32, new_read: bool) -> Result<Self, Error> {
99 use lemmy_db_schema::schema::comment::dsl::*;
100 diesel::update(comment.find(comment_id))
101 .set(read.eq(new_read))
102 .get_result::<Self>(conn)
109 ) -> Result<Self, Error> {
110 use lemmy_db_schema::schema::comment::dsl::*;
111 diesel::update(comment.find(comment_id))
112 .set((content.eq(new_content), updated.eq(naive_now())))
113 .get_result::<Self>(conn)
117 impl Crud<CommentForm> for Comment {
118 fn read(conn: &PgConnection, comment_id: i32) -> Result<Self, Error> {
119 use lemmy_db_schema::schema::comment::dsl::*;
120 comment.find(comment_id).first::<Self>(conn)
123 fn delete(conn: &PgConnection, comment_id: i32) -> Result<usize, Error> {
124 use lemmy_db_schema::schema::comment::dsl::*;
125 diesel::delete(comment.find(comment_id)).execute(conn)
128 fn create(conn: &PgConnection, comment_form: &CommentForm) -> Result<Self, Error> {
129 use lemmy_db_schema::schema::comment::dsl::*;
131 .values(comment_form)
132 .get_result::<Self>(conn)
138 comment_form: &CommentForm,
139 ) -> Result<Self, Error> {
140 use lemmy_db_schema::schema::comment::dsl::*;
141 diesel::update(comment.find(comment_id))
143 .get_result::<Self>(conn)
147 impl ApubObject<CommentForm> for Comment {
148 fn read_from_apub_id(conn: &PgConnection, object_id: &Url) -> Result<Self, Error> {
149 use lemmy_db_schema::schema::comment::dsl::*;
150 comment.filter(ap_id.eq(object_id)).first::<Self>(conn)
153 fn upsert(conn: &PgConnection, comment_form: &CommentForm) -> Result<Self, Error> {
154 use lemmy_db_schema::schema::comment::dsl::*;
156 .values(comment_form)
160 .get_result::<Self>(conn)
164 impl Likeable<CommentLikeForm> for CommentLike {
165 fn like(conn: &PgConnection, comment_like_form: &CommentLikeForm) -> Result<Self, Error> {
166 use lemmy_db_schema::schema::comment_like::dsl::*;
167 insert_into(comment_like)
168 .values(comment_like_form)
169 .on_conflict((comment_id, person_id))
171 .set(comment_like_form)
172 .get_result::<Self>(conn)
174 fn remove(conn: &PgConnection, person_id: i32, comment_id: i32) -> Result<usize, Error> {
175 use lemmy_db_schema::schema::comment_like::dsl;
178 .filter(dsl::comment_id.eq(comment_id))
179 .filter(dsl::person_id.eq(person_id)),
185 impl Saveable<CommentSavedForm> for CommentSaved {
186 fn save(conn: &PgConnection, comment_saved_form: &CommentSavedForm) -> Result<Self, Error> {
187 use lemmy_db_schema::schema::comment_saved::dsl::*;
188 insert_into(comment_saved)
189 .values(comment_saved_form)
190 .on_conflict((comment_id, user_id))
192 .set(comment_saved_form)
193 .get_result::<Self>(conn)
195 fn unsave(conn: &PgConnection, comment_saved_form: &CommentSavedForm) -> Result<usize, Error> {
196 use lemmy_db_schema::schema::comment_saved::dsl::*;
199 .filter(comment_id.eq(comment_saved_form.comment_id))
200 .filter(user_id.eq(comment_saved_form.person_id)),
208 use crate::{establish_unpooled_connection, Crud, Likeable, ListingType, Saveable, SortType};
209 use lemmy_db_schema::source::{
211 community::{Community, CommunityForm},
213 person::{PersonForm, Person},
218 let conn = establish_unpooled_connection();
220 let new_person = PersonForm {
221 name: "terry".into(),
222 preferred_username: None,
234 last_refreshed_at: None,
236 shared_inbox_url: None,
239 let inserted_persod = Person::create(&conn, &new_person).unwrap();
241 let new_community = CommunityForm {
242 name: "test community".to_string(),
243 title: "nada".to_owned(),
245 creator_id: inserted_persod.id,
254 last_refreshed_at: None,
259 shared_inbox_url: None,
263 let inserted_community = Community::create(&conn, &new_community).unwrap();
265 let new_post = PostForm {
266 name: "A test post".into(),
267 creator_id: inserted_persod.id,
270 community_id: inserted_community.id,
278 embed_description: None,
286 let inserted_post = Post::create(&conn, &new_post).unwrap();
288 let comment_form = CommentForm {
289 content: "A test comment".into(),
290 creator_id: inserted_persod.id,
291 post_id: inserted_post.id,
302 let inserted_comment = Comment::create(&conn, &comment_form).unwrap();
304 let expected_comment = Comment {
305 id: inserted_comment.id,
306 content: "A test comment".into(),
307 creator_id: inserted_persod.id,
308 post_id: inserted_post.id,
313 published: inserted_comment.published,
315 ap_id: inserted_comment.ap_id.to_owned(),
319 let child_comment_form = CommentForm {
320 content: "A child comment".into(),
321 creator_id: inserted_persod.id,
322 post_id: inserted_post.id,
323 parent_id: Some(inserted_comment.id),
333 let inserted_child_comment = Comment::create(&conn, &child_comment_form).unwrap();
336 let comment_like_form = CommentLikeForm {
337 comment_id: inserted_comment.id,
338 post_id: inserted_post.id,
339 person_id: inserted_persod.id,
343 let inserted_comment_like = CommentLike::like(&conn, &comment_like_form).unwrap();
345 let expected_comment_like = CommentLike {
346 id: inserted_comment_like.id,
347 comment_id: inserted_comment.id,
348 post_id: inserted_post.id,
349 person_id: inserted_persod.id,
350 published: inserted_comment_like.published,
355 let comment_saved_form = CommentSavedForm {
356 comment_id: inserted_comment.id,
357 person_id: inserted_persod.id,
360 let inserted_comment_saved = CommentSaved::save(&conn, &comment_saved_form).unwrap();
362 let expected_comment_saved = CommentSaved {
363 id: inserted_comment_saved.id,
364 comment_id: inserted_comment.id,
365 person_id: inserted_persod.id,
366 published: inserted_comment_saved.published,
369 let read_comment = Comment::read(&conn, inserted_comment.id).unwrap();
370 let updated_comment = Comment::update(&conn, inserted_comment.id, &comment_form).unwrap();
371 let like_removed = CommentLike::remove(&conn, inserted_persod.id, inserted_comment.id).unwrap();
372 let saved_removed = CommentSaved::unsave(&conn, &comment_saved_form).unwrap();
373 let num_deleted = Comment::delete(&conn, inserted_comment.id).unwrap();
374 Comment::delete(&conn, inserted_child_comment.id).unwrap();
375 Post::delete(&conn, inserted_post.id).unwrap();
376 Community::delete(&conn, inserted_community.id).unwrap();
377 Person::delete(&conn, inserted_persod.id).unwrap();
379 assert_eq!(expected_comment, read_comment);
380 assert_eq!(expected_comment, inserted_comment);
381 assert_eq!(expected_comment, updated_comment);
382 assert_eq!(expected_comment_like, inserted_comment_like);
383 assert_eq!(expected_comment_saved, inserted_comment_saved);
386 inserted_child_comment.parent_id.unwrap()
388 assert_eq!(1, like_removed);
389 assert_eq!(1, saved_removed);
390 assert_eq!(1, num_deleted);