Files
continuwuity/src/api/client/presence.rs
T

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

94 lines
2.5 KiB
Rust
Raw Normal View History

use std::time::Duration;
2024-03-05 19:48:54 -05:00
2024-07-16 08:05:25 +00:00
use axum::extract::State;
use ruma::api::client::{
error::ErrorKind,
presence::{get_presence, set_presence},
};
2024-03-05 19:48:54 -05:00
2024-07-16 08:05:25 +00:00
use crate::{Error, Result, Ruma};
2020-07-30 18:14:47 +02:00
2021-08-31 19:14:37 +02:00
/// # `PUT /_matrix/client/r0/presence/{userId}/status`
///
/// Sets the presence state of the sender user.
2024-07-16 08:05:25 +00:00
pub(crate) async fn set_presence_route(
State(services): State<crate::State>, body: Ruma<set_presence::v3::Request>,
) -> Result<set_presence::v3::Response> {
if !services.globals.allow_local_presence() {
return Err(Error::BadRequest(ErrorKind::forbidden(), "Presence is disabled on this server"));
}
2020-10-18 20:33:12 +02:00
let sender_user = body.sender_user.as_ref().expect("user is authenticated");
if sender_user != &body.user_id && body.appservice_info.is_none() {
return Err(Error::BadRequest(
ErrorKind::InvalidParam,
"Not allowed to set presence of other users",
));
}
2024-07-16 08:05:25 +00:00
services
2024-04-01 20:48:40 -07:00
.presence
2024-08-08 17:18:30 +00:00
.set_presence(sender_user, &body.presence, None, None, body.status_msg.clone())
.await?;
2020-07-30 18:14:47 +02:00
2022-02-18 15:33:14 +01:00
Ok(set_presence::v3::Response {})
2020-07-30 18:14:47 +02:00
}
2021-05-14 11:03:18 +02:00
2021-08-31 19:14:37 +02:00
/// # `GET /_matrix/client/r0/presence/{userId}/status`
///
/// Gets the presence state of the given user.
///
/// - Only works if you share a room with the user
2024-07-16 08:05:25 +00:00
pub(crate) async fn get_presence_route(
State(services): State<crate::State>, body: Ruma<get_presence::v3::Request>,
) -> Result<get_presence::v3::Response> {
if !services.globals.allow_local_presence() {
return Err(Error::BadRequest(ErrorKind::forbidden(), "Presence is disabled on this server"));
}
2021-05-14 11:03:18 +02:00
let sender_user = body.sender_user.as_ref().expect("user is authenticated");
let mut presence_event = None;
2024-08-08 17:18:30 +00:00
let has_shared_rooms = services
2024-03-25 17:05:11 -04:00
.rooms
.user
2024-08-08 17:18:30 +00:00
.has_shared_rooms(sender_user, &body.user_id)
.await;
if has_shared_rooms {
if let Ok(presence) = services.presence.get_presence(&body.user_id).await {
2021-05-14 11:03:18 +02:00
presence_event = Some(presence);
}
}
if let Some(presence) = presence_event {
let status_msg = if presence
.content
.status_msg
.as_ref()
.is_some_and(String::is_empty)
{
None
} else {
presence.content.status_msg
};
2022-02-18 15:33:14 +01:00
Ok(get_presence::v3::Response {
2021-05-14 11:03:18 +02:00
// TODO: Should ruma just use the presenceeventcontent type here?
status_msg,
2021-05-14 11:03:18 +02:00
currently_active: presence.content.currently_active,
2024-03-25 17:05:11 -04:00
last_active_ago: presence
.content
.last_active_ago
.map(|millis| Duration::from_millis(millis.into())),
2021-05-14 11:03:18 +02:00
presence: presence.content.presence,
2022-01-22 16:58:32 +01:00
})
2021-05-14 11:03:18 +02:00
} else {
Err(Error::BadRequest(
ErrorKind::NotFound,
2023-12-20 21:46:05 -05:00
"Presence state for this user was not found",
))
2021-05-14 11:03:18 +02:00
}
}