bcb89ada5e
* fix conversion from int to string yields a string of one rune, not a string of digits * Add receipts table to syncapi * Use StreamingToken as the since value * Add required method to testEDUProducer * Make receipt json creation "easier" to read * Add receipts api to the eduserver * Add receipts endpoint * Add eduserver kafka consumer * Add missing kafka config * Add passing tests to whitelist Signed-off-by: Till Faelligen <tfaelligen@gmail.com> * Fix copy & paste error * Fix column count error * Make outbound federation receipts pass * Make "Inbound federation rejects receipts from wrong remote" pass * Don't use errors package * - Add TODO for batching requests - Rename variable * Return a better error message * - Use OutputReceiptEvent instead of InputReceiptEvent as result - Don't use the errors package for errors - Defer CloseAndLogIfError to close rows - Fix Copyright * Better creation/usage of JoinResponse * Query all joined rooms instead of just one * Update gomatrixserverlib * Add sqlite3 migration * Add postgres migration * Ensure required sequence exists before running migrations * Clarification on comment * - Fix a bug when creating client receipts - Use concrete types instead of interface{} * Remove dead code Use key for timestamp * Fix postgres query... * Remove single purpose struct * Use key/value directly * Only apply receipts on initial sync or if edu positions differ, otherwise we'll be sending the same receipts over and over again. * Actually update the id, so it is correctly send in syncs * Set receipt on request to /read_markers * Fix issue with receipts getting overwritten * Use fmt.Errorf instead of pkg/errors * Revert "Add postgres migration" This reverts commit 722fe5a04628882b787d096942459961db159b06. * Revert "Add sqlite3 migration" This reverts commit d113b03f6495a4b8f8bcf158a3d00b510b4240cc. * Fix selectRoomReceipts query * Make golangci-lint happy Co-authored-by: Neil Alexander <neilalexander@users.noreply.github.com>
104 lines
3.0 KiB
Go
104 lines
3.0 KiB
Go
package caching
|
|
|
|
import (
|
|
"strconv"
|
|
|
|
"github.com/matrix-org/dendrite/roomserver/types"
|
|
)
|
|
|
|
const (
|
|
RoomServerStateKeyNIDsCacheName = "roomserver_statekey_nids"
|
|
RoomServerStateKeyNIDsCacheMaxEntries = 1024
|
|
RoomServerStateKeyNIDsCacheMutable = false
|
|
|
|
RoomServerEventTypeNIDsCacheName = "roomserver_eventtype_nids"
|
|
RoomServerEventTypeNIDsCacheMaxEntries = 64
|
|
RoomServerEventTypeNIDsCacheMutable = false
|
|
|
|
RoomServerRoomNIDsCacheName = "roomserver_room_nids"
|
|
RoomServerRoomNIDsCacheMaxEntries = 1024
|
|
RoomServerRoomNIDsCacheMutable = false
|
|
|
|
RoomServerRoomIDsCacheName = "roomserver_room_ids"
|
|
RoomServerRoomIDsCacheMaxEntries = 1024
|
|
RoomServerRoomIDsCacheMutable = false
|
|
)
|
|
|
|
type RoomServerCaches interface {
|
|
RoomServerNIDsCache
|
|
RoomVersionCache
|
|
}
|
|
|
|
// RoomServerNIDsCache contains the subset of functions needed for
|
|
// a roomserver NID cache.
|
|
type RoomServerNIDsCache interface {
|
|
GetRoomServerStateKeyNID(stateKey string) (types.EventStateKeyNID, bool)
|
|
StoreRoomServerStateKeyNID(stateKey string, nid types.EventStateKeyNID)
|
|
|
|
GetRoomServerEventTypeNID(eventType string) (types.EventTypeNID, bool)
|
|
StoreRoomServerEventTypeNID(eventType string, nid types.EventTypeNID)
|
|
|
|
GetRoomServerRoomNID(roomID string) (types.RoomNID, bool)
|
|
StoreRoomServerRoomNID(roomID string, nid types.RoomNID)
|
|
|
|
GetRoomServerRoomID(roomNID types.RoomNID) (string, bool)
|
|
StoreRoomServerRoomID(roomNID types.RoomNID, roomID string)
|
|
}
|
|
|
|
func (c Caches) GetRoomServerStateKeyNID(stateKey string) (types.EventStateKeyNID, bool) {
|
|
val, found := c.RoomServerStateKeyNIDs.Get(stateKey)
|
|
if found && val != nil {
|
|
if stateKeyNID, ok := val.(types.EventStateKeyNID); ok {
|
|
return stateKeyNID, true
|
|
}
|
|
}
|
|
return 0, false
|
|
}
|
|
|
|
func (c Caches) StoreRoomServerStateKeyNID(stateKey string, nid types.EventStateKeyNID) {
|
|
c.RoomServerStateKeyNIDs.Set(stateKey, nid)
|
|
}
|
|
|
|
func (c Caches) GetRoomServerEventTypeNID(eventType string) (types.EventTypeNID, bool) {
|
|
val, found := c.RoomServerEventTypeNIDs.Get(eventType)
|
|
if found && val != nil {
|
|
if eventTypeNID, ok := val.(types.EventTypeNID); ok {
|
|
return eventTypeNID, true
|
|
}
|
|
}
|
|
return 0, false
|
|
}
|
|
|
|
func (c Caches) StoreRoomServerEventTypeNID(eventType string, nid types.EventTypeNID) {
|
|
c.RoomServerEventTypeNIDs.Set(eventType, nid)
|
|
}
|
|
|
|
func (c Caches) GetRoomServerRoomNID(roomID string) (types.RoomNID, bool) {
|
|
val, found := c.RoomServerRoomNIDs.Get(roomID)
|
|
if found && val != nil {
|
|
if roomNID, ok := val.(types.RoomNID); ok {
|
|
return roomNID, true
|
|
}
|
|
}
|
|
return 0, false
|
|
}
|
|
|
|
func (c Caches) StoreRoomServerRoomNID(roomID string, roomNID types.RoomNID) {
|
|
c.RoomServerRoomNIDs.Set(roomID, roomNID)
|
|
c.RoomServerRoomIDs.Set(strconv.Itoa(int(roomNID)), roomID)
|
|
}
|
|
|
|
func (c Caches) GetRoomServerRoomID(roomNID types.RoomNID) (string, bool) {
|
|
val, found := c.RoomServerRoomIDs.Get(strconv.Itoa(int(roomNID)))
|
|
if found && val != nil {
|
|
if roomID, ok := val.(string); ok {
|
|
return roomID, true
|
|
}
|
|
}
|
|
return "", false
|
|
}
|
|
|
|
func (c Caches) StoreRoomServerRoomID(roomNID types.RoomNID, roomID string) {
|
|
c.StoreRoomServerRoomNID(roomID, roomNID)
|
|
}
|