mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-04-27 21:24:43 +00:00
* Remove explicit auth params (ref #3725) Only take auth via header or cookie. This requires a new version of lemmy-js-client for api tests to pass. * rework api_crud * remove remaining auth params, move logic to session middleware * fmt, fix test * update js client * remove auth param from api tests * Pass auth as header * add ! * url vars, setHeader * cleanup * fmt * update * Updating for new lemmy-js-client. --------- Co-authored-by: Dessalines <tyhou13@gmx.com> Co-authored-by: Dessalines <dessalines@users.noreply.github.com>
41 lines
1.2 KiB
Rust
41 lines
1.2 KiB
Rust
use actix_web::web::{Data, Json, Query};
|
|
use lemmy_api_common::{
|
|
context::LemmyContext,
|
|
private_message::{GetPrivateMessages, PrivateMessagesResponse},
|
|
};
|
|
use lemmy_db_views::{private_message_view::PrivateMessageQuery, structs::LocalUserView};
|
|
use lemmy_utils::error::LemmyError;
|
|
|
|
#[tracing::instrument(skip(context))]
|
|
pub async fn get_private_message(
|
|
data: Query<GetPrivateMessages>,
|
|
context: Data<LemmyContext>,
|
|
local_user_view: LocalUserView,
|
|
) -> Result<Json<PrivateMessagesResponse>, LemmyError> {
|
|
let person_id = local_user_view.person.id;
|
|
|
|
let page = data.page;
|
|
let limit = data.limit;
|
|
let unread_only = data.unread_only.unwrap_or_default();
|
|
let creator_id = data.creator_id;
|
|
let mut messages = PrivateMessageQuery {
|
|
page,
|
|
limit,
|
|
unread_only,
|
|
creator_id,
|
|
}
|
|
.list(&mut context.pool(), person_id)
|
|
.await?;
|
|
|
|
// Messages sent by ourselves should be marked as read. The `read` column in database is only
|
|
// for the recipient, and shouldnt be exposed to sender.
|
|
messages.iter_mut().for_each(|pmv| {
|
|
if pmv.creator.id == person_id {
|
|
pmv.private_message.read = true
|
|
}
|
|
});
|
|
|
|
Ok(Json(PrivateMessagesResponse {
|
|
private_messages: messages,
|
|
}))
|
|
}
|