Conduit is a simple, fast and reliable chat server powered by Matrix https://conduit.rs
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
83 lines
2.9 KiB
83 lines
2.9 KiB
use js_int::UInt; |
|
use ruma_events::{ |
|
collections::all::{RoomEvent, StateEvent}, |
|
stripped::AnyStrippedStateEvent, |
|
EventJson, EventType, |
|
}; |
|
use ruma_federation_api::EventHash; |
|
use ruma_identifiers::{EventId, RoomId, UserId}; |
|
use serde::{Deserialize, Serialize}; |
|
use std::collections::HashMap; |
|
|
|
#[derive(Deserialize, Serialize)] |
|
pub struct PduEvent { |
|
pub event_id: EventId, |
|
pub room_id: RoomId, |
|
pub sender: UserId, |
|
pub origin: String, |
|
pub origin_server_ts: UInt, |
|
#[serde(rename = "type")] |
|
pub kind: EventType, |
|
pub content: serde_json::Value, |
|
#[serde(skip_serializing_if = "Option::is_none")] |
|
pub state_key: Option<String>, |
|
pub prev_events: Vec<EventId>, |
|
pub depth: UInt, |
|
pub auth_events: Vec<EventId>, |
|
#[serde(skip_serializing_if = "Option::is_none")] |
|
pub redacts: Option<EventId>, |
|
#[serde(default, skip_serializing_if = "serde_json::Map::is_empty")] |
|
pub unsigned: serde_json::Map<String, serde_json::Value>, |
|
pub hashes: EventHash, |
|
pub signatures: HashMap<String, HashMap<String, String>>, |
|
} |
|
|
|
impl PduEvent { |
|
pub fn redact(&mut self) { |
|
self.unsigned.clear(); |
|
let allowed = match self.kind { |
|
EventType::RoomMember => vec!["membership"], |
|
EventType::RoomCreate => vec!["creator"], |
|
EventType::RoomJoinRules => vec!["join_rule"], |
|
EventType::RoomPowerLevels => vec![ |
|
"ban", |
|
"events", |
|
"events_default", |
|
"kick", |
|
"redact", |
|
"state_default", |
|
"users", |
|
"users_default", |
|
], |
|
EventType::RoomHistoryVisibility => vec!["history_visibility"], |
|
_ => vec![], |
|
}; |
|
|
|
let old_content = self.content.as_object_mut().unwrap(); // TODO error |
|
let mut new_content = serde_json::Map::new(); |
|
|
|
for key in allowed { |
|
if let Some(value) = old_content.remove(key) { |
|
new_content.insert(key.to_owned(), value); |
|
} |
|
} |
|
|
|
self.content = new_content.into(); |
|
} |
|
|
|
pub fn to_room_event(&self) -> EventJson<RoomEvent> { |
|
// Can only fail in rare circumstances that won't ever happen here, see |
|
// https://docs.rs/serde_json/1.0.50/serde_json/fn.to_string.html |
|
let json = serde_json::to_string(&self).unwrap(); |
|
// EventJson's deserialize implementation always returns `Ok(...)` |
|
serde_json::from_str::<EventJson<RoomEvent>>(&json).unwrap() |
|
} |
|
pub fn to_state_event(&self) -> EventJson<StateEvent> { |
|
let json = serde_json::to_string(&self).unwrap(); |
|
serde_json::from_str::<EventJson<StateEvent>>(&json).unwrap() |
|
} |
|
pub fn to_stripped_state_event(&self) -> EventJson<AnyStrippedStateEvent> { |
|
let json = serde_json::to_string(&self).unwrap(); |
|
serde_json::from_str::<EventJson<AnyStrippedStateEvent>>(&json).unwrap() |
|
} |
|
}
|
|
|