conduwuit/src/service/rooms/lazy_loading/mod.rs

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

85 lines
2.3 KiB
Rust
Raw Normal View History

mod data;
use std::{
collections::{HashMap, HashSet},
fmt::Write,
sync::{Arc, Mutex},
};
use conduit::{PduCount, Result};
2022-10-09 17:25:06 +02:00
use ruma::{DeviceId, OwnedDeviceId, OwnedRoomId, OwnedUserId, RoomId, UserId};
2022-01-04 14:30:13 +01:00
use self::data::Data;
2023-02-20 22:59:45 +01:00
pub struct Service {
db: Data,
2022-10-05 12:45:54 +02:00
#[allow(clippy::type_complexity)]
pub lazy_load_waiting: Mutex<HashMap<(OwnedUserId, OwnedDeviceId, OwnedRoomId, PduCount), HashSet<OwnedUserId>>>,
}
impl crate::Service for Service {
fn build(args: crate::Args<'_>) -> Result<Arc<Self>> {
Ok(Arc::new(Self {
db: Data::new(args.db),
lazy_load_waiting: Mutex::new(HashMap::new()),
}))
}
fn memory_usage(&self, out: &mut dyn Write) -> Result<()> {
let lazy_load_waiting = self.lazy_load_waiting.lock().expect("locked").len();
writeln!(out, "lazy_load_waiting: {lazy_load_waiting}")?;
Ok(())
}
fn clear_cache(&self) { self.lazy_load_waiting.lock().expect("locked").clear(); }
fn name(&self) -> &str { crate::service::make_name(std::module_path!()) }
}
impl Service {
#[tracing::instrument(skip(self), level = "debug")]
pub fn lazy_load_was_sent_before(
2022-01-04 14:30:13 +01:00
&self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, ll_user: &UserId,
) -> Result<bool> {
self.db
.lazy_load_was_sent_before(user_id, device_id, room_id, ll_user)
2022-01-04 14:30:13 +01:00
}
#[tracing::instrument(skip(self), level = "debug")]
pub async fn lazy_load_mark_sent(
2022-10-09 17:25:06 +02:00
&self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, lazy_load: HashSet<OwnedUserId>,
2023-02-20 22:59:45 +01:00
count: PduCount,
2022-01-04 14:30:13 +01:00
) {
self.lazy_load_waiting
.lock()
.expect("locked")
2022-01-04 14:30:13 +01:00
.insert((user_id.to_owned(), device_id.to_owned(), room_id.to_owned(), count), lazy_load);
}
#[tracing::instrument(skip(self), level = "debug")]
pub async fn lazy_load_confirm_delivery(
2022-01-04 14:30:13 +01:00
&self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, since: PduCount,
) -> Result<()> {
if let Some(user_ids) = self.lazy_load_waiting.lock().expect("locked").remove(&(
2022-10-05 12:45:54 +02:00
user_id.to_owned(),
device_id.to_owned(),
room_id.to_owned(),
since,
)) {
self.db
.lazy_load_confirm_delivery(user_id, device_id, room_id, &mut user_ids.iter().map(|u| &**u))?;
2022-10-05 12:45:54 +02:00
} else {
// Ignore
}
2022-10-05 12:45:54 +02:00
Ok(())
2022-01-04 14:30:13 +01:00
}
#[tracing::instrument(skip(self), level = "debug")]
pub fn lazy_load_reset(&self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId) -> Result<()> {
self.db.lazy_load_reset(user_id, device_id, room_id)
2022-01-04 14:30:13 +01:00
}
}