Skip to content

Commit

Permalink
Merge pull request matrix-org#4837 from matrix-org/erikj/optional_pre…
Browse files Browse the repository at this point in the history
…v_state

Make `prev_state` field optional
  • Loading branch information
erikjohnston authored Mar 11, 2019
2 parents 39e57f9 + fe6c12e commit ca7f7d8
Show file tree
Hide file tree
Showing 4 changed files with 3 additions and 16 deletions.
1 change: 1 addition & 0 deletions changelog.d/4837.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Fix bug where synapse expected an un-specced `prev_state` field on state events.
1 change: 0 additions & 1 deletion synapse/events/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -141,7 +141,6 @@ def __init__(self, event_dict, signatures={}, unsigned={},
origin = _event_dict_property("origin")
origin_server_ts = _event_dict_property("origin_server_ts")
prev_events = _event_dict_property("prev_events")
prev_state = _event_dict_property("prev_state")
redacts = _event_dict_property("redacts")
room_id = _event_dict_property("room_id")
sender = _event_dict_property("sender")
Expand Down
15 changes: 0 additions & 15 deletions synapse/storage/events.py
Original file line number Diff line number Diff line change
Expand Up @@ -1407,21 +1407,6 @@ def _update_metadata_tables_txn(self, txn, events_and_contexts,
values=state_values,
)

self._simple_insert_many_txn(
txn,
table="event_edges",
values=[
{
"event_id": event.event_id,
"prev_event_id": prev_id,
"room_id": event.room_id,
"is_state": True,
}
for event, _ in state_events_and_contexts
for prev_id, _ in event.prev_state
],
)

# Prefill the event cache
self._add_to_cache(txn, events_and_contexts)

Expand Down
2 changes: 2 additions & 0 deletions synapse/storage/schema/full_schemas/11/event_edges.sql
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,8 @@ CREATE TABLE IF NOT EXISTS event_edges(
event_id TEXT NOT NULL,
prev_event_id TEXT NOT NULL,
room_id TEXT NOT NULL,
-- We no longer insert prev_state into this table, so all new rows will have
-- is_state as false.
is_state BOOL NOT NULL,
UNIQUE (event_id, prev_event_id, room_id, is_state)
);
Expand Down

0 comments on commit ca7f7d8

Please sign in to comment.