mirror of
https://github.com/LemmyNet/lemmy.git
synced 2024-11-14 00:14:03 +00:00
parent
148f33def5
commit
3fa713f414
1 changed files with 7 additions and 44 deletions
|
@ -74,7 +74,6 @@ impl PostView {
|
||||||
|
|
||||||
// The left join below will return None in this case
|
// The left join below will return None in this case
|
||||||
let person_id_join = my_person_id.unwrap_or(PersonId(-1));
|
let person_id_join = my_person_id.unwrap_or(PersonId(-1));
|
||||||
let person_alias_1 = diesel::alias!(person as person1);
|
|
||||||
let mut query = post::table
|
let mut query = post::table
|
||||||
.find(post_id)
|
.find(post_id)
|
||||||
.inner_join(person::table)
|
.inner_join(person::table)
|
||||||
|
@ -134,14 +133,6 @@ impl PostView {
|
||||||
.and(person_post_aggregates::person_id.eq(person_id_join)),
|
.and(person_post_aggregates::person_id.eq(person_id_join)),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
// Used to check if you are the post creator
|
|
||||||
.left_join(
|
|
||||||
person_alias_1.on(
|
|
||||||
post::creator_id
|
|
||||||
.eq(person_alias_1.field(person::id))
|
|
||||||
.and(person_alias_1.field(person::id).eq(person_id_join)),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.select((
|
.select((
|
||||||
post::all_columns,
|
post::all_columns,
|
||||||
person::all_columns,
|
person::all_columns,
|
||||||
|
@ -160,21 +151,11 @@ impl PostView {
|
||||||
))
|
))
|
||||||
.into_boxed();
|
.into_boxed();
|
||||||
|
|
||||||
// If you are not a moderator, exclude deleted or removed content
|
// Hide deleted and removed for non-admins or mods
|
||||||
if !is_mod_or_admin.unwrap_or(true) {
|
if !is_mod_or_admin.unwrap_or(true) {
|
||||||
// If you are not the creator, then remove the other fields.
|
|
||||||
query = query
|
query = query
|
||||||
.filter(
|
.filter(community::removed.eq(false))
|
||||||
person_alias_1.field(person::id).is_null().and(
|
.filter(community::deleted.eq(false));
|
||||||
post::removed
|
|
||||||
.eq(false)
|
|
||||||
.and(post::deleted.eq(false))
|
|
||||||
.and(community::removed.eq(false))
|
|
||||||
.and(community::deleted.eq(false)),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
// If you are the creator, keep them
|
|
||||||
.or_filter(person_alias_1.field(person::id).is_not_null())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let (
|
let (
|
||||||
|
@ -241,7 +222,6 @@ impl<'a> PostQuery<'a> {
|
||||||
// The left join below will return None in this case
|
// The left join below will return None in this case
|
||||||
let person_id_join = self.local_user.map(|l| l.person_id).unwrap_or(PersonId(-1));
|
let person_id_join = self.local_user.map(|l| l.person_id).unwrap_or(PersonId(-1));
|
||||||
let local_user_id_join = self.local_user.map(|l| l.id).unwrap_or(LocalUserId(-1));
|
let local_user_id_join = self.local_user.map(|l| l.id).unwrap_or(LocalUserId(-1));
|
||||||
let person_alias_1 = diesel::alias!(person as person1);
|
|
||||||
|
|
||||||
let mut query = post::table
|
let mut query = post::table
|
||||||
.inner_join(person::table)
|
.inner_join(person::table)
|
||||||
|
@ -315,14 +295,6 @@ impl<'a> PostQuery<'a> {
|
||||||
.and(local_user_language::local_user_id.eq(local_user_id_join)),
|
.and(local_user_language::local_user_id.eq(local_user_id_join)),
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
// Used to check if you are the post creator
|
|
||||||
.left_join(
|
|
||||||
person_alias_1.on(
|
|
||||||
post::creator_id
|
|
||||||
.eq(person_alias_1.field(person::id))
|
|
||||||
.and(person_alias_1.field(person::id).eq(person_id_join)),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.select((
|
.select((
|
||||||
post::all_columns,
|
post::all_columns,
|
||||||
person::all_columns,
|
person::all_columns,
|
||||||
|
@ -341,21 +313,12 @@ impl<'a> PostQuery<'a> {
|
||||||
))
|
))
|
||||||
.into_boxed();
|
.into_boxed();
|
||||||
|
|
||||||
// If you are not a moderator, exclude deleted or removed content
|
// Hide deleted and removed for non-admins or mods
|
||||||
|
// TODO This eventually needs to show posts where you are the creator
|
||||||
if !self.is_mod_or_admin.unwrap_or(true) {
|
if !self.is_mod_or_admin.unwrap_or(true) {
|
||||||
// If you are not the creator, then remove the other fields.
|
|
||||||
query = query
|
query = query
|
||||||
.filter(
|
.filter(community::removed.eq(false))
|
||||||
person_alias_1.field(person::id).is_null().and(
|
.filter(community::deleted.eq(false));
|
||||||
post::removed
|
|
||||||
.eq(false)
|
|
||||||
.and(post::deleted.eq(false))
|
|
||||||
.and(community::removed.eq(false))
|
|
||||||
.and(community::deleted.eq(false)),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
// If you are the creator, keep them
|
|
||||||
.or_filter(person_alias_1.field(person::id).is_not_null())
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(listing_type) = self.listing_type {
|
if let Some(listing_type) = self.listing_type {
|
||||||
|
|
Loading…
Reference in a new issue