Merge branch 'initial_state_keys' into 'master'
Implement From<AnyInitialStateEvent> on PduBuilder Closes #116 See merge request famedly/conduit!136
This commit is contained in:
		
						commit
						cae2b200cc
					
				
					 2 changed files with 20 additions and 7 deletions
				
			
		|  | @ -233,10 +233,9 @@ pub async fn create_room_route( | |||
| 
 | ||||
|     // 5. Events listed in initial_state
 | ||||
|     for event in &body.initial_state { | ||||
|         let pdu_builder = serde_json::from_str::<PduBuilder>( | ||||
|             &serde_json::to_string(&event).expect("AnyInitialStateEvent::to_string always works"), | ||||
|         ) | ||||
|         .map_err(|_| Error::BadRequest(ErrorKind::InvalidParam, "Invalid initial state event."))?; | ||||
|         let pdu_builder = PduBuilder::from(event.deserialize().map_err(|_| { | ||||
|             Error::BadRequest(ErrorKind::InvalidParam, "Invalid initial state event.") | ||||
|         })?); | ||||
| 
 | ||||
|         // Silently skip encryption events if they are not allowed
 | ||||
|         if pdu_builder.event_type == EventType::RoomEncryption && !db.globals.allow_encryption() { | ||||
|  |  | |||
							
								
								
									
										20
									
								
								src/pdu.rs
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								src/pdu.rs
									
									
									
									
									
								
							|  | @ -2,9 +2,9 @@ use crate::Error; | |||
| use log::error; | ||||
| use ruma::{ | ||||
|     events::{ | ||||
|         pdu::EventHash, room::member::MemberEventContent, AnyEphemeralRoomEvent, AnyRoomEvent, | ||||
|         AnyStateEvent, AnyStrippedStateEvent, AnySyncRoomEvent, AnySyncStateEvent, EventType, | ||||
|         StateEvent, | ||||
|         pdu::EventHash, room::member::MemberEventContent, AnyEphemeralRoomEvent, | ||||
|         AnyInitialStateEvent, AnyRoomEvent, AnyStateEvent, AnyStrippedStateEvent, AnySyncRoomEvent, | ||||
|         AnySyncStateEvent, EventType, StateEvent, | ||||
|     }, | ||||
|     serde::{CanonicalJsonObject, CanonicalJsonValue, Raw}, | ||||
|     state_res, EventId, MilliSecondsSinceUnixEpoch, RoomId, RoomVersionId, ServerName, | ||||
|  | @ -346,3 +346,17 @@ pub struct PduBuilder { | |||
|     pub state_key: Option<String>, | ||||
|     pub redacts: Option<EventId>, | ||||
| } | ||||
| 
 | ||||
| /// Direct conversion prevents loss of the empty `state_key` that ruma requires.
 | ||||
| impl From<AnyInitialStateEvent> for PduBuilder { | ||||
|     fn from(event: AnyInitialStateEvent) -> Self { | ||||
|         Self { | ||||
|             event_type: EventType::from(event.event_type()), | ||||
|             content: serde_json::value::to_value(event.content()) | ||||
|                 .expect("AnyStateEventContent came from JSON and can thus turn back into JSON."), | ||||
|             unsigned: None, | ||||
|             state_key: Some(event.state_key().to_owned()), | ||||
|             redacts: None, | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue