2021-01-06 13:23:05 -05:00
use diesel ::{ pg ::Pg , result ::Error , * } ;
2020-12-22 00:27:42 +01:00
use lemmy_db_queries ::{
2020-12-10 15:53:49 -05:00
aggregates ::post_aggregates ::PostAggregates ,
functions ::hot_rank ,
fuzzy_search ,
limit_and_offset ,
ListingType ,
MaybeOptional ,
SortType ,
ToSafe ,
2020-12-22 00:27:42 +01:00
ViewToVec ,
2020-12-10 15:53:49 -05:00
} ;
2020-12-18 18:27:25 +01:00
use lemmy_db_schema ::{
2020-12-10 15:53:49 -05:00
schema ::{
community ,
community_follower ,
2021-03-10 17:33:55 -05:00
community_person_ban ,
2021-03-10 23:43:11 -05:00
person ,
2020-12-10 15:53:49 -05:00
post ,
post_aggregates ,
post_like ,
post_read ,
post_saved ,
} ,
2020-12-13 12:04:42 -05:00
source ::{
2021-03-10 23:43:11 -05:00
community ::{ Community , CommunityFollower , CommunityPersonBan , CommunitySafe } ,
person ::{ Person , PersonSafe } ,
2020-12-13 12:04:42 -05:00
post ::{ Post , PostRead , PostSaved } ,
} ,
2021-03-18 16:25:21 -04:00
CommunityId ,
PersonId ,
PostId ,
2020-12-10 15:53:49 -05:00
} ;
2021-01-06 13:23:05 -05:00
use log ::debug ;
2020-12-10 15:53:49 -05:00
use serde ::Serialize ;
2020-12-11 10:27:33 -05:00
#[ derive(Debug, PartialEq, Serialize, Clone) ]
2020-12-10 15:53:49 -05:00
pub struct PostView {
pub post : Post ,
2021-03-10 17:33:55 -05:00
pub creator : PersonSafe ,
2020-12-10 15:53:49 -05:00
pub community : CommunitySafe ,
2021-03-10 17:33:55 -05:00
pub creator_banned_from_community : bool , // Left Join to CommunityPersonBan
2020-12-15 10:28:25 -05:00
pub counts : PostAggregates ,
pub subscribed : bool , // Left join to CommunityFollower
pub saved : bool , // Left join to PostSaved
pub read : bool , // Left join to PostRead
pub my_vote : Option < i16 > , // Left join to PostLike
2020-12-10 15:53:49 -05:00
}
2020-12-10 20:39:42 -05:00
type PostViewTuple = (
2020-12-10 15:53:49 -05:00
Post ,
2021-03-10 17:33:55 -05:00
PersonSafe ,
2020-12-10 15:53:49 -05:00
CommunitySafe ,
2021-02-26 08:49:58 -05:00
Option < CommunityPersonBan > ,
2020-12-10 15:53:49 -05:00
PostAggregates ,
Option < CommunityFollower > ,
Option < PostSaved > ,
Option < PostRead > ,
Option < i16 > ,
) ;
impl PostView {
2021-03-18 16:25:21 -04:00
pub fn read (
conn : & PgConnection ,
post_id : PostId ,
my_person_id : Option < PersonId > ,
) -> Result < Self , Error > {
2020-12-10 15:53:49 -05:00
// The left join below will return None in this case
2021-03-18 16:25:21 -04:00
let person_id_join = my_person_id . unwrap_or ( PersonId ( - 1 ) ) ;
2020-12-10 15:53:49 -05:00
2020-12-11 10:27:33 -05:00
let (
post ,
creator ,
community ,
creator_banned_from_community ,
counts ,
follower ,
saved ,
read ,
2021-01-31 10:29:21 -05:00
post_like ,
2020-12-11 10:27:33 -05:00
) = post ::table
. find ( post_id )
2021-03-10 17:33:55 -05:00
. inner_join ( person ::table )
2020-12-11 10:27:33 -05:00
. inner_join ( community ::table )
. left_join (
2021-03-10 17:33:55 -05:00
community_person_ban ::table . on (
2020-12-11 10:27:33 -05:00
post ::community_id
2021-03-10 17:33:55 -05:00
. eq ( community_person_ban ::community_id )
. and ( community_person_ban ::person_id . eq ( post ::creator_id ) ) ,
2020-12-11 10:27:33 -05:00
) ,
)
. inner_join ( post_aggregates ::table )
. left_join (
community_follower ::table . on (
post ::community_id
. eq ( community_follower ::community_id )
2021-03-10 17:33:55 -05:00
. and ( community_follower ::person_id . eq ( person_id_join ) ) ,
2020-12-11 10:27:33 -05:00
) ,
)
. left_join (
post_saved ::table . on (
post ::id
. eq ( post_saved ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_saved ::person_id . eq ( person_id_join ) ) ,
2020-12-11 10:27:33 -05:00
) ,
)
. left_join (
post_read ::table . on (
post ::id
. eq ( post_read ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_read ::person_id . eq ( person_id_join ) ) ,
2020-12-11 10:27:33 -05:00
) ,
)
. left_join (
post_like ::table . on (
post ::id
. eq ( post_like ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_like ::person_id . eq ( person_id_join ) ) ,
2020-12-11 10:27:33 -05:00
) ,
)
. select ( (
post ::all_columns ,
2021-03-10 17:33:55 -05:00
Person ::safe_columns_tuple ( ) ,
2020-12-11 10:27:33 -05:00
Community ::safe_columns_tuple ( ) ,
2021-03-10 17:33:55 -05:00
community_person_ban ::all_columns . nullable ( ) ,
2020-12-11 10:27:33 -05:00
post_aggregates ::all_columns ,
community_follower ::all_columns . nullable ( ) ,
post_saved ::all_columns . nullable ( ) ,
post_read ::all_columns . nullable ( ) ,
post_like ::score . nullable ( ) ,
) )
. first ::< PostViewTuple > ( conn ) ? ;
2020-12-10 15:53:49 -05:00
2021-03-10 17:33:55 -05:00
// If a person is given, then my_vote, if None, should be 0, not null
// Necessary to differentiate between other person's votes
let my_vote = if my_person_id . is_some ( ) & & post_like . is_none ( ) {
2021-01-31 10:29:21 -05:00
Some ( 0 )
} else {
post_like
} ;
2020-12-10 15:53:49 -05:00
Ok ( PostView {
post ,
creator ,
community ,
2020-12-11 10:27:33 -05:00
creator_banned_from_community : creator_banned_from_community . is_some ( ) ,
2020-12-10 15:53:49 -05:00
counts ,
subscribed : follower . is_some ( ) ,
saved : saved . is_some ( ) ,
read : read . is_some ( ) ,
my_vote ,
} )
}
}
pub struct PostQueryBuilder < ' a > {
conn : & ' a PgConnection ,
2021-04-14 23:37:51 -04:00
listing_type : Option < ListingType > ,
sort : Option < SortType > ,
2021-03-18 16:25:21 -04:00
creator_id : Option < PersonId > ,
community_id : Option < CommunityId > ,
2020-12-16 13:59:43 -05:00
community_name : Option < String > ,
2021-03-18 16:25:21 -04:00
my_person_id : Option < PersonId > ,
2020-12-10 15:53:49 -05:00
search_term : Option < String > ,
url_search : Option < String > ,
2021-04-14 23:37:51 -04:00
show_nsfw : Option < bool > ,
show_bot_accounts : Option < bool > ,
saved_only : Option < bool > ,
unread_only : Option < bool > ,
2020-12-10 15:53:49 -05:00
page : Option < i64 > ,
limit : Option < i64 > ,
}
impl < ' a > PostQueryBuilder < ' a > {
2020-12-16 13:59:43 -05:00
pub fn create ( conn : & ' a PgConnection ) -> Self {
2020-12-10 15:53:49 -05:00
PostQueryBuilder {
conn ,
2021-04-14 23:37:51 -04:00
listing_type : None ,
sort : None ,
2020-12-16 13:59:43 -05:00
creator_id : None ,
community_id : None ,
community_name : None ,
2021-03-10 17:33:55 -05:00
my_person_id : None ,
2020-12-10 15:53:49 -05:00
search_term : None ,
url_search : None ,
2021-04-14 23:37:51 -04:00
show_nsfw : None ,
show_bot_accounts : None ,
saved_only : None ,
unread_only : None ,
2020-12-10 15:53:49 -05:00
page : None ,
limit : None ,
}
}
2021-04-14 23:37:51 -04:00
pub fn listing_type < T : MaybeOptional < ListingType > > ( mut self , listing_type : T ) -> Self {
self . listing_type = listing_type . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
2021-04-14 23:37:51 -04:00
pub fn sort < T : MaybeOptional < SortType > > ( mut self , sort : T ) -> Self {
self . sort = sort . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
2021-03-18 16:25:21 -04:00
pub fn community_id < T : MaybeOptional < CommunityId > > ( mut self , community_id : T ) -> Self {
2020-12-16 13:59:43 -05:00
self . community_id = community_id . get_optional ( ) ;
self
}
2021-03-18 16:25:21 -04:00
pub fn my_person_id < T : MaybeOptional < PersonId > > ( mut self , my_person_id : T ) -> Self {
2021-03-10 17:33:55 -05:00
self . my_person_id = my_person_id . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
2020-12-16 13:59:43 -05:00
pub fn community_name < T : MaybeOptional < String > > ( mut self , community_name : T ) -> Self {
self . community_name = community_name . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
2021-03-18 16:25:21 -04:00
pub fn creator_id < T : MaybeOptional < PersonId > > ( mut self , creator_id : T ) -> Self {
2020-12-16 13:59:43 -05:00
self . creator_id = creator_id . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
pub fn search_term < T : MaybeOptional < String > > ( mut self , search_term : T ) -> Self {
self . search_term = search_term . get_optional ( ) ;
self
}
pub fn url_search < T : MaybeOptional < String > > ( mut self , url_search : T ) -> Self {
self . url_search = url_search . get_optional ( ) ;
self
}
2021-04-14 23:37:51 -04:00
pub fn show_nsfw < T : MaybeOptional < bool > > ( mut self , show_nsfw : T ) -> Self {
self . show_nsfw = show_nsfw . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
2021-04-14 23:37:51 -04:00
pub fn show_bot_accounts < T : MaybeOptional < bool > > ( mut self , show_bot_accounts : T ) -> Self {
2021-04-23 02:40:10 -04:00
self . show_bot_accounts = show_bot_accounts . get_optional ( ) ;
2021-04-21 21:41:14 +00:00
self
}
2021-04-14 23:37:51 -04:00
pub fn saved_only < T : MaybeOptional < bool > > ( mut self , saved_only : T ) -> Self {
self . saved_only = saved_only . get_optional ( ) ;
2020-12-10 15:53:49 -05:00
self
}
pub fn page < T : MaybeOptional < i64 > > ( mut self , page : T ) -> Self {
self . page = page . get_optional ( ) ;
self
}
pub fn limit < T : MaybeOptional < i64 > > ( mut self , limit : T ) -> Self {
self . limit = limit . get_optional ( ) ;
self
}
pub fn list ( self ) -> Result < Vec < PostView > , Error > {
use diesel ::dsl ::* ;
2020-12-16 13:59:43 -05:00
// The left join below will return None in this case
2021-03-18 16:25:21 -04:00
let person_id_join = self . my_person_id . unwrap_or ( PersonId ( - 1 ) ) ;
2020-12-16 13:59:43 -05:00
let mut query = post ::table
2021-03-10 17:33:55 -05:00
. inner_join ( person ::table )
2020-12-16 13:59:43 -05:00
. inner_join ( community ::table )
. left_join (
2021-03-10 17:33:55 -05:00
community_person_ban ::table . on (
2020-12-16 13:59:43 -05:00
post ::community_id
2021-03-10 17:33:55 -05:00
. eq ( community_person_ban ::community_id )
2021-04-08 07:29:08 -04:00
. and ( community_person_ban ::person_id . eq ( post ::creator_id ) ) ,
2020-12-16 13:59:43 -05:00
) ,
)
. inner_join ( post_aggregates ::table )
. left_join (
community_follower ::table . on (
post ::community_id
. eq ( community_follower ::community_id )
2021-03-10 17:33:55 -05:00
. and ( community_follower ::person_id . eq ( person_id_join ) ) ,
2020-12-16 13:59:43 -05:00
) ,
)
. left_join (
post_saved ::table . on (
post ::id
. eq ( post_saved ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_saved ::person_id . eq ( person_id_join ) ) ,
2020-12-16 13:59:43 -05:00
) ,
)
. left_join (
post_read ::table . on (
post ::id
. eq ( post_read ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_read ::person_id . eq ( person_id_join ) ) ,
2020-12-16 13:59:43 -05:00
) ,
)
. left_join (
post_like ::table . on (
post ::id
. eq ( post_like ::post_id )
2021-03-10 17:33:55 -05:00
. and ( post_like ::person_id . eq ( person_id_join ) ) ,
2020-12-16 13:59:43 -05:00
) ,
)
. select ( (
post ::all_columns ,
2021-03-10 17:33:55 -05:00
Person ::safe_columns_tuple ( ) ,
2020-12-16 13:59:43 -05:00
Community ::safe_columns_tuple ( ) ,
2021-03-10 17:33:55 -05:00
community_person_ban ::all_columns . nullable ( ) ,
2020-12-16 13:59:43 -05:00
post_aggregates ::all_columns ,
community_follower ::all_columns . nullable ( ) ,
post_saved ::all_columns . nullable ( ) ,
post_read ::all_columns . nullable ( ) ,
post_like ::score . nullable ( ) ,
) )
. into_boxed ( ) ;
2020-12-10 15:53:49 -05:00
2021-04-14 23:37:51 -04:00
if let Some ( listing_type ) = self . listing_type {
query = match listing_type {
ListingType ::Subscribed = > query . filter ( community_follower ::person_id . is_not_null ( ) ) , // TODO could be this: and(community_follower::person_id.eq(person_id_join)),
ListingType ::Local = > query . filter ( community ::local . eq ( true ) ) ,
_ = > query ,
} ;
}
2020-12-10 15:53:49 -05:00
2020-12-16 13:59:43 -05:00
if let Some ( community_id ) = self . community_id {
2020-12-10 15:53:49 -05:00
query = query
2020-12-16 13:59:43 -05:00
. filter ( post ::community_id . eq ( community_id ) )
2021-01-07 16:22:17 -05:00
. then_order_by ( post_aggregates ::stickied . desc ( ) ) ;
2020-12-10 15:53:49 -05:00
}
2020-12-16 13:59:43 -05:00
if let Some ( community_name ) = self . community_name {
2020-12-10 15:53:49 -05:00
query = query
2020-12-16 13:59:43 -05:00
. filter ( community ::name . eq ( community_name ) )
2020-12-10 15:53:49 -05:00
. filter ( community ::local . eq ( true ) )
2021-01-07 16:22:17 -05:00
. then_order_by ( post_aggregates ::stickied . desc ( ) ) ;
2020-12-10 15:53:49 -05:00
}
if let Some ( url_search ) = self . url_search {
query = query . filter ( post ::url . eq ( url_search ) ) ;
}
if let Some ( search_term ) = self . search_term {
let searcher = fuzzy_search ( & search_term ) ;
query = query . filter (
post ::name
. ilike ( searcher . to_owned ( ) )
. or ( post ::body . ilike ( searcher ) ) ,
) ;
}
2021-03-10 17:33:55 -05:00
// If its for a specific person, show the removed / deleted
2020-12-16 13:59:43 -05:00
if let Some ( creator_id ) = self . creator_id {
query = query . filter ( post ::creator_id . eq ( creator_id ) ) ;
}
2021-04-14 23:37:51 -04:00
if ! self . show_nsfw . unwrap_or ( true ) {
2020-12-16 13:59:43 -05:00
query = query
. filter ( post ::nsfw . eq ( false ) )
. filter ( community ::nsfw . eq ( false ) ) ;
} ;
2021-04-23 02:40:10 -04:00
if ! self . show_bot_accounts . unwrap_or ( true ) {
2021-04-21 21:41:14 +00:00
query = query . filter ( person ::bot_account . eq ( false ) ) ;
} ;
2020-12-16 13:59:43 -05:00
// TODO These two might be wrong
2021-04-14 23:37:51 -04:00
if self . saved_only . unwrap_or_default ( ) {
2020-12-16 13:59:43 -05:00
query = query . filter ( post_saved ::id . is_not_null ( ) ) ;
} ;
2021-04-14 23:37:51 -04:00
if self . unread_only . unwrap_or_default ( ) {
2020-12-16 13:59:43 -05:00
query = query . filter ( post_read ::id . is_not_null ( ) ) ;
} ;
2021-04-14 23:37:51 -04:00
query = match self . sort . unwrap_or ( SortType ::Hot ) {
2020-12-10 15:53:49 -05:00
SortType ::Active = > query
. then_order_by (
2021-02-18 10:38:25 -05:00
hot_rank (
post_aggregates ::score ,
post_aggregates ::newest_comment_time_necro ,
)
. desc ( ) ,
2020-12-10 15:53:49 -05:00
)
2021-02-18 10:38:25 -05:00
. then_order_by ( post_aggregates ::newest_comment_time_necro . desc ( ) ) ,
2020-12-10 15:53:49 -05:00
SortType ::Hot = > query
2021-01-05 23:42:48 -05:00
. then_order_by ( hot_rank ( post_aggregates ::score , post_aggregates ::published ) . desc ( ) )
. then_order_by ( post_aggregates ::published . desc ( ) ) ,
2021-01-07 16:22:17 -05:00
SortType ::New = > query . then_order_by ( post_aggregates ::published . desc ( ) ) ,
2021-02-01 11:53:44 -05:00
SortType ::MostComments = > query . then_order_by ( post_aggregates ::comments . desc ( ) ) ,
2021-02-18 10:38:25 -05:00
SortType ::NewComments = > query . then_order_by ( post_aggregates ::newest_comment_time . desc ( ) ) ,
2020-12-10 15:53:49 -05:00
SortType ::TopAll = > query . then_order_by ( post_aggregates ::score . desc ( ) ) ,
SortType ::TopYear = > query
. filter ( post ::published . gt ( now - 1. years ( ) ) )
. then_order_by ( post_aggregates ::score . desc ( ) ) ,
SortType ::TopMonth = > query
. filter ( post ::published . gt ( now - 1. months ( ) ) )
. then_order_by ( post_aggregates ::score . desc ( ) ) ,
SortType ::TopWeek = > query
. filter ( post ::published . gt ( now - 1. weeks ( ) ) )
. then_order_by ( post_aggregates ::score . desc ( ) ) ,
SortType ::TopDay = > query
. filter ( post ::published . gt ( now - 1. days ( ) ) )
. then_order_by ( post_aggregates ::score . desc ( ) ) ,
} ;
let ( limit , offset ) = limit_and_offset ( self . page , self . limit ) ;
2021-01-06 13:23:05 -05:00
query = query
2020-12-10 15:53:49 -05:00
. limit ( limit )
. offset ( offset )
. filter ( post ::removed . eq ( false ) )
. filter ( post ::deleted . eq ( false ) )
. filter ( community ::removed . eq ( false ) )
2021-01-06 13:23:05 -05:00
. filter ( community ::deleted . eq ( false ) ) ;
debug! ( " Post View Query: {:?} " , debug_query ::< Pg , _ > ( & query ) ) ;
let res = query . load ::< PostViewTuple > ( self . conn ) ? ;
2020-12-10 15:53:49 -05:00
2020-12-23 16:56:20 -05:00
Ok ( PostView ::from_tuple_to_vec ( res ) )
2020-12-10 15:53:49 -05:00
}
}
2020-12-10 20:39:42 -05:00
impl ViewToVec for PostView {
type DbTuple = PostViewTuple ;
2020-12-23 16:56:20 -05:00
fn from_tuple_to_vec ( items : Vec < Self ::DbTuple > ) -> Vec < Self > {
items
2020-12-10 20:39:42 -05:00
. iter ( )
. map ( | a | Self {
post : a . 0. to_owned ( ) ,
creator : a . 1. to_owned ( ) ,
community : a . 2. to_owned ( ) ,
2020-12-11 10:27:33 -05:00
creator_banned_from_community : a . 3. is_some ( ) ,
counts : a . 4. to_owned ( ) ,
subscribed : a . 5. is_some ( ) ,
2020-12-10 20:39:42 -05:00
saved : a . 6. is_some ( ) ,
read : a . 7. is_some ( ) ,
my_vote : a . 8 ,
} )
. collect ::< Vec < Self > > ( )
}
2020-12-10 15:53:49 -05:00
}
2020-12-11 10:27:33 -05:00
#[ cfg(test) ]
mod tests {
2020-12-21 17:30:34 +01:00
use crate ::post_view ::{ PostQueryBuilder , PostView } ;
2020-12-22 00:27:42 +01:00
use lemmy_db_queries ::{
2020-12-11 10:27:33 -05:00
aggregates ::post_aggregates ::PostAggregates ,
2020-12-22 00:27:42 +01:00
establish_unpooled_connection ,
2020-12-11 10:27:33 -05:00
Crud ,
Likeable ,
2020-12-22 00:27:42 +01:00
ListingType ,
SortType ,
2020-12-11 10:27:33 -05:00
} ;
2021-03-10 23:43:11 -05:00
use lemmy_db_schema ::source ::{ community ::* , person ::* , post ::* } ;
2021-02-25 14:43:39 -05:00
use serial_test ::serial ;
2020-12-11 10:27:33 -05:00
#[ test ]
2021-02-25 14:43:39 -05:00
#[ serial ]
2020-12-11 10:27:33 -05:00
fn test_crud ( ) {
let conn = establish_unpooled_connection ( ) ;
2021-03-10 17:33:55 -05:00
let person_name = " tegan " . to_string ( ) ;
2020-12-11 10:27:33 -05:00
let community_name = " test_community_3 " . to_string ( ) ;
let post_name = " test post 3 " . to_string ( ) ;
2021-04-21 21:41:14 +00:00
let bot_post_name = " test bot post " . to_string ( ) ;
2020-12-11 10:27:33 -05:00
2021-03-10 17:33:55 -05:00
let new_person = PersonForm {
name : person_name . to_owned ( ) ,
2021-03-20 16:59:07 -04:00
.. PersonForm ::default ( )
2020-12-11 10:27:33 -05:00
} ;
2021-03-10 17:33:55 -05:00
let inserted_person = Person ::create ( & conn , & new_person ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
2021-04-21 21:41:14 +00:00
let new_bot = PersonForm {
name : person_name . to_owned ( ) ,
bot_account : Some ( true ) ,
.. PersonForm ::default ( )
} ;
let inserted_bot = Person ::create ( & conn , & new_bot ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
let new_community = CommunityForm {
name : community_name . to_owned ( ) ,
title : " nada " . to_owned ( ) ,
2021-03-20 16:59:07 -04:00
.. CommunityForm ::default ( )
2020-12-11 10:27:33 -05:00
} ;
let inserted_community = Community ::create ( & conn , & new_community ) . unwrap ( ) ;
let new_post = PostForm {
name : post_name . to_owned ( ) ,
2021-03-10 17:33:55 -05:00
creator_id : inserted_person . id ,
2020-12-11 10:27:33 -05:00
community_id : inserted_community . id ,
2021-03-20 16:59:07 -04:00
.. PostForm ::default ( )
2020-12-11 10:27:33 -05:00
} ;
let inserted_post = Post ::create ( & conn , & new_post ) . unwrap ( ) ;
2021-04-21 21:41:14 +00:00
let new_bot_post = PostForm {
name : bot_post_name ,
creator_id : inserted_bot . id ,
community_id : inserted_community . id ,
.. PostForm ::default ( )
} ;
let _inserted_bot_post = Post ::create ( & conn , & new_bot_post ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
let post_like_form = PostLikeForm {
post_id : inserted_post . id ,
2021-03-10 17:33:55 -05:00
person_id : inserted_person . id ,
2020-12-11 10:27:33 -05:00
score : 1 ,
} ;
let inserted_post_like = PostLike ::like ( & conn , & post_like_form ) . unwrap ( ) ;
let expected_post_like = PostLike {
id : inserted_post_like . id ,
post_id : inserted_post . id ,
2021-03-10 17:33:55 -05:00
person_id : inserted_person . id ,
2020-12-11 10:27:33 -05:00
published : inserted_post_like . published ,
score : 1 ,
} ;
2021-03-10 17:33:55 -05:00
let read_post_listings_with_person = PostQueryBuilder ::create ( & conn )
2021-04-14 23:37:51 -04:00
. listing_type ( ListingType ::Community )
. sort ( SortType ::New )
2021-04-21 21:41:14 +00:00
. show_bot_accounts ( false )
2020-12-16 13:59:43 -05:00
. community_id ( inserted_community . id )
2021-03-10 17:33:55 -05:00
. my_person_id ( inserted_person . id )
2020-12-11 10:27:33 -05:00
. list ( )
. unwrap ( ) ;
2021-03-10 17:33:55 -05:00
let read_post_listings_no_person = PostQueryBuilder ::create ( & conn )
2021-04-14 23:37:51 -04:00
. listing_type ( ListingType ::Community )
. sort ( SortType ::New )
2020-12-16 13:59:43 -05:00
. community_id ( inserted_community . id )
2020-12-11 10:27:33 -05:00
. list ( )
. unwrap ( ) ;
2021-03-10 17:33:55 -05:00
let read_post_listing_no_person = PostView ::read ( & conn , inserted_post . id , None ) . unwrap ( ) ;
let read_post_listing_with_person =
PostView ::read ( & conn , inserted_post . id , Some ( inserted_person . id ) ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
2020-12-18 12:25:27 -05:00
let agg = PostAggregates ::read ( & conn , inserted_post . id ) . unwrap ( ) ;
2021-03-10 17:33:55 -05:00
// the non person version
let expected_post_listing_no_person = PostView {
2020-12-11 10:27:33 -05:00
post : Post {
id : inserted_post . id ,
2020-12-22 13:03:50 +01:00
name : post_name ,
2021-03-10 17:33:55 -05:00
creator_id : inserted_person . id ,
2020-12-11 10:27:33 -05:00
url : None ,
body : None ,
published : inserted_post . published ,
updated : None ,
community_id : inserted_community . id ,
removed : false ,
deleted : false ,
locked : false ,
stickied : false ,
nsfw : false ,
embed_title : None ,
embed_description : None ,
embed_html : None ,
thumbnail_url : None ,
ap_id : inserted_post . ap_id . to_owned ( ) ,
local : true ,
} ,
my_vote : None ,
2021-03-10 17:33:55 -05:00
creator : PersonSafe {
id : inserted_person . id ,
name : person_name ,
2021-04-01 13:57:45 -04:00
display_name : None ,
2021-03-10 17:33:55 -05:00
published : inserted_person . published ,
2020-12-11 10:27:33 -05:00
avatar : None ,
2021-03-10 17:33:55 -05:00
actor_id : inserted_person . actor_id . to_owned ( ) ,
2020-12-11 10:27:33 -05:00
local : true ,
2021-03-22 10:28:00 -04:00
admin : false ,
2021-04-21 21:41:14 +00:00
bot_account : false ,
2020-12-11 10:27:33 -05:00
banned : false ,
deleted : false ,
bio : None ,
banner : None ,
updated : None ,
2021-03-10 17:33:55 -05:00
inbox_url : inserted_person . inbox_url . to_owned ( ) ,
2021-02-04 16:34:58 +00:00
shared_inbox_url : None ,
2021-03-20 15:21:51 -04:00
matrix_user_id : None ,
2020-12-11 10:27:33 -05:00
} ,
creator_banned_from_community : false ,
community : CommunitySafe {
id : inserted_community . id ,
2020-12-22 13:03:50 +01:00
name : community_name ,
2020-12-11 10:27:33 -05:00
icon : None ,
removed : false ,
deleted : false ,
nsfw : false ,
actor_id : inserted_community . actor_id . to_owned ( ) ,
local : true ,
title : " nada " . to_owned ( ) ,
description : None ,
updated : None ,
banner : None ,
published : inserted_community . published ,
} ,
counts : PostAggregates {
2020-12-18 12:25:27 -05:00
id : agg . id ,
2020-12-11 10:27:33 -05:00
post_id : inserted_post . id ,
comments : 0 ,
score : 1 ,
upvotes : 1 ,
downvotes : 0 ,
2021-01-07 16:22:17 -05:00
stickied : false ,
2021-01-05 23:42:48 -05:00
published : agg . published ,
2021-02-18 10:38:25 -05:00
newest_comment_time_necro : inserted_post . published ,
2020-12-11 10:27:33 -05:00
newest_comment_time : inserted_post . published ,
} ,
subscribed : false ,
read : false ,
saved : false ,
} ;
// TODO More needs to be added here
2021-03-10 17:33:55 -05:00
let mut expected_post_listing_with_user = expected_post_listing_no_person . to_owned ( ) ;
2020-12-11 10:27:33 -05:00
expected_post_listing_with_user . my_vote = Some ( 1 ) ;
2021-03-10 17:33:55 -05:00
let like_removed = PostLike ::remove ( & conn , inserted_person . id , inserted_post . id ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
let num_deleted = Post ::delete ( & conn , inserted_post . id ) . unwrap ( ) ;
Community ::delete ( & conn , inserted_community . id ) . unwrap ( ) ;
2021-03-10 17:33:55 -05:00
Person ::delete ( & conn , inserted_person . id ) . unwrap ( ) ;
2021-04-21 21:41:14 +00:00
Person ::delete ( & conn , inserted_bot . id ) . unwrap ( ) ;
2020-12-11 10:27:33 -05:00
// The with user
assert_eq! (
expected_post_listing_with_user ,
2021-03-10 17:33:55 -05:00
read_post_listings_with_person [ 0 ]
2020-12-11 10:27:33 -05:00
) ;
2021-03-10 23:43:11 -05:00
assert_eq! (
expected_post_listing_with_user ,
read_post_listing_with_person
) ;
2021-04-21 21:41:14 +00:00
// Should be only one person, IE the bot post should be missing
2021-03-10 17:33:55 -05:00
assert_eq! ( 1 , read_post_listings_with_person . len ( ) ) ;
2020-12-11 10:27:33 -05:00
// Without the user
2021-03-10 23:43:11 -05:00
assert_eq! (
expected_post_listing_no_person ,
2021-04-21 21:41:14 +00:00
read_post_listings_no_person [ 1 ]
2021-03-10 23:43:11 -05:00
) ;
2021-03-10 17:33:55 -05:00
assert_eq! ( expected_post_listing_no_person , read_post_listing_no_person ) ;
2020-12-11 10:27:33 -05:00
2021-04-21 21:41:14 +00:00
// Should be 2 posts, with the bot post
assert_eq! ( 2 , read_post_listings_no_person . len ( ) ) ;
2020-12-11 10:27:33 -05:00
assert_eq! ( expected_post_like , inserted_post_like ) ;
assert_eq! ( 1 , like_removed ) ;
assert_eq! ( 1 , num_deleted ) ;
}
}