2024-06-28 10:34:57 +00:00
|
|
|
{.push raises: [].}
|
2022-11-22 18:40:24 +00:00
|
|
|
|
2024-07-09 11:14:28 +00:00
|
|
|
import std/options, results, chronos
|
2024-03-15 23:08:47 +00:00
|
|
|
import ../waku_core, ./common
|
2022-11-22 18:40:24 +00:00
|
|
|
|
|
|
|
const DefaultPageSize*: uint = 25
|
|
|
|
|
|
|
|
type
|
|
|
|
ArchiveDriverResult*[T] = Result[T, string]
|
|
|
|
ArchiveDriver* = ref object of RootObj
|
|
|
|
|
2024-07-12 16:19:12 +00:00
|
|
|
type ArchiveRow* = (WakuMessageHash, PubsubTopic, WakuMessage)
|
2022-11-22 18:40:24 +00:00
|
|
|
|
|
|
|
# ArchiveDriver interface
|
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
method put*(
|
|
|
|
driver: ArchiveDriver,
|
2024-07-12 16:19:12 +00:00
|
|
|
messageHash: WakuMessageHash,
|
2024-03-15 23:08:47 +00:00
|
|
|
pubsubTopic: PubsubTopic,
|
|
|
|
message: WakuMessage,
|
|
|
|
): Future[ArchiveDriverResult[void]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getAllMessages*(
|
|
|
|
driver: ArchiveDriver
|
|
|
|
): Future[ArchiveDriverResult[seq[ArchiveRow]]] {.base, async.} =
|
|
|
|
discard
|
|
|
|
|
|
|
|
method getMessages*(
|
|
|
|
driver: ArchiveDriver,
|
2024-07-12 16:19:12 +00:00
|
|
|
includeData = true,
|
|
|
|
contentTopics = newSeq[ContentTopic](0),
|
2024-03-15 23:08:47 +00:00
|
|
|
pubsubTopic = none(PubsubTopic),
|
|
|
|
cursor = none(ArchiveCursor),
|
|
|
|
startTime = none(Timestamp),
|
|
|
|
endTime = none(Timestamp),
|
|
|
|
hashes = newSeq[WakuMessageHash](0),
|
|
|
|
maxPageSize = DefaultPageSize,
|
|
|
|
ascendingOrder = true,
|
2024-08-29 20:56:14 +00:00
|
|
|
requestId = "",
|
2024-03-15 23:08:47 +00:00
|
|
|
): 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
|