Fix bug where we didn't correctly store the ops power levels event.

This commit is contained in:
Erik Johnston 2014-09-02 12:11:52 +01:00
parent 4ac80b8570
commit 4b8244fbf8
3 changed files with 9 additions and 1 deletions

View file

@ -169,6 +169,11 @@ class Auth(object):
)
_, kick_level = yield self.store.get_ops_levels(event.room_id)
if kick_level:
kick_level = int(kick_level)
else:
kick_level = 5
if user_level < kick_level:
raise AuthError(
403, "You cannot kick user %s." % target_user_id

View file

@ -23,6 +23,7 @@ from synapse.api.events.room import (
RoomPowerLevelsEvent,
RoomAddStateLevelEvent,
RoomSendEventLevelEvent,
RoomOpsPowerLevelsEvent,
)
from synapse.util.logutils import log_function
@ -140,6 +141,8 @@ class DataStore(RoomMemberStore, RoomStore,
self._store_add_state_level(txn, event)
elif event.type == RoomSendEventLevelEvent.TYPE:
self._store_send_event_level(txn, event)
elif event.type == RoomOpsPowerLevelsEvent.TYPE:
self._store_ops_level(txn, event)
vals = {
"topological_ordering": event.depth,

View file

@ -328,7 +328,7 @@ class RoomStore(SQLBaseStore):
self._simple_insert_txn(
txn,
"room_send_event_levels",
"room_ops_levels",
content,
)