Remove associated pushers on device delete. (fixes #120)
Signed-off-by: Jason Volk <jason@zemos.net>
This commit is contained in:
@@ -9,10 +9,7 @@ use ruma::api::client::{
|
||||
},
|
||||
uiaa::{AuthFlow, AuthType, UiaaInfo},
|
||||
};
|
||||
use tuwunel_core::{
|
||||
Err, Error, Result, err, info, utils,
|
||||
utils::{ReadyExt, stream::BroadbandExt},
|
||||
};
|
||||
use tuwunel_core::{Err, Error, Result, err, info, utils, utils::ReadyExt};
|
||||
|
||||
use super::SESSION_ID_LENGTH;
|
||||
use crate::Ruma;
|
||||
@@ -93,29 +90,6 @@ pub(crate) async fn change_password_route(
|
||||
.ready_filter(|id| *id != body.sender_device())
|
||||
.for_each(|id| services.users.remove_device(sender_user, id))
|
||||
.await;
|
||||
|
||||
// Remove all pushers except the ones associated with this session
|
||||
services
|
||||
.pusher
|
||||
.get_pushkeys(sender_user)
|
||||
.map(ToOwned::to_owned)
|
||||
.broad_filter_map(async |pushkey| {
|
||||
services
|
||||
.pusher
|
||||
.get_pusher_device(&pushkey)
|
||||
.await
|
||||
.ok()
|
||||
.filter(|pusher_device| pusher_device != body.sender_device())
|
||||
.is_some()
|
||||
.then_some(pushkey)
|
||||
})
|
||||
.for_each(async |pushkey| {
|
||||
services
|
||||
.pusher
|
||||
.delete_pusher(sender_user, &pushkey)
|
||||
.await;
|
||||
})
|
||||
.await;
|
||||
}
|
||||
|
||||
info!("User {sender_user} changed their password.");
|
||||
|
||||
@@ -24,7 +24,10 @@ use tuwunel_core::{
|
||||
Err, Result, debug_warn, err,
|
||||
matrix::Event,
|
||||
trace,
|
||||
utils::{stream::TryIgnore, string_from_bytes},
|
||||
utils::{
|
||||
stream::{BroadbandExt, TryIgnore},
|
||||
string_from_bytes,
|
||||
},
|
||||
warn,
|
||||
};
|
||||
use tuwunel_database::{Deserialized, Ignore, Interfix, Json, Map};
|
||||
@@ -134,6 +137,25 @@ impl Service {
|
||||
.ok();
|
||||
}
|
||||
|
||||
pub async fn get_device_pushkeys(
|
||||
&self,
|
||||
sender: &UserId,
|
||||
device_id: &DeviceId,
|
||||
) -> Vec<String> {
|
||||
self.get_pushkeys(sender)
|
||||
.map(ToOwned::to_owned)
|
||||
.broad_filter_map(async |pushkey| {
|
||||
self.get_pusher_device(&pushkey)
|
||||
.await
|
||||
.ok()
|
||||
.filter(|pusher_device| pusher_device == device_id)
|
||||
.is_some()
|
||||
.then_some(pushkey)
|
||||
})
|
||||
.collect()
|
||||
.await
|
||||
}
|
||||
|
||||
pub async fn get_pusher_device(&self, pushkey: &str) -> Result<OwnedDeviceId> {
|
||||
self.db
|
||||
.pushkey_deviceid
|
||||
|
||||
@@ -13,7 +13,7 @@ use tuwunel_core::{
|
||||
Err, Result, at, implement,
|
||||
utils::{
|
||||
self, ReadyExt,
|
||||
stream::TryIgnore,
|
||||
stream::{IterStream, TryIgnore},
|
||||
time::{duration_since_epoch, timepoint_from_epoch, timepoint_from_now},
|
||||
},
|
||||
};
|
||||
@@ -70,6 +70,21 @@ pub async fn remove_device(&self, user_id: &UserId, device_id: &DeviceId) {
|
||||
.ready_for_each(|key| self.db.todeviceid_events.remove(key))
|
||||
.await;
|
||||
|
||||
// Remove pushers
|
||||
self.services
|
||||
.pusher
|
||||
.get_device_pushkeys(user_id, device_id)
|
||||
.map(Vec::into_iter)
|
||||
.map(IterStream::stream)
|
||||
.flatten_stream()
|
||||
.for_each(async |pushkey| {
|
||||
self.services
|
||||
.pusher
|
||||
.delete_pusher(user_id, &pushkey)
|
||||
.await;
|
||||
})
|
||||
.await;
|
||||
|
||||
// TODO: Remove onetimekeys
|
||||
|
||||
increment(&self.db.userid_devicelistversion, user_id.as_bytes());
|
||||
|
||||
Reference in New Issue
Block a user