Merge remote-tracking branch 'origin/better-admin-commands' into custom

This commit is contained in:
tezlm 2024-08-22 15:17:12 -07:00
commit e283dd3438
Signed by: tezlm
GPG key ID: 649733FCD94AFBBA
5 changed files with 1027 additions and 656 deletions

View file

@ -75,4 +75,28 @@ impl service::rooms::alias::Data for KeyValueDatabase {
})
.transpose()
}
fn all_local_aliases<'a>(
&'a self,
) -> Box<dyn Iterator<Item = Result<(OwnedRoomId, String)>> + 'a> {
Box::new(
self.alias_roomid
.iter()
.map(|(room_alias_bytes, room_id_bytes)| {
let room_alias_localpart = utils::string_from_bytes(&room_alias_bytes)
.map_err(|_| {
Error::bad_database("Invalid alias bytes in aliasid_alias.")
})?;
let room_id = utils::string_from_bytes(&room_id_bytes)
.map_err(|_| {
Error::bad_database("Invalid room_id bytes in aliasid_alias.")
})?
.try_into()
.map_err(|_| Error::bad_database("Invalid room_id in aliasid_alias."))?;
Ok((room_id, room_alias_localpart))
}),
)
}
}

File diff suppressed because it is too large Load diff

View file

@ -19,4 +19,9 @@ pub trait Data: Send + Sync {
&'a self,
room_id: &RoomId,
) -> Box<dyn Iterator<Item = Result<OwnedRoomAliasId>> + 'a>;
/// Returns all local aliases on the server
fn all_local_aliases<'a>(
&'a self,
) -> Box<dyn Iterator<Item = Result<(OwnedRoomId, String)>> + 'a>;
}

View file

@ -98,4 +98,11 @@ impl Service {
) -> Box<dyn Iterator<Item = Result<OwnedRoomAliasId>> + 'a> {
self.db.local_aliases_for_room(room_id)
}
#[tracing::instrument(skip(self))]
pub fn all_local_aliases<'a>(
&'a self,
) -> Box<dyn Iterator<Item = Result<(OwnedRoomId, String)>> + 'a> {
self.db.all_local_aliases()
}
}

View file

@ -506,7 +506,11 @@ impl Service {
.state_cache
.is_joined(server_user, &admin_room)?
{
services().admin.process_message(body);
services().admin.process_message(
body,
pdu.event_id.clone(),
pdu.sender.clone(),
);
}
}
}