mod data; use std::{collections::{HashSet, HashMap}, sync::{Mutex, Arc}}; pub use data::Data; use ruma::{DeviceId, UserId, RoomId}; use crate::Result; pub struct Service { db: Arc, lazy_load_waiting: Mutex, Box, Box, u64), HashSet>>>, } impl Service { #[tracing::instrument(skip(self))] pub fn lazy_load_was_sent_before( &self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, ll_user: &UserId, ) -> Result { self.db.lazy_load_was_sent_before(user_id, device_id, room_id, ll_user) } #[tracing::instrument(skip(self))] pub fn lazy_load_mark_sent( &self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, lazy_load: HashSet>, count: u64, ) { self.lazy_load_waiting.lock().unwrap().insert( ( user_id.to_owned(), device_id.to_owned(), room_id.to_owned(), count, ), lazy_load, ); } #[tracing::instrument(skip(self))] pub fn lazy_load_confirm_delivery( &self, user_id: &UserId, device_id: &DeviceId, room_id: &RoomId, since: u64, ) -> Result<()> { if let Some(user_ids) = self.lazy_load_waiting.lock().unwrap().remove(&( 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))?; } else { // Ignore } Ok(()) } #[tracing::instrument(skip(self))] 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) } }