5 changed files with 112 additions and 55 deletions
@ -0,0 +1,42 @@
@@ -0,0 +1,42 @@
|
||||
use js_int::UInt; |
||||
use ruma_events::{collections::all::RoomEvent, EventResult, 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 to_room_event(&self) -> 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(); |
||||
// EventResult's deserialize implementation always returns `Ok(...)`
|
||||
serde_json::from_str::<EventResult<RoomEvent>>(&json) |
||||
.unwrap() |
||||
.into_result() |
||||
.unwrap() |
||||
} |
||||
} |
||||
Loading…
Reference in new issue