mirror of
https://gitlab.com/famedly/conduit.git
synced 2025-01-14 13:36:27 +03:00
improvement: better federation joins
This commit is contained in:
parent
af53485d70
commit
1f292c09f2
4 changed files with 136 additions and 79 deletions
30
Cargo.lock
generated
30
Cargo.lock
generated
|
@ -1634,7 +1634,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma"
|
name = "ruma"
|
||||||
version = "0.0.1"
|
version = "0.0.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ruma-api",
|
"ruma-api",
|
||||||
"ruma-appservice-api",
|
"ruma-appservice-api",
|
||||||
|
@ -1650,7 +1650,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-api"
|
name = "ruma-api"
|
||||||
version = "0.17.0-alpha.1"
|
version = "0.17.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"http",
|
"http",
|
||||||
"percent-encoding",
|
"percent-encoding",
|
||||||
|
@ -1665,7 +1665,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-api-macros"
|
name = "ruma-api-macros"
|
||||||
version = "0.17.0-alpha.1"
|
version = "0.17.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro-crate",
|
"proc-macro-crate",
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
|
@ -1676,7 +1676,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-appservice-api"
|
name = "ruma-appservice-api"
|
||||||
version = "0.2.0-alpha.1"
|
version = "0.2.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"ruma-api",
|
"ruma-api",
|
||||||
"ruma-common",
|
"ruma-common",
|
||||||
|
@ -1689,7 +1689,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-client-api"
|
name = "ruma-client-api"
|
||||||
version = "0.10.0-alpha.1"
|
version = "0.10.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"assign",
|
"assign",
|
||||||
"http",
|
"http",
|
||||||
|
@ -1708,7 +1708,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-common"
|
name = "ruma-common"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"js_int",
|
"js_int",
|
||||||
"ruma-api",
|
"ruma-api",
|
||||||
|
@ -1722,7 +1722,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-events"
|
name = "ruma-events"
|
||||||
version = "0.22.0-alpha.1"
|
version = "0.22.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"js_int",
|
"js_int",
|
||||||
"ruma-common",
|
"ruma-common",
|
||||||
|
@ -1737,7 +1737,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-events-macros"
|
name = "ruma-events-macros"
|
||||||
version = "0.22.0-alpha.1"
|
version = "0.22.0-alpha.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro-crate",
|
"proc-macro-crate",
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
|
@ -1748,7 +1748,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-federation-api"
|
name = "ruma-federation-api"
|
||||||
version = "0.0.3"
|
version = "0.0.3"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"js_int",
|
"js_int",
|
||||||
"ruma-api",
|
"ruma-api",
|
||||||
|
@ -1763,7 +1763,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-identifiers"
|
name = "ruma-identifiers"
|
||||||
version = "0.17.4"
|
version = "0.17.4"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"rand",
|
"rand",
|
||||||
"ruma-identifiers-macros",
|
"ruma-identifiers-macros",
|
||||||
|
@ -1775,7 +1775,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-identifiers-macros"
|
name = "ruma-identifiers-macros"
|
||||||
version = "0.17.4"
|
version = "0.17.4"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"proc-macro2",
|
"proc-macro2",
|
||||||
"quote",
|
"quote",
|
||||||
|
@ -1786,7 +1786,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-identifiers-validation"
|
name = "ruma-identifiers-validation"
|
||||||
version = "0.1.1"
|
version = "0.1.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"serde",
|
"serde",
|
||||||
"strum",
|
"strum",
|
||||||
|
@ -1795,7 +1795,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-serde"
|
name = "ruma-serde"
|
||||||
version = "0.2.3"
|
version = "0.2.3"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"form_urlencoded",
|
"form_urlencoded",
|
||||||
"itoa",
|
"itoa",
|
||||||
|
@ -1807,7 +1807,7 @@ dependencies = [
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ruma-signatures"
|
name = "ruma-signatures"
|
||||||
version = "0.6.0-dev.1"
|
version = "0.6.0-dev.1"
|
||||||
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#63341000fbabce9b230b6665ce65c617944408fa"
|
source = "git+https://github.com/timokoesters/ruma?branch=timo-fed-fixes#8d763abaecb13f4799a31ecf1e0da77d2bc956a6"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"base64",
|
"base64",
|
||||||
"ring",
|
"ring",
|
||||||
|
@ -2072,7 +2072,7 @@ checksum = "7345c971d1ef21ffdbd103a75990a15eb03604fc8b8852ca8cb418ee1a099028"
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "state-res"
|
name = "state-res"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
source = "git+https://github.com/timokoesters/state-res?branch=spec-comp#0081081604b051d412a2365b68357e064c33320c"
|
source = "git+https://github.com/timokoesters/state-res?branch=spec-comp#a9186476b748c901fbf4356414247a0b3ac01b5f"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"itertools",
|
"itertools",
|
||||||
"js_int",
|
"js_int",
|
||||||
|
|
|
@ -2,7 +2,7 @@ use super::State;
|
||||||
use crate::{
|
use crate::{
|
||||||
client_server,
|
client_server,
|
||||||
pdu::{PduBuilder, PduEvent},
|
pdu::{PduBuilder, PduEvent},
|
||||||
server_server, utils, ConduitResult, Database, Error, Ruma,
|
server_server, utils, ConduitResult, Database, Error, Result, Ruma,
|
||||||
};
|
};
|
||||||
use log::warn;
|
use log::warn;
|
||||||
use ruma::{
|
use ruma::{
|
||||||
|
@ -17,11 +17,14 @@ use ruma::{
|
||||||
},
|
},
|
||||||
federation,
|
federation,
|
||||||
},
|
},
|
||||||
|
events::pdu::Pdu,
|
||||||
events::{room::member, EventType},
|
events::{room::member, EventType},
|
||||||
EventId, Raw, RoomId, RoomVersionId, UserId,
|
EventId, Raw, RoomId, RoomVersionId, UserId,
|
||||||
};
|
};
|
||||||
use state_res::StateEvent;
|
use state_res::StateEvent;
|
||||||
use std::{collections::BTreeMap, convert::TryFrom, sync::Arc};
|
use std::{
|
||||||
|
collections::BTreeMap, collections::HashMap, collections::HashSet, convert::TryFrom, sync::Arc,
|
||||||
|
};
|
||||||
|
|
||||||
#[cfg(feature = "conduit_bin")]
|
#[cfg(feature = "conduit_bin")]
|
||||||
use rocket::{get, post};
|
use rocket::{get, post};
|
||||||
|
@ -482,36 +485,49 @@ async fn join_room_by_id_helper(
|
||||||
)
|
)
|
||||||
.await?;
|
.await?;
|
||||||
|
|
||||||
let mut event_map = send_join_response
|
let add_event_id = |pdu: &Raw<Pdu>| {
|
||||||
|
let mut value = serde_json::from_str(pdu.json().get())
|
||||||
|
.expect("converting raw jsons to values always works");
|
||||||
|
let event_id = EventId::try_from(&*format!(
|
||||||
|
"${}",
|
||||||
|
ruma::signatures::reference_hash(&value)
|
||||||
|
.expect("ruma can calculate reference hashes")
|
||||||
|
))
|
||||||
|
.expect("ruma's reference hashes are valid event ids");
|
||||||
|
|
||||||
|
value
|
||||||
|
.as_object_mut()
|
||||||
|
.ok_or_else(|| Error::BadServerResponse("PDU is not an object."))?
|
||||||
|
.insert("event_id".to_owned(), event_id.to_string().into());
|
||||||
|
|
||||||
|
Ok((event_id, value))
|
||||||
|
};
|
||||||
|
|
||||||
|
let room_state = send_join_response.room_state.state.iter().map(add_event_id);
|
||||||
|
|
||||||
|
let state_events = room_state
|
||||||
|
.clone()
|
||||||
|
.map(|pdu: Result<(EventId, serde_json::Value)>| Ok(pdu?.0))
|
||||||
|
.collect::<Result<HashSet<EventId>>>()?;
|
||||||
|
|
||||||
|
let auth_chain = send_join_response
|
||||||
.room_state
|
.room_state
|
||||||
.state
|
.auth_chain
|
||||||
.iter()
|
.iter()
|
||||||
.chain(send_join_response.room_state.auth_chain.iter())
|
.map(add_event_id);
|
||||||
.map(|pdu| {
|
|
||||||
let mut value = serde_json::from_str(pdu.json().get())
|
|
||||||
.expect("converting raw jsons to values always works");
|
|
||||||
let event_id = EventId::try_from(&*format!(
|
|
||||||
"${}",
|
|
||||||
ruma::signatures::reference_hash(&value)
|
|
||||||
.expect("ruma can calculate reference hashes")
|
|
||||||
))
|
|
||||||
.expect("ruma's reference hashes are valid event ids");
|
|
||||||
|
|
||||||
value
|
|
||||||
.as_object_mut()
|
|
||||||
.ok_or_else(|| Error::BadServerResponse("PDU is not an object."))?
|
|
||||||
.insert("event_id".to_owned(), event_id.to_string().into());
|
|
||||||
|
|
||||||
dbg!(&value);
|
|
||||||
|
|
||||||
|
let mut event_map = room_state
|
||||||
|
.chain(auth_chain)
|
||||||
|
.map(|r| {
|
||||||
|
let (event_id, value) = r?;
|
||||||
serde_json::from_value::<StateEvent>(value)
|
serde_json::from_value::<StateEvent>(value)
|
||||||
.map(|ev| (dbg!(&ev).event_id().clone(), Arc::new(ev)))
|
.map(|ev| (event_id, Arc::new(ev)))
|
||||||
.map_err(|e| {
|
.map_err(|e| {
|
||||||
warn!("{}", e);
|
warn!("{}", e);
|
||||||
Error::BadServerResponse("Invalid PDU bytes in send_join response.")
|
Error::BadServerResponse("Invalid PDU bytes in send_join response.")
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
.collect::<Result<BTreeMap<EventId, Arc<StateEvent>>, _>>()?;
|
.collect::<Result<BTreeMap<EventId, Arc<StateEvent>>>>()?;
|
||||||
|
|
||||||
let control_events = event_map
|
let control_events = event_map
|
||||||
.values()
|
.values()
|
||||||
|
@ -575,6 +591,8 @@ async fn join_room_by_id_helper(
|
||||||
)
|
)
|
||||||
.expect("iterative auth check failed on resolved events");
|
.expect("iterative auth check failed on resolved events");
|
||||||
|
|
||||||
|
let mut state = HashMap::new();
|
||||||
|
|
||||||
// filter the events that failed the auth check keeping the remaining events
|
// filter the events that failed the auth check keeping the remaining events
|
||||||
// sorted correctly
|
// sorted correctly
|
||||||
for ev_id in sorted_event_ids
|
for ev_id in sorted_event_ids
|
||||||
|
@ -587,9 +605,22 @@ async fn join_room_by_id_helper(
|
||||||
.expect("Found event_id in sorted events that is not in resolved state");
|
.expect("Found event_id in sorted events that is not in resolved state");
|
||||||
|
|
||||||
// We do not rebuild the PDU in this case only insert to DB
|
// We do not rebuild the PDU in this case only insert to DB
|
||||||
db.rooms
|
let pdu_id =
|
||||||
.append_pdu(PduEvent::from(&**pdu), &db.globals, &db.account_data)?;
|
db.rooms
|
||||||
|
.append_pdu(&PduEvent::from(&**pdu), &db.globals, &db.account_data)?;
|
||||||
|
|
||||||
|
if state_events.contains(ev_id) {
|
||||||
|
state.insert(
|
||||||
|
(
|
||||||
|
pdu.kind(),
|
||||||
|
pdu.state_key().expect("State events have a state key"),
|
||||||
|
),
|
||||||
|
pdu_id,
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
db.rooms.force_state(room_id, state)?;
|
||||||
} else {
|
} else {
|
||||||
let event = member::MemberEventContent {
|
let event = member::MemberEventContent {
|
||||||
membership: member::MembershipState::Join,
|
membership: member::MembershipState::Join,
|
||||||
|
|
|
@ -220,6 +220,31 @@ impl Rooms {
|
||||||
.is_some())
|
.is_some())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Returns the full room state.
|
||||||
|
pub fn force_state(
|
||||||
|
&self,
|
||||||
|
room_id: &RoomId,
|
||||||
|
state: HashMap<(EventType, String), Vec<u8>>,
|
||||||
|
) -> Result<()> {
|
||||||
|
let state_hash =
|
||||||
|
self.calculate_hash(&state.values().map(|pdu_id| &**pdu_id).collect::<Vec<_>>())?;
|
||||||
|
let mut prefix = state_hash.clone();
|
||||||
|
prefix.push(0xff);
|
||||||
|
|
||||||
|
for ((event_type, state_key), pdu_id) in state {
|
||||||
|
let mut state_id = prefix.clone();
|
||||||
|
state_id.extend_from_slice(&event_type.as_str().as_bytes());
|
||||||
|
state_id.push(0xff);
|
||||||
|
state_id.extend_from_slice(&state_key.as_bytes());
|
||||||
|
self.stateid_pduid.insert(state_id, pdu_id)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
self.roomid_statehash
|
||||||
|
.insert(room_id.as_bytes(), &*state_hash)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns the full room state.
|
/// Returns the full room state.
|
||||||
pub fn room_state_full(
|
pub fn room_state_full(
|
||||||
&self,
|
&self,
|
||||||
|
@ -446,10 +471,10 @@ impl Rooms {
|
||||||
/// Creates a new persisted data unit and adds it to a room.
|
/// Creates a new persisted data unit and adds it to a room.
|
||||||
pub fn append_pdu(
|
pub fn append_pdu(
|
||||||
&self,
|
&self,
|
||||||
pdu: PduEvent,
|
pdu: &PduEvent,
|
||||||
globals: &super::globals::Globals,
|
globals: &super::globals::Globals,
|
||||||
account_data: &super::account_data::AccountData,
|
account_data: &super::account_data::AccountData,
|
||||||
) -> Result<EventId> {
|
) -> Result<Vec<u8>> {
|
||||||
let mut pdu_json = serde_json::to_value(&pdu).expect("event is valid, we just created it");
|
let mut pdu_json = serde_json::to_value(&pdu).expect("event is valid, we just created it");
|
||||||
ruma::signatures::hash_and_sign_event(
|
ruma::signatures::hash_and_sign_event(
|
||||||
globals.server_name().as_str(),
|
globals.server_name().as_str(),
|
||||||
|
@ -473,10 +498,6 @@ impl Rooms {
|
||||||
self.eventid_pduid
|
self.eventid_pduid
|
||||||
.insert(pdu.event_id.as_bytes(), &*pdu_id)?;
|
.insert(pdu.event_id.as_bytes(), &*pdu_id)?;
|
||||||
|
|
||||||
if pdu.state_key.is_some() {
|
|
||||||
self.append_to_state(&pdu_id, &pdu)?;
|
|
||||||
}
|
|
||||||
|
|
||||||
match pdu.kind {
|
match pdu.kind {
|
||||||
EventType::RoomRedaction => {
|
EventType::RoomRedaction => {
|
||||||
if let Some(redact_id) = &pdu.redacts {
|
if let Some(redact_id) = &pdu.redacts {
|
||||||
|
@ -484,23 +505,22 @@ impl Rooms {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EventType::RoomMember => {
|
EventType::RoomMember => {
|
||||||
if let Some(state_key) = pdu.state_key {
|
if let Some(state_key) = &pdu.state_key {
|
||||||
// if the state_key fails
|
// if the state_key fails
|
||||||
let target_user_id = UserId::try_from(state_key)
|
let target_user_id = UserId::try_from(state_key.clone())
|
||||||
.expect("This state_key was previously validated");
|
.expect("This state_key was previously validated");
|
||||||
// Update our membership info, we do this here incase a user is invited
|
// Update our membership info, we do this here incase a user is invited
|
||||||
// and immediately leaves we need the DB to record the invite event for auth
|
// and immediately leaves we need the DB to record the invite event for auth
|
||||||
self.update_membership(
|
self.update_membership(
|
||||||
&pdu.room_id,
|
&pdu.room_id,
|
||||||
&target_user_id,
|
&target_user_id,
|
||||||
serde_json::from_value::<member::MemberEventContent>(pdu.content).map_err(
|
serde_json::from_value::<member::MemberEventContent>(pdu.content.clone())
|
||||||
|_| {
|
.map_err(|_| {
|
||||||
Error::BadRequest(
|
Error::BadRequest(
|
||||||
ErrorKind::InvalidParam,
|
ErrorKind::InvalidParam,
|
||||||
"Invalid redaction event content.",
|
"Invalid redaction event content.",
|
||||||
)
|
)
|
||||||
},
|
})?,
|
||||||
)?,
|
|
||||||
&pdu.sender,
|
&pdu.sender,
|
||||||
account_data,
|
account_data,
|
||||||
globals,
|
globals,
|
||||||
|
@ -528,7 +548,7 @@ impl Rooms {
|
||||||
self.edus
|
self.edus
|
||||||
.private_read_set(&pdu.room_id, &pdu.sender, index, &globals)?;
|
.private_read_set(&pdu.room_id, &pdu.sender, index, &globals)?;
|
||||||
|
|
||||||
Ok(pdu.event_id)
|
Ok(pdu_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Generates a new StateHash and associates it with the incoming event.
|
/// Generates a new StateHash and associates it with the incoming event.
|
||||||
|
@ -789,7 +809,13 @@ impl Rooms {
|
||||||
))
|
))
|
||||||
.expect("ruma's reference hashes are valid event ids");
|
.expect("ruma's reference hashes are valid event ids");
|
||||||
|
|
||||||
self.append_pdu(pdu, globals, account_data)
|
let pdu_id = self.append_pdu(&pdu, globals, account_data)?;
|
||||||
|
|
||||||
|
if pdu.state_key.is_some() {
|
||||||
|
self.append_to_state(&pdu_id, &pdu)?;
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(pdu.event_id)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Returns an iterator over all PDUs in a room.
|
/// Returns an iterator over all PDUs in a room.
|
||||||
|
@ -953,19 +979,17 @@ impl Rooms {
|
||||||
self.roomuseroncejoinedids.insert(&userroom_id, &[])?;
|
self.roomuseroncejoinedids.insert(&userroom_id, &[])?;
|
||||||
|
|
||||||
// Check if the room has a predecessor
|
// Check if the room has a predecessor
|
||||||
if let Some(predecessor) = serde_json::from_value::<
|
if let Some(predecessor) = self
|
||||||
Raw<ruma::events::room::create::CreateEventContent>,
|
.room_state_get(&room_id, &EventType::RoomCreate, "")?
|
||||||
>(
|
.and_then(|create| {
|
||||||
self.room_state_get(&room_id, &EventType::RoomCreate, "")?
|
serde_json::from_value::<
|
||||||
.ok_or_else(|| {
|
Raw<ruma::events::room::create::CreateEventContent>,
|
||||||
Error::bad_database("Found room without m.room.create event.")
|
>(create.content)
|
||||||
})?
|
.expect("Raw::from_value always works")
|
||||||
.content,
|
.deserialize()
|
||||||
)
|
.ok()
|
||||||
.expect("Raw::from_value always works")
|
})
|
||||||
.deserialize()
|
.and_then(|content| content.predecessor)
|
||||||
.map_err(|_| Error::bad_database("Invalid room event in database."))?
|
|
||||||
.predecessor
|
|
||||||
{
|
{
|
||||||
// Copy user settings from predecessor to the current room:
|
// Copy user settings from predecessor to the current room:
|
||||||
// - Push rules
|
// - Push rules
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use crate::{client_server, ConduitResult, Database, Error, Result, Ruma};
|
use crate::{client_server, ConduitResult, Database, Error, PduEvent, Result, Ruma};
|
||||||
use http::header::{HeaderValue, AUTHORIZATION};
|
use http::header::{HeaderValue, AUTHORIZATION};
|
||||||
use rocket::{get, post, put, response::content::Json, State};
|
use rocket::{get, post, put, response::content::Json, State};
|
||||||
use ruma::{
|
use ruma::{
|
||||||
|
@ -270,9 +270,11 @@ pub fn send_transaction_message_route<'a>(
|
||||||
db: State<'a, Database>,
|
db: State<'a, Database>,
|
||||||
body: Ruma<send_transaction_message::v1::Request<'_>>,
|
body: Ruma<send_transaction_message::v1::Request<'_>>,
|
||||||
) -> ConduitResult<send_transaction_message::v1::Response> {
|
) -> ConduitResult<send_transaction_message::v1::Response> {
|
||||||
dbg!(&*body);
|
//dbg!(&*body);
|
||||||
for pdu in &body.pdus {
|
for pdu in &body.pdus {
|
||||||
let mut value = serde_json::to_value(pdu).expect("all ruma pdus are json values");
|
let mut value = serde_json::from_str(pdu.json().get())
|
||||||
|
.expect("converting raw jsons to values always works");
|
||||||
|
|
||||||
let event_id = EventId::try_from(&*format!(
|
let event_id = EventId::try_from(&*format!(
|
||||||
"${}",
|
"${}",
|
||||||
ruma::signatures::reference_hash(&value).expect("ruma can calculate reference hashes")
|
ruma::signatures::reference_hash(&value).expect("ruma can calculate reference hashes")
|
||||||
|
@ -284,11 +286,11 @@ pub fn send_transaction_message_route<'a>(
|
||||||
.expect("ruma pdus are json objects")
|
.expect("ruma pdus are json objects")
|
||||||
.insert("event_id".to_owned(), event_id.to_string().into());
|
.insert("event_id".to_owned(), event_id.to_string().into());
|
||||||
|
|
||||||
db.rooms.append_pdu(
|
let pdu =
|
||||||
serde_json::from_value(value).expect("all ruma pdus are conduit pdus"),
|
serde_json::from_value::<PduEvent>(value).expect("all ruma pdus are conduit pdus");
|
||||||
&db.globals,
|
if db.rooms.exists(&pdu.room_id)? {
|
||||||
&db.account_data,
|
db.rooms.append_pdu(&pdu, &db.globals, &db.account_data)?;
|
||||||
)?;
|
}
|
||||||
}
|
}
|
||||||
Ok(send_transaction_message::v1::Response {
|
Ok(send_transaction_message::v1::Response {
|
||||||
pdus: BTreeMap::new(),
|
pdus: BTreeMap::new(),
|
||||||
|
|
Loading…
Reference in a new issue