2024-06-28 16:04:57 +05:30
|
|
|
{.push raises: [].}
|
2022-11-22 19:40:24 +01:00
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
import std/options, stew/results, chronos
|
|
|
|
import ../waku_core, ./common
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
const DefaultPageSize*: uint = 25
|
|
|
|
|
|
|
|
type
|
|
|
|
ArchiveDriverResult*[T] = Result[T, string]
|
|
|
|
ArchiveDriver* = ref object of RootObj
|
|
|
|
|
2024-03-12 07:51:03 -04:00
|
|
|
#TODO Once Store v2 is removed keep only messages and hashes
|
|
|
|
type ArchiveRow* = (PubsubTopic, WakuMessage, seq[byte], Timestamp, WakuMessageHash)
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
# ArchiveDriver interface
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
method put*(
|
|
|
|
driver: ArchiveDriver,
|
|
|
|
pubsubTopic: PubsubTopic,
|
|
|
|
message: WakuMessage,
|
|
|
|
digest: MessageDigest,
|
|
|
|
messageHash: WakuMessageHash,
|
|
|
|
receivedTime: Timestamp,
|
|
|
|
): Future[ArchiveDriverResult[void]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getAllMessages*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
2024-04-25 09:09:52 -04:00
|
|
|
method getMessagesV2*(
|
|
|
|
driver: ArchiveDriver,
|
|
|
|
contentTopic = newSeq[ContentTopic](0),
|
|
|
|
pubsubTopic = none(PubsubTopic),
|
|
|
|
cursor = none(ArchiveCursor),
|
|
|
|
startTime = none(Timestamp),
|
|
|
|
endTime = none(Timestamp),
|
|
|
|
maxPageSize = DefaultPageSize,
|
|
|
|
ascendingOrder = true,
|
2024-05-01 14:47:06 -04:00
|
|
|
): Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, deprecated, async.} =
|
2024-04-25 09:09:52 -04:00
|
|
|
discard
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
method getMessages*(
|
|
|
|
driver: ArchiveDriver,
|
2024-05-01 14:47:06 -04:00
|
|
|
includeData = false,
|
2024-03-16 00:08:47 +01:00
|
|
|
contentTopic = newSeq[ContentTopic](0),
|
|
|
|
pubsubTopic = none(PubsubTopic),
|
|
|
|
cursor = none(ArchiveCursor),
|
|
|
|
startTime = none(Timestamp),
|
|
|
|
endTime = none(Timestamp),
|
|
|
|
hashes = newSeq[WakuMessageHash](0),
|
|
|
|
maxPageSize = DefaultPageSize,
|
|
|
|
ascendingOrder = true,
|
|
|
|
): Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getMessagesCount*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[int64]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getPagesCount*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[int64]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getPagesSize*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[int64]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getDatabaseSize*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[int64]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method performVacuum*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[void]] {.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 decreaseDatabaseSize*(
|
|
|
|
driver: ArchiveDriver, targetSizeInBytes: int64, forceRemoval: bool = false
|
|
|
|
): Future[ArchiveDriverResult[void]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method close*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[void]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method existsTable*(
|
|
|
|
driver: ArchiveDriver, tableName: string
|
|
|
|
): Future[ArchiveDriverResult[bool]] {.base, async.} =
|
|
|
|
discard
|