mirror of
				https://github.com/matrix-org/synapse.git
				synced 2025-10-24 22:01:58 +02:00 
			
		
		
		
	Merge pull request #2290 from matrix-org/erikj/ensure_round_trip
Reject local events that don't round trip the DB
This commit is contained in:
		
						commit
						d04d672a80
					
				| @ -34,6 +34,7 @@ from canonicaljson import encode_canonical_json | |||||||
| 
 | 
 | ||||||
| import logging | import logging | ||||||
| import random | import random | ||||||
|  | import ujson | ||||||
| 
 | 
 | ||||||
| logger = logging.getLogger(__name__) | logger = logging.getLogger(__name__) | ||||||
| 
 | 
 | ||||||
| @ -498,6 +499,14 @@ class MessageHandler(BaseHandler): | |||||||
|             logger.warn("Denying new event %r because %s", event, err) |             logger.warn("Denying new event %r because %s", event, err) | ||||||
|             raise err |             raise err | ||||||
| 
 | 
 | ||||||
|  |         # Ensure that we can round trip before trying to persist in db | ||||||
|  |         try: | ||||||
|  |             dump = ujson.dumps(event.content) | ||||||
|  |             ujson.loads(dump) | ||||||
|  |         except: | ||||||
|  |             logger.exception("Failed to encode content: %r", event.content) | ||||||
|  |             raise | ||||||
|  | 
 | ||||||
|         yield self.maybe_kick_guest_users(event, context) |         yield self.maybe_kick_guest_users(event, context) | ||||||
| 
 | 
 | ||||||
|         if event.type == EventTypes.CanonicalAlias: |         if event.type == EventTypes.CanonicalAlias: | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user