matrix-sdk-base: merge StrippedRoom and Room
parent
f6f382e28a
commit
9332c55c8d
|
@ -63,7 +63,7 @@ use zeroize::Zeroizing;
|
||||||
use crate::{
|
use crate::{
|
||||||
error::Result,
|
error::Result,
|
||||||
event_handler::Handler,
|
event_handler::Handler,
|
||||||
rooms::{RoomInfo, RoomType, StrippedRoomInfo},
|
rooms::{RoomInfo, RoomType},
|
||||||
session::Session,
|
session::Session,
|
||||||
store::{ambiguity_map::AmbiguityCache, Result as StoreResult, StateChanges, Store},
|
store::{ambiguity_map::AmbiguityCache, Result as StoreResult, StateChanges, Store},
|
||||||
EventHandler, RoomState,
|
EventHandler, RoomState,
|
||||||
|
@ -481,7 +481,7 @@ impl BaseClient {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
_ => {
|
_ => {
|
||||||
room_info.handle_state_event(&s);
|
room_info.handle_state_event(&s.content());
|
||||||
changes.add_state_event(room_id, s.clone());
|
changes.add_state_event(room_id, s.clone());
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -525,7 +525,7 @@ impl BaseClient {
|
||||||
fn handle_invited_state(
|
fn handle_invited_state(
|
||||||
&self,
|
&self,
|
||||||
events: Vec<Raw<AnyStrippedStateEvent>>,
|
events: Vec<Raw<AnyStrippedStateEvent>>,
|
||||||
room_info: &mut StrippedRoomInfo,
|
room_info: &mut RoomInfo,
|
||||||
) -> (
|
) -> (
|
||||||
InviteState,
|
InviteState,
|
||||||
BTreeMap<UserId, StrippedMemberEvent>,
|
BTreeMap<UserId, StrippedMemberEvent>,
|
||||||
|
@ -549,7 +549,7 @@ impl BaseClient {
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
room_info.handle_state_event(&e);
|
room_info.handle_state_event(&e.content());
|
||||||
state_events
|
state_events
|
||||||
.entry(e.content().event_type().to_owned())
|
.entry(e.content().event_type().to_owned())
|
||||||
.or_insert_with(BTreeMap::new)
|
.or_insert_with(BTreeMap::new)
|
||||||
|
@ -598,7 +598,7 @@ impl BaseClient {
|
||||||
})
|
})
|
||||||
{
|
{
|
||||||
state.events.push(event.clone());
|
state.events.push(event.clone());
|
||||||
room_info.handle_state_event(&event);
|
room_info.handle_state_event(&event.content());
|
||||||
|
|
||||||
if let AnySyncStateEvent::RoomMember(member) = event {
|
if let AnySyncStateEvent::RoomMember(member) = event {
|
||||||
match MemberEvent::try_from(member) {
|
match MemberEvent::try_from(member) {
|
||||||
|
|
|
@ -54,7 +54,6 @@ mod store;
|
||||||
pub use event_handler::{CustomEvent, EventHandler};
|
pub use event_handler::{CustomEvent, EventHandler};
|
||||||
pub use rooms::{
|
pub use rooms::{
|
||||||
InvitedRoom, JoinedRoom, LeftRoom, Room, RoomInfo, RoomMember, RoomState, RoomType,
|
InvitedRoom, JoinedRoom, LeftRoom, Room, RoomInfo, RoomMember, RoomState, RoomType,
|
||||||
StrippedRoom, StrippedRoomInfo,
|
|
||||||
};
|
};
|
||||||
pub use store::{StateChanges, StateStore, Store, StoreError};
|
pub use store::{StateChanges, StateStore, Store, StoreError};
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
mod members;
|
mod members;
|
||||||
mod normal;
|
mod normal;
|
||||||
mod stripped;
|
|
||||||
|
|
||||||
use matrix_sdk_common::{
|
use matrix_sdk_common::{
|
||||||
events::room::{
|
events::room::{
|
||||||
|
@ -10,7 +9,6 @@ use matrix_sdk_common::{
|
||||||
identifiers::UserId,
|
identifiers::UserId,
|
||||||
};
|
};
|
||||||
pub use normal::{Room, RoomInfo, RoomType};
|
pub use normal::{Room, RoomInfo, RoomType};
|
||||||
pub use stripped::{StrippedRoom, StrippedRoomInfo};
|
|
||||||
|
|
||||||
pub use members::RoomMember;
|
pub use members::RoomMember;
|
||||||
|
|
||||||
|
@ -140,11 +138,11 @@ impl Deref for LeftRoom {
|
||||||
/// A room in an invited state.
|
/// A room in an invited state.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct InvitedRoom {
|
pub struct InvitedRoom {
|
||||||
pub(crate) inner: StrippedRoom,
|
pub(crate) inner: Room,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Deref for InvitedRoom {
|
impl Deref for InvitedRoom {
|
||||||
type Target = StrippedRoom;
|
type Target = Room;
|
||||||
|
|
||||||
fn deref(&self) -> &Self::Target {
|
fn deref(&self) -> &Self::Target {
|
||||||
&self.inner
|
&self.inner
|
||||||
|
|
|
@ -29,7 +29,7 @@ use matrix_sdk_common::{
|
||||||
guest_access::GuestAccess, history_visibility::HistoryVisibility, join_rules::JoinRule,
|
guest_access::GuestAccess, history_visibility::HistoryVisibility, join_rules::JoinRule,
|
||||||
tombstone::TombstoneEventContent,
|
tombstone::TombstoneEventContent,
|
||||||
},
|
},
|
||||||
AnySyncStateEvent, EventType,
|
AnySyncStateEvent, AnyStateEventContent, EventType,
|
||||||
},
|
},
|
||||||
identifiers::{RoomAliasId, RoomId, UserId},
|
identifiers::{RoomAliasId, RoomId, UserId},
|
||||||
};
|
};
|
||||||
|
@ -43,7 +43,7 @@ use crate::{
|
||||||
|
|
||||||
use super::{BaseRoomInfo, RoomMember};
|
use super::{BaseRoomInfo, RoomMember};
|
||||||
|
|
||||||
/// The underlying room data structure collecting state for joined and left rooms.
|
/// The underlying room data structure collecting state for joined, left and invtied rooms.
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct Room {
|
pub struct Room {
|
||||||
room_id: Arc<RoomId>,
|
room_id: Arc<RoomId>,
|
||||||
|
@ -484,8 +484,8 @@ impl RoomInfo {
|
||||||
self.base_info.encryption.is_some()
|
self.base_info.encryption.is_some()
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn handle_state_event(&mut self, event: &AnySyncStateEvent) -> bool {
|
pub(crate) fn handle_state_event(&mut self, event: &AnyStateEventContent) -> bool {
|
||||||
self.base_info.handle_state_event(&event.content())
|
self.base_info.handle_state_event(&event)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn update_notification_count(
|
pub(crate) fn update_notification_count(
|
||||||
|
|
|
@ -1,145 +0,0 @@
|
||||||
// Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
||||||
//
|
|
||||||
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
// you may not use this file except in compliance with the License.
|
|
||||||
// You may obtain a copy of the License at
|
|
||||||
//
|
|
||||||
// http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
//
|
|
||||||
// Unless required by applicable law or agreed to in writing, software
|
|
||||||
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
// See the License for the specific language governing permissions and
|
|
||||||
// limitations under the License.
|
|
||||||
|
|
||||||
use std::sync::{Arc, Mutex as SyncMutex};
|
|
||||||
|
|
||||||
use matrix_sdk_common::{
|
|
||||||
events::{
|
|
||||||
room::{encryption::EncryptionEventContent, history_visibility::HistoryVisibility},
|
|
||||||
AnyStrippedStateEvent,
|
|
||||||
},
|
|
||||||
identifiers::{RoomId, UserId},
|
|
||||||
};
|
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
|
|
||||||
use crate::store::StateStore;
|
|
||||||
|
|
||||||
use super::BaseRoomInfo;
|
|
||||||
|
|
||||||
/// The underlying room data structure collecting state for invited rooms.
|
|
||||||
#[derive(Debug, Clone)]
|
|
||||||
pub struct StrippedRoom {
|
|
||||||
room_id: Arc<RoomId>,
|
|
||||||
own_user_id: Arc<UserId>,
|
|
||||||
inner: Arc<SyncMutex<StrippedRoomInfo>>,
|
|
||||||
store: Arc<Box<dyn StateStore>>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl StrippedRoom {
|
|
||||||
pub(crate) fn new(
|
|
||||||
own_user_id: &UserId,
|
|
||||||
store: Arc<Box<dyn StateStore>>,
|
|
||||||
room_id: &RoomId,
|
|
||||||
) -> Self {
|
|
||||||
let room_id = Arc::new(room_id.clone());
|
|
||||||
|
|
||||||
let info = StrippedRoomInfo {
|
|
||||||
room_id,
|
|
||||||
base_info: BaseRoomInfo::new(),
|
|
||||||
};
|
|
||||||
|
|
||||||
Self::restore(own_user_id, store, info)
|
|
||||||
}
|
|
||||||
|
|
||||||
pub(crate) fn restore(
|
|
||||||
own_user_id: &UserId,
|
|
||||||
store: Arc<Box<dyn StateStore>>,
|
|
||||||
room_info: StrippedRoomInfo,
|
|
||||||
) -> Self {
|
|
||||||
Self {
|
|
||||||
own_user_id: Arc::new(own_user_id.clone()),
|
|
||||||
room_id: room_info.room_id.clone(),
|
|
||||||
store,
|
|
||||||
inner: Arc::new(SyncMutex::new(room_info)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fn calculate_name(&self) -> String {
|
|
||||||
let inner = self.inner.lock().unwrap();
|
|
||||||
|
|
||||||
if let Some(name) = &inner.base_info.name {
|
|
||||||
let name = name.trim();
|
|
||||||
name.to_string()
|
|
||||||
} else if let Some(alias) = &inner.base_info.canonical_alias {
|
|
||||||
let alias = alias.alias().trim();
|
|
||||||
alias.to_string()
|
|
||||||
} else {
|
|
||||||
// TODO do the dance with room members to calculate the name
|
|
||||||
self.room_id.to_string()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get the unique room id of the room.
|
|
||||||
pub fn room_id(&self) -> &RoomId {
|
|
||||||
&self.room_id
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get our own user id.
|
|
||||||
pub fn own_user_id(&self) -> &UserId {
|
|
||||||
&self.own_user_id
|
|
||||||
}
|
|
||||||
|
|
||||||
pub(crate) fn clone_info(&self) -> StrippedRoomInfo {
|
|
||||||
(*self.inner.lock().unwrap()).clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Is the room encrypted.
|
|
||||||
pub fn is_encrypted(&self) -> bool {
|
|
||||||
self.inner.lock().unwrap().base_info.encryption.is_some()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get the `m.room.encryption` content that enabled end to end encryption
|
|
||||||
/// in the room.
|
|
||||||
pub fn encryption_settings(&self) -> Option<EncryptionEventContent> {
|
|
||||||
self.inner.lock().unwrap().base_info.encryption.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Get the history visibility policy of this room.
|
|
||||||
pub fn history_visibility(&self) -> HistoryVisibility {
|
|
||||||
self.inner
|
|
||||||
.lock()
|
|
||||||
.unwrap()
|
|
||||||
.base_info
|
|
||||||
.history_visibility
|
|
||||||
.clone()
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Calculate the canonical display name of the room, taking into account
|
|
||||||
/// its name, aliases and members.
|
|
||||||
///
|
|
||||||
/// The display name is calculated according to [this algorithm][spec].
|
|
||||||
///
|
|
||||||
/// [spec]: <https://matrix.org/docs/spec/client_server/latest#calculating-the-display-name-for-a-room>
|
|
||||||
pub async fn display_name(&self) -> String {
|
|
||||||
self.calculate_name().await
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The underlying pure data structure for invited rooms.
|
|
||||||
///
|
|
||||||
/// Holds all the info needed to persist a room into the state store.
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
||||||
pub struct StrippedRoomInfo {
|
|
||||||
/// The unique room id of the room.
|
|
||||||
pub room_id: Arc<RoomId>,
|
|
||||||
/// Base room info which holds some basic event contents important for the
|
|
||||||
/// room state.
|
|
||||||
pub base_info: BaseRoomInfo,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl StrippedRoomInfo {
|
|
||||||
pub(crate) fn handle_state_event(&mut self, event: &AnyStrippedStateEvent) -> bool {
|
|
||||||
self.base_info.handle_state_event(&event.content())
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -33,7 +33,7 @@ use tracing::info;
|
||||||
|
|
||||||
use crate::deserialized_responses::{MemberEvent, StrippedMemberEvent};
|
use crate::deserialized_responses::{MemberEvent, StrippedMemberEvent};
|
||||||
|
|
||||||
use super::{Result, RoomInfo, StateChanges, StateStore, StrippedRoomInfo};
|
use super::{Result, RoomInfo, StateChanges, StateStore};
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct MemoryStore {
|
pub struct MemoryStore {
|
||||||
|
@ -49,7 +49,7 @@ pub struct MemoryStore {
|
||||||
#[allow(clippy::type_complexity)]
|
#[allow(clippy::type_complexity)]
|
||||||
room_state: Arc<DashMap<RoomId, DashMap<String, DashMap<String, AnySyncStateEvent>>>>,
|
room_state: Arc<DashMap<RoomId, DashMap<String, DashMap<String, AnySyncStateEvent>>>>,
|
||||||
room_account_data: Arc<DashMap<RoomId, DashMap<String, AnyBasicEvent>>>,
|
room_account_data: Arc<DashMap<RoomId, DashMap<String, AnyBasicEvent>>>,
|
||||||
stripped_room_info: Arc<DashMap<RoomId, StrippedRoomInfo>>,
|
stripped_room_info: Arc<DashMap<RoomId, RoomInfo>>,
|
||||||
#[allow(clippy::type_complexity)]
|
#[allow(clippy::type_complexity)]
|
||||||
stripped_room_state:
|
stripped_room_state:
|
||||||
Arc<DashMap<RoomId, DashMap<String, DashMap<String, AnyStrippedStateEvent>>>>,
|
Arc<DashMap<RoomId, DashMap<String, DashMap<String, AnyStrippedStateEvent>>>>,
|
||||||
|
@ -291,7 +291,7 @@ impl MemoryStore {
|
||||||
self.room_info.iter().map(|r| r.clone()).collect()
|
self.room_info.iter().map(|r| r.clone()).collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_stripped_room_infos(&self) -> Vec<StrippedRoomInfo> {
|
fn get_stripped_room_infos(&self) -> Vec<RoomInfo> {
|
||||||
#[allow(clippy::map_clone)]
|
#[allow(clippy::map_clone)]
|
||||||
self.stripped_room_info.iter().map(|r| r.clone()).collect()
|
self.stripped_room_info.iter().map(|r| r.clone()).collect()
|
||||||
}
|
}
|
||||||
|
@ -357,7 +357,7 @@ impl StateStore for MemoryStore {
|
||||||
Ok(self.get_room_infos())
|
Ok(self.get_room_infos())
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn get_stripped_room_infos(&self) -> Result<Vec<StrippedRoomInfo>> {
|
async fn get_stripped_room_infos(&self) -> Result<Vec<RoomInfo>> {
|
||||||
Ok(self.get_stripped_room_infos())
|
Ok(self.get_stripped_room_infos())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@ use sled::Db;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
deserialized_responses::{MemberEvent, StrippedMemberEvent},
|
deserialized_responses::{MemberEvent, StrippedMemberEvent},
|
||||||
rooms::{RoomInfo, RoomType, StrippedRoom, StrippedRoomInfo},
|
rooms::{RoomInfo, RoomType},
|
||||||
InvitedRoom, JoinedRoom, LeftRoom, Room, RoomState, Session,
|
InvitedRoom, JoinedRoom, LeftRoom, Room, RoomState, Session,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -164,8 +164,8 @@ pub trait StateStore: AsyncTraitDeps {
|
||||||
/// Get all the pure `RoomInfo`s the store knows about.
|
/// Get all the pure `RoomInfo`s the store knows about.
|
||||||
async fn get_room_infos(&self) -> Result<Vec<RoomInfo>>;
|
async fn get_room_infos(&self) -> Result<Vec<RoomInfo>>;
|
||||||
|
|
||||||
/// Get all the pure `StrippedRoomInfo`s the store knows about.
|
/// Get all the pure `RoomInfo`s the store knows about.
|
||||||
async fn get_stripped_room_infos(&self) -> Result<Vec<StrippedRoomInfo>>;
|
async fn get_stripped_room_infos(&self) -> Result<Vec<RoomInfo>>;
|
||||||
|
|
||||||
/// Get all the users that use the given display name in the given room.
|
/// Get all the users that use the given display name in the given room.
|
||||||
///
|
///
|
||||||
|
@ -192,7 +192,7 @@ pub struct Store {
|
||||||
pub(crate) session: Arc<RwLock<Option<Session>>>,
|
pub(crate) session: Arc<RwLock<Option<Session>>>,
|
||||||
pub(crate) sync_token: Arc<RwLock<Option<String>>>,
|
pub(crate) sync_token: Arc<RwLock<Option<String>>>,
|
||||||
rooms: Arc<DashMap<RoomId, Room>>,
|
rooms: Arc<DashMap<RoomId, Room>>,
|
||||||
stripped_rooms: Arc<DashMap<RoomId, StrippedRoom>>,
|
stripped_rooms: Arc<DashMap<RoomId, Room>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Store {
|
impl Store {
|
||||||
|
@ -216,7 +216,7 @@ impl Store {
|
||||||
}
|
}
|
||||||
|
|
||||||
for info in self.inner.get_stripped_room_infos().await? {
|
for info in self.inner.get_stripped_room_infos().await? {
|
||||||
let room = StrippedRoom::restore(&session.user_id, self.inner.clone(), info);
|
let room = Room::restore(&session.user_id, self.inner.clone(), info);
|
||||||
self.stripped_rooms.insert(room.room_id().to_owned(), room);
|
self.stripped_rooms.insert(room.room_id().to_owned(), room);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -315,12 +315,12 @@ impl Store {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_stripped_room(&self, room_id: &RoomId) -> Option<StrippedRoom> {
|
fn get_stripped_room(&self, room_id: &RoomId) -> Option<Room> {
|
||||||
#[allow(clippy::map_clone)]
|
#[allow(clippy::map_clone)]
|
||||||
self.stripped_rooms.get(room_id).map(|r| r.clone())
|
self.stripped_rooms.get(room_id).map(|r| r.clone())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn get_or_create_stripped_room(&self, room_id: &RoomId) -> StrippedRoom {
|
pub(crate) async fn get_or_create_stripped_room(&self, room_id: &RoomId) -> Room {
|
||||||
let session = self.session.read().await;
|
let session = self.session.read().await;
|
||||||
let user_id = &session
|
let user_id = &session
|
||||||
.as_ref()
|
.as_ref()
|
||||||
|
@ -329,7 +329,7 @@ impl Store {
|
||||||
|
|
||||||
self.stripped_rooms
|
self.stripped_rooms
|
||||||
.entry(room_id.clone())
|
.entry(room_id.clone())
|
||||||
.or_insert_with(|| StrippedRoom::new(user_id, self.inner.clone(), room_id))
|
.or_insert_with(|| Room::new(user_id, self.inner.clone(), room_id, RoomType::Invited))
|
||||||
.clone()
|
.clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -384,8 +384,8 @@ pub struct StateChanges {
|
||||||
pub stripped_state: BTreeMap<RoomId, BTreeMap<String, BTreeMap<String, AnyStrippedStateEvent>>>,
|
pub stripped_state: BTreeMap<RoomId, BTreeMap<String, BTreeMap<String, AnyStrippedStateEvent>>>,
|
||||||
/// A mapping of `RoomId` to a map of users and their `StrippedMemberEvent`.
|
/// A mapping of `RoomId` to a map of users and their `StrippedMemberEvent`.
|
||||||
pub stripped_members: BTreeMap<RoomId, BTreeMap<UserId, StrippedMemberEvent>>,
|
pub stripped_members: BTreeMap<RoomId, BTreeMap<UserId, StrippedMemberEvent>>,
|
||||||
/// A map of `RoomId` to `StrippedRoomInfo`.
|
/// A map of `RoomId` to `RoomInfo`.
|
||||||
pub invited_room_info: BTreeMap<RoomId, StrippedRoomInfo>,
|
pub invited_room_info: BTreeMap<RoomId, RoomInfo>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl StateChanges {
|
impl StateChanges {
|
||||||
|
@ -408,8 +408,8 @@ impl StateChanges {
|
||||||
.insert(room.room_id.as_ref().to_owned(), room);
|
.insert(room.room_id.as_ref().to_owned(), room);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Update the `StateChanges` struct with the given `StrippedRoomInfo`.
|
/// Update the `StateChanges` struct with the given `RoomInfo`.
|
||||||
pub fn add_stripped_room(&mut self, room: StrippedRoomInfo) {
|
pub fn add_stripped_room(&mut self, room: RoomInfo) {
|
||||||
self.invited_room_info
|
self.invited_room_info
|
||||||
.insert(room.room_id.as_ref().to_owned(), room);
|
.insert(room.room_id.as_ref().to_owned(), room);
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ use sled::{
|
||||||
};
|
};
|
||||||
use tracing::info;
|
use tracing::info;
|
||||||
|
|
||||||
use crate::{deserialized_responses::MemberEvent, rooms::StrippedRoomInfo};
|
use crate::deserialized_responses::MemberEvent;
|
||||||
|
|
||||||
use self::store_key::{EncryptedEvent, StoreKey};
|
use self::store_key::{EncryptedEvent, StoreKey};
|
||||||
|
|
||||||
|
@ -560,7 +560,7 @@ impl SledStore {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get_stripped_room_infos(&self) -> impl Stream<Item = Result<StrippedRoomInfo>> {
|
pub async fn get_stripped_room_infos(&self) -> impl Stream<Item = Result<RoomInfo>> {
|
||||||
let db = self.clone();
|
let db = self.clone();
|
||||||
stream::iter(
|
stream::iter(
|
||||||
self.stripped_room_info
|
self.stripped_room_info
|
||||||
|
@ -644,7 +644,7 @@ impl StateStore for SledStore {
|
||||||
self.get_room_infos().await.try_collect().await
|
self.get_room_infos().await.try_collect().await
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn get_stripped_room_infos(&self) -> Result<Vec<StrippedRoomInfo>> {
|
async fn get_stripped_room_infos(&self) -> Result<Vec<RoomInfo>> {
|
||||||
self.get_stripped_room_infos().await.try_collect().await
|
self.get_stripped_room_infos().await.try_collect().await
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue