aboutsummaryrefslogtreecommitdiff
path: root/roomserver
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2020-12-04 10:41:07 +0000
committerGitHub <noreply@github.com>2020-12-04 10:41:07 +0000
commit1ce9c524420bc6a7b08748ca736284382581ab56 (patch)
tree099e40612e2dc731a7e4d5a99daab8c12bc4d94a /roomserver
parent19b1d40d6479ac73cf4073c23f9ee291e3d5d112 (diff)
Don't recalculate event IDs so often (#1610)
* Don't recalculate event IDs so often * Revert invite change * Make sure we're using the right NIDs * Update gomatrixserverlib * Update to NewEventFromTrustedJSONWithEventID * Fix go.mod * Update gomatrixserverlib to matrix-org/gomatrixserverlib#243 * Use BulkSelectEventID
Diffstat (limited to 'roomserver')
-rw-r--r--roomserver/storage/shared/storage.go28
1 files changed, 23 insertions, 5 deletions
diff --git a/roomserver/storage/shared/storage.go b/roomserver/storage/shared/storage.go
index 2548980d..83982299 100644
--- a/roomserver/storage/shared/storage.go
+++ b/roomserver/storage/shared/storage.go
@@ -309,6 +309,10 @@ func (d *Database) Events(
if err != nil {
return nil, err
}
+ eventIDs, _ := d.EventsTable.BulkSelectEventID(ctx, eventNIDs)
+ if err != nil {
+ eventIDs = map[types.EventNID]string{}
+ }
results := make([]types.Event, len(eventJSONs))
for i, eventJSON := range eventJSONs {
var roomNID types.RoomNID
@@ -328,8 +332,8 @@ func (d *Database) Events(
return nil, err
}
}
- result.Event, err = gomatrixserverlib.NewEventFromTrustedJSON(
- eventJSON.EventJSON, false, roomVersion,
+ result.Event, err = gomatrixserverlib.NewEventFromTrustedJSONWithEventID(
+ eventIDs[eventJSON.EventNID], eventJSON.EventJSON, false, roomVersion,
)
if err != nil {
return nil, err
@@ -779,6 +783,7 @@ func (d *Database) loadEvent(ctx context.Context, eventID string) *types.Event {
// GetStateEvent returns the current state event of a given type for a given room with a given state key
// If no event could be found, returns nil
// If there was an issue during the retrieval, returns an error
+// nolint:gocyclo
func (d *Database) GetStateEvent(ctx context.Context, roomID, evType, stateKey string) (*gomatrixserverlib.HeaderedEvent, error) {
roomInfo, err := d.RoomInfo(ctx, roomID)
if err != nil {
@@ -800,6 +805,16 @@ func (d *Database) GetStateEvent(ctx context.Context, roomID, evType, stateKey s
if err != nil {
return nil, err
}
+ var eventNIDs []types.EventNID
+ for _, e := range entries {
+ if e.EventTypeNID == eventTypeNID && e.EventStateKeyNID == stateKeyNID {
+ eventNIDs = append(eventNIDs, e.EventNID)
+ }
+ }
+ eventIDs, _ := d.EventsTable.BulkSelectEventID(ctx, eventNIDs)
+ if err != nil {
+ eventIDs = map[types.EventNID]string{}
+ }
// return the event requested
for _, e := range entries {
if e.EventTypeNID == eventTypeNID && e.EventStateKeyNID == stateKeyNID {
@@ -810,7 +825,7 @@ func (d *Database) GetStateEvent(ctx context.Context, roomID, evType, stateKey s
if len(data) == 0 {
return nil, fmt.Errorf("GetStateEvent: no json for event nid %d", e.EventNID)
}
- ev, err := gomatrixserverlib.NewEventFromTrustedJSON(data[0].EventJSON, false, roomInfo.RoomVersion)
+ ev, err := gomatrixserverlib.NewEventFromTrustedJSONWithEventID(eventIDs[e.EventNID], data[0].EventJSON, false, roomInfo.RoomVersion)
if err != nil {
return nil, err
}
@@ -921,7 +936,10 @@ func (d *Database) GetBulkStateContent(ctx context.Context, roomIDs []string, tu
}
}
}
-
+ eventIDs, _ := d.EventsTable.BulkSelectEventID(ctx, eventNIDs)
+ if err != nil {
+ eventIDs = map[types.EventNID]string{}
+ }
events, err := d.EventJSONTable.BulkSelectEventJSON(ctx, eventNIDs)
if err != nil {
return nil, fmt.Errorf("GetBulkStateContent: failed to load event JSON for event nids: %w", err)
@@ -929,7 +947,7 @@ func (d *Database) GetBulkStateContent(ctx context.Context, roomIDs []string, tu
result := make([]tables.StrippedEvent, len(events))
for i := range events {
roomVer := eventNIDToVer[events[i].EventNID]
- ev, err := gomatrixserverlib.NewEventFromTrustedJSON(events[i].EventJSON, false, roomVer)
+ ev, err := gomatrixserverlib.NewEventFromTrustedJSONWithEventID(eventIDs[events[i].EventNID], events[i].EventJSON, false, roomVer)
if err != nil {
return nil, fmt.Errorf("GetBulkStateContent: failed to load event JSON for event NID %v : %w", events[i].EventNID, err)
}