rooms: Fix BadEvent creation.

This commit is contained in:
Damir Jelić 2018-07-13 15:31:45 +02:00
parent 783f2d59e8
commit 901b18ac06
2 changed files with 20 additions and 15 deletions

View file

@ -954,7 +954,8 @@ class RoomBuffer(object):
self._handle_power_level(event) self._handle_power_level(event)
else: else:
W.prnt("", "Unhandled event of type {}.".format(type(event))) W.prnt("", "Unhandled event of type {}.".format(
type(event).__name__))
def self_message(self, message): def self_message(self, message):
nick = self.find_nick(self.room.own_user_id) nick = self.find_nick(self.room.own_user_id)

View file

@ -275,20 +275,22 @@ class RoomInfo():
def _parse_events(olm, room_id, parsed_dict): def _parse_events(olm, room_id, parsed_dict):
events = [] events = []
try: for event in parsed_dict:
for event in parsed_dict: try:
e = RoomInfo.parse_event(olm, room_id, event) e = RoomInfo.parse_event(olm, room_id, event)
except (ValueError, TypeError, KeyError) as error:
message = ("{prefix}matrix: Error parsing "
"room event of type {type}: "
"{error}\n{event}").format(
prefix=W.prefix("error"),
type=event["type"],
error=pformat(error),
event=pformat(event))
W.prnt("", message)
e = BadEvent.from_dict(event)
finally:
events.append(e) events.append(e)
except (ValueError, TypeError, KeyError) as error:
message = ("{prefix}matrix: Error parsing "
"room event of type {type}: {error}\n{event}").format(
prefix=W.prefix("error"),
type=event["type"],
error=pformat(error),
event=pformat(event))
W.prnt("", message)
e = BadEvent.from_dict(event)
events.append(e)
return events return events
@ -318,7 +320,7 @@ class RoomInfo():
) )
class RoomEvent(): class RoomEvent(object):
def __init__(self, event_id, sender, timestamp): def __init__(self, event_id, sender, timestamp):
self.event_id = event_id self.event_id = event_id
@ -328,14 +330,16 @@ class RoomEvent():
class BadEvent(RoomEvent): class BadEvent(RoomEvent):
def __init__(self, event_id, sender, timestamp, source): def __init__(self, event_id, sender, timestamp, source):
RoomEvent.__init__(self, event_id, sender, timestamp)
self.source = source self.source = source
@classmethod
def from_dict(cls, event): def from_dict(cls, event):
event_id = (sanitize_id(event["event_id"]) event_id = (sanitize_id(event["event_id"])
if "event_id" in event else None) if "event_id" in event else None)
sender = (sanitize_id(event["sender"]) sender = (sanitize_id(event["sender"])
if "sender" in event else None) if "sender" in event else None)
timestamp = (sanitize_id(event["origin_server_ts"]) timestamp = (sanitize_ts(event["origin_server_ts"])
if "origin_server_ts" in event else None) if "origin_server_ts" in event else None)
source = json.dumps(event) source = json.dumps(event)