- .inner_join(person_alias_1::table.on(private_message::recipient_id.eq(person_alias_1::id)))
- .order_by(private_message::published.desc())
- .select((
- private_message::all_columns,
- Person::safe_columns_tuple(),
- PersonAlias1::safe_columns_tuple(),
- ))
- .first::<PrivateMessageViewTuple>(conn)?;
-
- Ok(PrivateMessageView {
- private_message,
- creator,
- recipient,
- })
- }
-}
-
-pub struct PrivateMessageQueryBuilder<'a> {
- conn: &'a PgConnection,
- recipient_id: PersonId,
- unread_only: bool,
- page: Option<i64>,
- limit: Option<i64>,
-}
-
-impl<'a> PrivateMessageQueryBuilder<'a> {
- pub fn create(conn: &'a PgConnection, recipient_id: PersonId) -> Self {
- PrivateMessageQueryBuilder {
- conn,
- recipient_id,
- unread_only: false,
- page: None,
- limit: None,
- }
- }
-
- pub fn unread_only(mut self, unread_only: bool) -> Self {
- self.unread_only = unread_only;
- self
- }