2022-11-22 19:40:24 +01:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
import
|
|
|
|
std/options,
|
2023-05-25 17:34:34 +02:00
|
|
|
stew/results,
|
|
|
|
chronos
|
2022-11-22 19:40:24 +01:00
|
|
|
import
|
2023-04-19 13:29:23 +02:00
|
|
|
../waku_core,
|
2022-11-22 19:40:24 +01:00
|
|
|
./common
|
|
|
|
|
|
|
|
const DefaultPageSize*: uint = 25
|
|
|
|
|
|
|
|
type
|
|
|
|
ArchiveDriverResult*[T] = Result[T, string]
|
|
|
|
ArchiveDriver* = ref object of RootObj
|
2023-09-06 19:16:37 +02:00
|
|
|
OnErrHandler* = proc(errMsg: string) {.gcsafe, closure.}
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
type ArchiveRow* = (PubsubTopic, WakuMessage, seq[byte], Timestamp)
|
|
|
|
|
|
|
|
# ArchiveDriver interface
|
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
method put*(driver: ArchiveDriver,
|
|
|
|
pubsubTopic: PubsubTopic,
|
|
|
|
message: WakuMessage,
|
|
|
|
digest: MessageDigest,
|
|
|
|
receivedTime: Timestamp):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getAllMessages*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getMessages*(driver: ArchiveDriver,
|
|
|
|
contentTopic: seq[ContentTopic] = @[],
|
|
|
|
pubsubTopic = none(PubsubTopic),
|
|
|
|
cursor = none(ArchiveCursor),
|
|
|
|
startTime = none(Timestamp),
|
|
|
|
endTime = none(Timestamp),
|
|
|
|
maxPageSize = DefaultPageSize,
|
|
|
|
ascendingOrder = true):
|
|
|
|
Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getMessagesCount*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[int64]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getOldestMessageTimestamp*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[Timestamp]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getNewestMessageTimestamp*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[Timestamp]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method deleteMessagesOlderThanTimestamp*(driver: ArchiveDriver,
|
|
|
|
ts: Timestamp):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method deleteOldestMessagesNotWithinLimit*(driver: ArchiveDriver,
|
|
|
|
limit: int):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method close*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|