Try stuff

pull/3663/head
dull b 2023-07-17 19:25:37 +00:00
parent 38c6210912
commit 3da5f83a8b
1 changed files with 93 additions and 89 deletions

View File

@ -1,12 +1,20 @@
use crate::structs::CommentReportView; use crate::structs::CommentReportView;
use diesel::{ use diesel::{
dsl,
dsl::now, dsl::now,
helper_types::AliasedFields,
query_builder::{AsQuery, Query},
query_dsl::methods,
result::Error, result::Error,
sql_types,
BoolExpressionMethods, BoolExpressionMethods,
Expression,
ExpressionMethods, ExpressionMethods,
JoinOnDsl, JoinOnDsl,
JoinTo,
NullableExpressionMethods, NullableExpressionMethods,
QueryDsl, QueryDsl,
Table,
}; };
use diesel_async::RunQueryDsl; use diesel_async::RunQueryDsl;
use lemmy_db_schema::{ use lemmy_db_schema::{
@ -34,22 +42,43 @@ use lemmy_db_schema::{
utils::{get_conn, limit_and_offset, DbPool}, utils::{get_conn, limit_and_offset, DbPool},
}; };
impl CommentReportView { diesel::alias!(person as person_alias_1: PersonAlias1, person as person_alias_2:PersonAlias2);
/// returns the CommentReportView for the provided report_id
/// type Ac<T> = <T as Table>::AllColumns;
/// * `report_id` - the report id to obtain
pub async fn read( fn full_query<'query, Conn, Q, C, R>(
pool: &mut DbPool<'_>, query: comment_report::table,
report_id: CommentReportId,
my_person_id: PersonId, my_person_id: PersonId,
) -> Result<Self, Error> { community_person_ban_condition: C,
let conn = &mut get_conn(pool).await?; ) -> dsl::Select<
impl Query + Table,
let (person_alias_1, person_alias_2) = diesel::alias!(person as person1, person as person2); (
Ac<comment_report::table>,
let res = comment_report::table Ac<comment::table>,
.find(report_id) Ac<post::table>,
.inner_join(comment::table) Ac<community::table>,
Ac<person::table>,
AliasedFields<person::table, Ac<person::table>>,
Ac<comment_aggregates::table>,
dsl::NullableSelect<Ac<community_person_ban::table>>,
dsl::NullableSelect<comment_like::score>,
dsl::NullableSelect<AliasedFields<person::table, Ac<person::table>>>,
),
>
where
/*Q: AsQuery,
<Q as AsQuery>::Query: Table, /*<
SqlType = <comment_report::table as AsQuery>::SqlType,
AllColumns = <comment_report::table as Table>::AllColumns,
>*/*/
C: Expression<SqlType = sql_types::Nullable<sql_types::Bool>> + Clone,
R: methods::LimitDsl,
dsl::Limit<R>: methods::LoadQuery<'query, Conn, <CommentReportView as JoinView>::JoinTuple>,
{
QueryDsl::inner_join(
query,
comment::table.on(comment_report::comment_id.eq(comment::id)),
)
.inner_join(post::table.on(comment::post_id.eq(post::id))) .inner_join(post::table.on(comment::post_id.eq(post::id)))
.inner_join(community::table.on(post::community_id.eq(community::id))) .inner_join(community::table.on(post::community_id.eq(community::id)))
.inner_join(person::table.on(comment_report::creator_id.eq(person::id))) .inner_join(person::table.on(comment_report::creator_id.eq(person::id)))
@ -61,7 +90,8 @@ impl CommentReportView {
community_person_ban::table.on( community_person_ban::table.on(
community::id community::id
.eq(community_person_ban::community_id) .eq(community_person_ban::community_id)
.and(community_person_ban::person_id.eq(comment::creator_id)), .and(community_person_ban::person_id.eq(comment::creator_id))
.and(community_person_ban_condition),
), ),
) )
.left_join( .left_join(
@ -72,8 +102,7 @@ impl CommentReportView {
), ),
) )
.left_join( .left_join(
person_alias_2 person_alias_2.on(comment_report::resolver_id.eq(person_alias_2.field(person::id).nullable())),
.on(comment_report::resolver_id.eq(person_alias_2.field(person::id).nullable())),
) )
.select(( .select((
comment_report::all_columns, comment_report::all_columns,
@ -87,6 +116,20 @@ impl CommentReportView {
comment_like::score.nullable(), comment_like::score.nullable(),
person_alias_2.fields(person::all_columns).nullable(), person_alias_2.fields(person::all_columns).nullable(),
)) ))
}
impl CommentReportView {
/// returns the CommentReportView for the provided report_id
///
/// * `report_id` - the report id to obtain
pub async fn read(
pool: &mut DbPool<'_>,
report_id: CommentReportId,
my_person_id: PersonId,
) -> Result<Self, Error> {
let conn = &mut get_conn(pool).await?;
let res = full_query(comment_report::table.find(report_id), my_person_id, true)
.first::<<CommentReportView as JoinView>::JoinTuple>(conn) .first::<<CommentReportView as JoinView>::JoinTuple>(conn)
.await?; .await?;
@ -152,52 +195,13 @@ impl CommentReportQuery {
) -> Result<Vec<CommentReportView>, Error> { ) -> Result<Vec<CommentReportView>, Error> {
let conn = &mut get_conn(pool).await?; let conn = &mut get_conn(pool).await?;
let (person_alias_1, person_alias_2) = diesel::alias!(person as person1, person as person2); let mut query = full_query(
comment_report::table,
let mut query = comment_report::table my_person.id,
.inner_join(comment::table)
.inner_join(post::table.on(comment::post_id.eq(post::id)))
.inner_join(community::table.on(post::community_id.eq(community::id)))
.inner_join(person::table.on(comment_report::creator_id.eq(person::id)))
.inner_join(person_alias_1.on(comment::creator_id.eq(person_alias_1.field(person::id))))
.inner_join(
comment_aggregates::table.on(comment_report::comment_id.eq(comment_aggregates::comment_id)),
)
.left_join(
community_person_ban::table.on(
community::id
.eq(community_person_ban::community_id)
.and(community_person_ban::person_id.eq(comment::creator_id))
.and(
community_person_ban::expires community_person_ban::expires
.is_null() .is_null()
.or(community_person_ban::expires.gt(now)), .or(community_person_ban::expires.gt(now)),
),
),
) )
.left_join(
comment_like::table.on(
comment::id
.eq(comment_like::comment_id)
.and(comment_like::person_id.eq(my_person.id)),
),
)
.left_join(
person_alias_2
.on(comment_report::resolver_id.eq(person_alias_2.field(person::id).nullable())),
)
.select((
comment_report::all_columns,
comment::all_columns,
post::all_columns,
community::all_columns,
person::all_columns,
person_alias_1.fields(person::all_columns),
comment_aggregates::all_columns,
community_person_ban::all_columns.nullable(),
comment_like::score.nullable(),
person_alias_2.fields(person::all_columns).nullable(),
))
.into_boxed(); .into_boxed();
if let Some(community_id) = self.community_id { if let Some(community_id) = self.community_id {