2021-07-14 19:58:46 +02:00
|
|
|
{.push raises: [Defect].}
|
|
|
|
|
|
2021-01-22 11:39:16 +02:00
|
|
|
import
|
2021-11-03 11:59:51 +01:00
|
|
|
std/options,
|
2021-01-22 11:39:16 +02:00
|
|
|
stew/results,
|
2021-03-25 10:37:11 +02:00
|
|
|
../../../protocol/waku_message,
|
|
|
|
|
../../../utils/pagination
|
2021-01-22 11:39:16 +02:00
|
|
|
|
|
|
|
|
## This module defines a message store interface. Implementations of
|
2021-04-27 16:52:24 -07:00
|
|
|
## MessageStore are used by the `WakuStore` protocol to store and
|
|
|
|
|
## retrieve historical messages
|
2021-01-22 11:39:16 +02:00
|
|
|
|
|
|
|
|
type
|
2021-07-14 19:58:46 +02:00
|
|
|
DataProc* = proc(receiverTimestamp: float64, msg: WakuMessage, pubsubTopic: string) {.closure, raises: [Defect].}
|
2021-01-22 11:39:16 +02:00
|
|
|
|
|
|
|
|
MessageStoreResult*[T] = Result[T, string]
|
|
|
|
|
|
|
|
|
|
MessageStore* = ref object of RootObj
|
|
|
|
|
|
|
|
|
|
# MessageStore interface
|
2021-04-27 16:52:24 -07:00
|
|
|
method put*(db: MessageStore, cursor: Index, message: WakuMessage, pubsubTopic: string): MessageStoreResult[void] {.base.} = discard
|
2021-11-03 11:59:51 +01:00
|
|
|
method getAll*(db: MessageStore, onData: DataProc, limit = none(int)): MessageStoreResult[bool] {.base.} = discard
|
2021-04-27 16:52:24 -07:00
|
|
|
|