-use crate::structs::{LocalUserSettingsView, LocalUserView};
+use crate::structs::LocalUserView;
use diesel::{result::Error, BoolExpressionMethods, ExpressionMethods, JoinOnDsl, QueryDsl};
use diesel_async::RunQueryDsl;
use lemmy_db_schema::{
aggregates::structs::PersonAggregates,
newtypes::{LocalUserId, PersonId},
schema::{local_user, person, person_aggregates},
- source::{
- local_user::{LocalUser, LocalUserSettings},
- person::{Person, PersonSafe},
- },
- traits::{ToSafe, ToSafeSettings, ViewToVec},
+ source::{local_user::LocalUser, person::Person},
+ traits::JoinView,
utils::{functions::lower, get_conn, DbPool},
};
counts,
})
}
-}
-
-type LocalUserSettingsViewTuple = (LocalUserSettings, PersonSafe, PersonAggregates);
-
-impl LocalUserSettingsView {
- pub async fn read(pool: &DbPool, local_user_id: LocalUserId) -> Result<Self, Error> {
- let conn = &mut get_conn(pool).await?;
- let (local_user, person, counts) = local_user::table
- .find(local_user_id)
- .inner_join(person::table)
- .inner_join(person_aggregates::table.on(person::id.eq(person_aggregates::person_id)))
- .select((
- LocalUser::safe_settings_columns_tuple(),
- Person::safe_columns_tuple(),
- person_aggregates::all_columns,
- ))
- .first::<LocalUserSettingsViewTuple>(conn)
- .await?;
- Ok(Self {
- local_user,
- person,
- counts,
- })
- }
pub async fn list_admins_with_emails(pool: &DbPool) -> Result<Vec<Self>, Error> {
let conn = &mut get_conn(pool).await?;
.inner_join(person::table)
.inner_join(person_aggregates::table.on(person::id.eq(person_aggregates::person_id)))
.select((
- LocalUser::safe_settings_columns_tuple(),
- Person::safe_columns_tuple(),
+ local_user::all_columns,
+ person::all_columns,
person_aggregates::all_columns,
))
- .load::<LocalUserSettingsViewTuple>(conn)
+ .load::<LocalUserViewTuple>(conn)
.await?;
- Ok(LocalUserSettingsView::from_tuple_to_vec(res))
+ Ok(res.into_iter().map(LocalUserView::from_tuple).collect())
}
}
-impl ViewToVec for LocalUserSettingsView {
- type DbTuple = LocalUserSettingsViewTuple;
- fn from_tuple_to_vec(items: Vec<Self::DbTuple>) -> Vec<Self> {
- items
- .into_iter()
- .map(|a| Self {
- local_user: a.0,
- person: a.1,
- counts: a.2,
- })
- .collect::<Vec<Self>>()
+impl JoinView for LocalUserView {
+ type JoinTuple = LocalUserViewTuple;
+ fn from_tuple(a: Self::JoinTuple) -> Self {
+ Self {
+ local_user: a.0,
+ person: a.1,
+ counts: a.2,
+ }
}
}