Handle exceptions in get_hosts_for_room when sending events over federation
							parent
							
								
									135fc5b9cd
								
							
						
					
					
						commit
						145d14656b
					
				|  | @ -184,17 +184,22 @@ class TransactionQueue(object): | |||
|                     if not is_mine and send_on_behalf_of is None: | ||||
|                         continue | ||||
| 
 | ||||
|                     # Get the state from before the event. | ||||
|                     # We need to make sure that this is the state from before | ||||
|                     # the event and not from after it. | ||||
|                     # Otherwise if the last member on a server in a room is | ||||
|                     # banned then it won't receive the event because it won't | ||||
|                     # be in the room after the ban. | ||||
|                     destinations = yield self.state.get_current_hosts_in_room( | ||||
|                         event.room_id, latest_event_ids=[ | ||||
|                             prev_id for prev_id, _ in event.prev_events | ||||
|                         ], | ||||
|                     ) | ||||
|                     try: | ||||
|                         # Get the state from before the event. | ||||
|                         # We need to make sure that this is the state from before | ||||
|                         # the event and not from after it. | ||||
|                         # Otherwise if the last member on a server in a room is | ||||
|                         # banned then it won't receive the event because it won't | ||||
|                         # be in the room after the ban. | ||||
|                         destinations = yield self.state.get_current_hosts_in_room( | ||||
|                             event.room_id, latest_event_ids=[ | ||||
|                                 prev_id for prev_id, _ in event.prev_events | ||||
|                             ], | ||||
|                         ) | ||||
|                     except Exception: | ||||
|                         logger.exception("Failed to calculate hosts in room") | ||||
|                         continue | ||||
| 
 | ||||
|                     destinations = set(destinations) | ||||
| 
 | ||||
|                     if send_on_behalf_of is not None: | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Erik Johnston
						Erik Johnston