summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTimo Kösters <timo@koesters.xyz>2023-08-10 11:45:31 +0200
committerTimo Kösters <timo@koesters.xyz>2023-08-10 11:45:31 +0200
commitfd9e52a559303989740cb64deb273eefea9d3958 (patch)
tree05dbd91ade33db0e83335c6e7e7fd4d793e1715d
parent183558150d1c2a022b9be60b22295f78d2326b27 (diff)
downloadconduit-fd9e52a559303989740cb64deb273eefea9d3958.zip
More sanity checks
-rw-r--r--src/service/rooms/event_handler/mod.rs18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/service/rooms/event_handler/mod.rs b/src/service/rooms/event_handler/mod.rs
index c6e433c..899f035 100644
--- a/src/service/rooms/event_handler/mod.rs
+++ b/src/service/rooms/event_handler/mod.rs
@@ -119,6 +119,7 @@ impl Service {
let (incoming_pdu, val) = self
.handle_outlier_pdu(origin, &create_event, event_id, room_id, value, pub_key_map)
.await?;
+ self.check_room_id(room_id, &incoming_pdu)?;
// 8. if not timeline event: stop
if !is_timeline_event {
@@ -338,6 +339,8 @@ impl Service {
)
.map_err(|_| Error::bad_database("Event is not a valid PDU."))?;
+ self.check_room_id(room_id, &incoming_pdu)?;
+
// 4. fetch any missing auth events doing all checks listed here starting at 1. These are not timeline events
// 5. Reject "due to auth events" if can't get all the auth events or some of the auth events are also rejected "due to auth events"
// NOTE: Step 5 is not applied anymore because it failed too often
@@ -373,6 +376,8 @@ impl Service {
}
};
+ self.check_room_id(room_id, &auth_event)?;
+
match auth_events.entry((
auth_event.kind.to_string().into(),
auth_event
@@ -1178,6 +1183,8 @@ impl Service {
.await
.pop()
{
+ self.check_room_id(room_id, &pdu)?;
+
if amount > services().globals.max_fetch_prev_events() {
// Max limit reached
warn!("Max prev event limit reached!");
@@ -1702,4 +1709,15 @@ impl Service {
"Failed to find public key for server",
))
}
+
+ fn check_room_id(&self, room_id: &RoomId, pdu: &PduEvent) -> Result<()> {
+ if pdu.room_id != room_id {
+ warn!("Found event from room {} in room {}", pdu.room_id, room_id);
+ return Err(Error::BadRequest(
+ ErrorKind::InvalidParam,
+ "Event has wrong room id",
+ ));
+ }
+ Ok(())
+ }
}