Remove more references to dead PDU tables

This commit is contained in:
Erik Johnston 2014-10-31 14:27:14 +00:00
parent bfa36a72b9
commit 2f39dc19a2
4 changed files with 8 additions and 94 deletions

View File

@ -32,11 +32,11 @@ class PduCodec(object):
self.hs = hs self.hs = hs
def encode_event_id(self, local, domain): def encode_event_id(self, local, domain):
return EventID.create(local, domain, self.hs).to_string() return local
def decode_event_id(self, event_id): def decode_event_id(self, event_id):
e_id = self.hs.parse_eventid(event_id) e_id = self.hs.parse_eventid(event_id)
return e_id.localpart, e_id.domain return event_id, e_id.domain
def event_from_pdu(self, pdu): def event_from_pdu(self, pdu):
kwargs = {} kwargs = {}

View File

@ -77,29 +77,18 @@ class StateHandler(object):
snapshot.fill_out_prev_events(event) snapshot.fill_out_prev_events(event)
yield self.annotate_state_groups(event) yield self.annotate_state_groups(event)
current_state = snapshot.prev_state_pdu if event.old_state_events:
current_state = event.old_state_events.get(
(event.type, event.state_key)
)
if current_state: if current_state:
event.prev_state = EventID.create( event.prev_state = current_state.event_id
current_state.pdu_id, current_state.origin, self.hs
).to_string()
# TODO check current_state to see if the min power level is less # TODO check current_state to see if the min power level is less
# than the power level of the user # than the power level of the user
# power_level = self._get_power_level_for_event(event) # power_level = self._get_power_level_for_event(event)
e_id = self.hs.parse_eventid(event.event_id)
pdu_id = e_id.localpart
origin = e_id.domain
yield self.store.update_current_state(
pdu_id=pdu_id,
origin=origin,
context=key.context,
pdu_type=key.type,
state_key=key.state_key
)
defer.returnValue(True) defer.returnValue(True)
@defer.inlineCallbacks @defer.inlineCallbacks

View File

@ -67,7 +67,6 @@ SCHEMAS = [
"keys", "keys",
"redactions", "redactions",
"state", "state",
"signatures",
"event_edges", "event_edges",
"event_signatures", "event_signatures",
] ]
@ -364,13 +363,6 @@ class DataStore(RoomMemberStore, RoomStore,
membership_state = self._get_room_member(txn, user_id, room_id) membership_state = self._get_room_member(txn, user_id, room_id)
prev_events = self._get_latest_events_in_room(txn, room_id) prev_events = self._get_latest_events_in_room(txn, room_id)
if state_type is not None and state_key is not None:
prev_state_pdu = self._get_current_state_pdu(
txn, room_id, state_type, state_key
)
else:
prev_state_pdu = None
return Snapshot( return Snapshot(
store=self, store=self,
room_id=room_id, room_id=room_id,
@ -379,7 +371,6 @@ class DataStore(RoomMemberStore, RoomStore,
membership_state=membership_state, membership_state=membership_state,
state_type=state_type, state_type=state_type,
state_key=state_key, state_key=state_key,
prev_state_pdu=prev_state_pdu,
) )
return self.runInteraction("snapshot_room", _snapshot) return self.runInteraction("snapshot_room", _snapshot)

View File

@ -1,66 +0,0 @@
/* Copyright 2014 OpenMarket Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
CREATE TABLE IF NOT EXISTS pdu_content_hashes (
pdu_id TEXT,
origin TEXT,
algorithm TEXT,
hash BLOB,
CONSTRAINT uniqueness UNIQUE (pdu_id, origin, algorithm)
);
CREATE INDEX IF NOT EXISTS pdu_content_hashes_id ON pdu_content_hashes (
pdu_id, origin
);
CREATE TABLE IF NOT EXISTS pdu_reference_hashes (
pdu_id TEXT,
origin TEXT,
algorithm TEXT,
hash BLOB,
CONSTRAINT uniqueness UNIQUE (pdu_id, origin, algorithm)
);
CREATE INDEX IF NOT EXISTS pdu_reference_hashes_id ON pdu_reference_hashes (
pdu_id, origin
);
CREATE TABLE IF NOT EXISTS pdu_origin_signatures (
pdu_id TEXT,
origin TEXT,
key_id TEXT,
signature BLOB,
CONSTRAINT uniqueness UNIQUE (pdu_id, origin, key_id)
);
CREATE INDEX IF NOT EXISTS pdu_origin_signatures_id ON pdu_origin_signatures (
pdu_id, origin
);
CREATE TABLE IF NOT EXISTS pdu_edge_hashes(
pdu_id TEXT,
origin TEXT,
prev_pdu_id TEXT,
prev_origin TEXT,
algorithm TEXT,
hash BLOB,
CONSTRAINT uniqueness UNIQUE (
pdu_id, origin, prev_pdu_id, prev_origin, algorithm
)
);
CREATE INDEX IF NOT EXISTS pdu_edge_hashes_id ON pdu_edge_hashes(
pdu_id, origin
);