1 use crate::{ApubObject, Crud, Likeable, Readable, Saveable};
2 use diesel::{dsl::*, result::Error, *};
18 impl Crud<PostForm> for Post {
19 fn read(conn: &PgConnection, post_id: i32) -> Result<Self, Error> {
20 use lemmy_db_schema::schema::post::dsl::*;
21 post.find(post_id).first::<Self>(conn)
24 fn delete(conn: &PgConnection, post_id: i32) -> Result<usize, Error> {
25 use lemmy_db_schema::schema::post::dsl::*;
26 diesel::delete(post.find(post_id)).execute(conn)
29 fn create(conn: &PgConnection, new_post: &PostForm) -> Result<Self, Error> {
30 use lemmy_db_schema::schema::post::dsl::*;
31 insert_into(post).values(new_post).get_result::<Self>(conn)
34 fn update(conn: &PgConnection, post_id: i32, new_post: &PostForm) -> Result<Self, Error> {
35 use lemmy_db_schema::schema::post::dsl::*;
36 diesel::update(post.find(post_id))
38 .get_result::<Self>(conn)
43 //fn read(conn: &PgConnection, post_id: i32) -> Result<Post, Error>;
44 fn list_for_community(conn: &PgConnection, the_community_id: i32) -> Result<Vec<Post>, Error>;
45 fn update_ap_id(conn: &PgConnection, post_id: i32, apub_id: Url) -> Result<Post, Error>;
46 fn permadelete_for_creator(conn: &PgConnection, for_creator_id: i32) -> Result<Vec<Post>, Error>;
47 fn update_deleted(conn: &PgConnection, post_id: i32, new_deleted: bool) -> Result<Post, Error>;
48 fn update_removed(conn: &PgConnection, post_id: i32, new_removed: bool) -> Result<Post, Error>;
49 fn update_removed_for_creator(
52 for_community_id: Option<i32>,
54 ) -> Result<Vec<Post>, Error>;
55 fn update_locked(conn: &PgConnection, post_id: i32, new_locked: bool) -> Result<Post, Error>;
56 fn update_stickied(conn: &PgConnection, post_id: i32, new_stickied: bool) -> Result<Post, Error>;
57 fn is_post_creator(person_id: i32, post_creator_id: i32) -> bool;
61 fn list_for_community(conn: &PgConnection, the_community_id: i32) -> Result<Vec<Self>, Error> {
62 use lemmy_db_schema::schema::post::dsl::*;
64 .filter(community_id.eq(the_community_id))
65 .then_order_by(published.desc())
66 .then_order_by(stickied.desc())
71 fn update_ap_id(conn: &PgConnection, post_id: i32, apub_id: Url) -> Result<Self, Error> {
72 use lemmy_db_schema::schema::post::dsl::*;
74 diesel::update(post.find(post_id))
75 .set(ap_id.eq(apub_id))
76 .get_result::<Self>(conn)
79 fn permadelete_for_creator(conn: &PgConnection, for_creator_id: i32) -> Result<Vec<Self>, Error> {
80 use lemmy_db_schema::schema::post::dsl::*;
82 let perma_deleted = "*Permananently Deleted*";
83 let perma_deleted_url = "https://deleted.com";
85 diesel::update(post.filter(creator_id.eq(for_creator_id)))
87 name.eq(perma_deleted),
88 url.eq(perma_deleted_url),
89 body.eq(perma_deleted),
91 updated.eq(naive_now()),
93 .get_results::<Self>(conn)
96 fn update_deleted(conn: &PgConnection, post_id: i32, new_deleted: bool) -> Result<Self, Error> {
97 use lemmy_db_schema::schema::post::dsl::*;
98 diesel::update(post.find(post_id))
99 .set((deleted.eq(new_deleted), updated.eq(naive_now())))
100 .get_result::<Self>(conn)
103 fn update_removed(conn: &PgConnection, post_id: i32, new_removed: bool) -> Result<Self, Error> {
104 use lemmy_db_schema::schema::post::dsl::*;
105 diesel::update(post.find(post_id))
106 .set((removed.eq(new_removed), updated.eq(naive_now())))
107 .get_result::<Self>(conn)
110 fn update_removed_for_creator(
113 for_community_id: Option<i32>,
115 ) -> Result<Vec<Self>, Error> {
116 use lemmy_db_schema::schema::post::dsl::*;
118 let mut update = diesel::update(post).into_boxed();
119 update = update.filter(creator_id.eq(for_creator_id));
121 if let Some(for_community_id) = for_community_id {
122 update = update.filter(community_id.eq(for_community_id));
126 .set((removed.eq(new_removed), updated.eq(naive_now())))
127 .get_results::<Self>(conn)
130 fn update_locked(conn: &PgConnection, post_id: i32, new_locked: bool) -> Result<Self, Error> {
131 use lemmy_db_schema::schema::post::dsl::*;
132 diesel::update(post.find(post_id))
133 .set(locked.eq(new_locked))
134 .get_result::<Self>(conn)
137 fn update_stickied(conn: &PgConnection, post_id: i32, new_stickied: bool) -> Result<Self, Error> {
138 use lemmy_db_schema::schema::post::dsl::*;
139 diesel::update(post.find(post_id))
140 .set(stickied.eq(new_stickied))
141 .get_result::<Self>(conn)
144 fn is_post_creator(person_id: i32, post_creator_id: i32) -> bool {
145 person_id == post_creator_id
149 impl ApubObject<PostForm> for Post {
150 fn read_from_apub_id(conn: &PgConnection, object_id: &Url) -> Result<Self, Error> {
151 use lemmy_db_schema::schema::post::dsl::*;
152 post.filter(ap_id.eq(object_id)).first::<Self>(conn)
155 fn upsert(conn: &PgConnection, post_form: &PostForm) -> Result<Post, Error> {
156 use lemmy_db_schema::schema::post::dsl::*;
162 .get_result::<Self>(conn)
166 impl Likeable<PostLikeForm> for PostLike {
167 fn like(conn: &PgConnection, post_like_form: &PostLikeForm) -> Result<Self, Error> {
168 use lemmy_db_schema::schema::post_like::dsl::*;
169 insert_into(post_like)
170 .values(post_like_form)
171 .on_conflict((post_id, person_id))
174 .get_result::<Self>(conn)
176 fn remove(conn: &PgConnection, person_id: i32, post_id: i32) -> Result<usize, Error> {
177 use lemmy_db_schema::schema::post_like::dsl;
180 .filter(dsl::post_id.eq(post_id))
181 .filter(dsl::person_id.eq(person_id)),
187 impl Saveable<PostSavedForm> for PostSaved {
188 fn save(conn: &PgConnection, post_saved_form: &PostSavedForm) -> Result<Self, Error> {
189 use lemmy_db_schema::schema::post_saved::dsl::*;
190 insert_into(post_saved)
191 .values(post_saved_form)
192 .on_conflict((post_id, person_id))
194 .set(post_saved_form)
195 .get_result::<Self>(conn)
197 fn unsave(conn: &PgConnection, post_saved_form: &PostSavedForm) -> Result<usize, Error> {
198 use lemmy_db_schema::schema::post_saved::dsl::*;
201 .filter(post_id.eq(post_saved_form.post_id))
202 .filter(person_id.eq(post_saved_form.person_id)),
208 impl Readable<PostReadForm> for PostRead {
209 fn mark_as_read(conn: &PgConnection, post_read_form: &PostReadForm) -> Result<Self, Error> {
210 use lemmy_db_schema::schema::post_read::dsl::*;
211 insert_into(post_read)
212 .values(post_read_form)
213 .get_result::<Self>(conn)
216 fn mark_as_unread(conn: &PgConnection, post_read_form: &PostReadForm) -> Result<usize, Error> {
217 use lemmy_db_schema::schema::post_read::dsl::*;
220 .filter(post_id.eq(post_read_form.post_id))
221 .filter(person_id.eq(post_read_form.person_id)),
229 use crate::{establish_unpooled_connection, source::post::*, ListingType, SortType};
230 use lemmy_db_schema::source::{
231 community::{Community, CommunityForm},
237 let conn = establish_unpooled_connection();
239 let new_person = PersonForm {
241 preferred_username: None,
253 last_refreshed_at: None,
255 shared_inbox_url: None,
258 let inserted_person = Person::create(&conn, &new_person).unwrap();
260 let new_community = CommunityForm {
261 name: "test community_3".to_string(),
262 title: "nada".to_owned(),
264 creator_id: inserted_person.id,
273 last_refreshed_at: None,
279 shared_inbox_url: None,
282 let inserted_community = Community::create(&conn, &new_community).unwrap();
284 let new_post = PostForm {
285 name: "A test post".into(),
288 creator_id: inserted_person.id,
289 community_id: inserted_community.id,
297 embed_description: None,
305 let inserted_post = Post::create(&conn, &new_post).unwrap();
307 let expected_post = Post {
308 id: inserted_post.id,
309 name: "A test post".into(),
312 creator_id: inserted_person.id,
313 community_id: inserted_community.id,
314 published: inserted_post.published,
322 embed_description: None,
325 ap_id: inserted_post.ap_id.to_owned(),
330 let post_like_form = PostLikeForm {
331 post_id: inserted_post.id,
332 person_id: inserted_person.id,
336 let inserted_post_like = PostLike::like(&conn, &post_like_form).unwrap();
338 let expected_post_like = PostLike {
339 id: inserted_post_like.id,
340 post_id: inserted_post.id,
341 person_id: inserted_person.id,
342 published: inserted_post_like.published,
347 let post_saved_form = PostSavedForm {
348 post_id: inserted_post.id,
349 person_id: inserted_person.id,
352 let inserted_post_saved = PostSaved::save(&conn, &post_saved_form).unwrap();
354 let expected_post_saved = PostSaved {
355 id: inserted_post_saved.id,
356 post_id: inserted_post.id,
357 person_id: inserted_person.id,
358 published: inserted_post_saved.published,
362 let post_read_form = PostReadForm {
363 post_id: inserted_post.id,
364 person_id: inserted_person.id,
367 let inserted_post_read = PostRead::mark_as_read(&conn, &post_read_form).unwrap();
369 let expected_post_read = PostRead {
370 id: inserted_post_read.id,
371 post_id: inserted_post.id,
372 person_id: inserted_person.id,
373 published: inserted_post_read.published,
376 let read_post = Post::read(&conn, inserted_post.id).unwrap();
377 let updated_post = Post::update(&conn, inserted_post.id, &new_post).unwrap();
378 let like_removed = PostLike::remove(&conn, inserted_person.id, inserted_post.id).unwrap();
379 let saved_removed = PostSaved::unsave(&conn, &post_saved_form).unwrap();
380 let read_removed = PostRead::mark_as_unread(&conn, &post_read_form).unwrap();
381 let num_deleted = Post::delete(&conn, inserted_post.id).unwrap();
382 Community::delete(&conn, inserted_community.id).unwrap();
383 Person::delete(&conn, inserted_person.id).unwrap();
385 assert_eq!(expected_post, read_post);
386 assert_eq!(expected_post, inserted_post);
387 assert_eq!(expected_post, updated_post);
388 assert_eq!(expected_post_like, inserted_post_like);
389 assert_eq!(expected_post_saved, inserted_post_saved);
390 assert_eq!(expected_post_read, inserted_post_read);
391 assert_eq!(1, like_removed);
392 assert_eq!(1, saved_removed);
393 assert_eq!(1, read_removed);
394 assert_eq!(1, num_deleted);