1 use diesel::{result::Error, *};
2 use lemmy_db_queries::{
3 aggregates::person_aggregates::PersonAggregates,
8 schema::{person, person_aggregates, local_user},
9 source::person::{PersonSafe, Person},
10 source::local_user::{LocalUser, LocalUserSettings},
14 #[derive(Debug, Serialize, Clone)]
15 pub struct LocalUserView {
17 pub counts: PersonAggregates,
18 pub local_user: LocalUser,
21 type LocalUserViewTuple = (Person, PersonAggregates, LocalUser);
24 pub fn read(conn: &PgConnection, person_id: i32) -> Result<Self, Error> {
25 let (person, counts, local_user) = person::table
27 .inner_join(person_aggregates::table)
28 .inner_join(local_user::table)
29 .select((person::all_columns, person_aggregates::all_columns, local_user::all_columns))
30 .first::<LocalUserViewTuple>(conn)?;
31 Ok(Self { person, counts, local_user })
34 // TODO check where this is used
35 pub fn read_from_name(conn: &PgConnection, name: &str) -> Result<Self, Error> {
36 let (person, counts, local_user) = person::table
37 .filter(person::name.eq(name))
38 .inner_join(person_aggregates::table)
39 .inner_join(local_user::table)
40 .select((person::all_columns, person_aggregates::all_columns, local_user::all_columns))
41 .first::<LocalUserViewTuple>(conn)?;
42 Ok(Self { person, counts, local_user })
45 pub fn find_by_email_or_name(
48 ) -> Result<Self, Error> {
49 let (person, counts, local_user) = person::table
50 .inner_join(person_aggregates::table)
51 .inner_join(local_user::table)
52 .filter(person::name.ilike(name_or_email).or(local_user::email.ilike(name_or_email)))
53 .select((person::all_columns, person_aggregates::all_columns, local_user::all_columns))
54 .first::<LocalUserViewTuple>(conn)?;
55 Ok(Self { person, counts, local_user })
59 #[derive(Debug, Serialize, Clone)]
60 pub struct LocalUserSettingsView {
61 pub person: PersonSafe,
62 pub counts: PersonAggregates,
63 pub local_user: LocalUserSettings,
66 type LocalUserSettingsViewTuple = (PersonSafe, PersonAggregates, LocalUserSettings);
68 impl LocalUserSettingsView {
69 pub fn read(conn: &PgConnection, person_id: i32) -> Result<Self, Error> {
70 let (person, counts, local_user) = person::table
72 .inner_join(person_aggregates::table)
73 .inner_join(local_user::table)
74 .select((Person::safe_columns_tuple(), person_aggregates::all_columns, LocalUser::safe_settings_columns_tuple()))
75 .first::<LocalUserSettingsViewTuple>(conn)?;
76 Ok(Self { person, counts, local_user })