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,
|
2024-02-15 16:55:08 +05:30
|
|
|
../common/error_handling,
|
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-10-24 16:05:39 +02:00
|
|
|
type ArchiveRow* = (PubsubTopic, WakuMessage, seq[byte], Timestamp)
|
2022-11-22 19:40:24 +01:00
|
|
|
|
|
|
|
# ArchiveDriver interface
|
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
method put*(driver: ArchiveDriver,
|
|
|
|
pubsubTopic: PubsubTopic,
|
|
|
|
message: WakuMessage,
|
|
|
|
digest: MessageDigest,
|
2023-11-22 17:32:56 +01:00
|
|
|
messageHash: WakuMessageHash,
|
2023-05-25 17:34:34 +02:00
|
|
|
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
|
|
|
|
|
2023-10-10 11:59:09 +02:00
|
|
|
method getPagesCount*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[int64]] {.base, async.} = discard
|
|
|
|
|
|
|
|
method getPagesSize*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[int64]] {.base, async.} = discard
|
2023-11-24 15:43:47 +01:00
|
|
|
|
|
|
|
method getDatabaseSize*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[int64]] {.base, async.} = discard
|
2023-10-10 11:59:09 +02:00
|
|
|
|
|
|
|
method performVacuum*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
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
|
|
|
|
|
2024-02-22 16:55:37 +01:00
|
|
|
method decreaseDatabaseSize*(driver: ArchiveDriver,
|
2024-03-06 20:50:22 +01:00
|
|
|
targetSizeInBytes: int64,
|
|
|
|
forceRemoval: bool = false):
|
2024-02-22 16:55:37 +01:00
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
|
|
|
|
2023-05-25 17:34:34 +02:00
|
|
|
method close*(driver: ArchiveDriver):
|
|
|
|
Future[ArchiveDriverResult[void]] {.base, async.} = discard
|
2023-10-10 11:59:09 +02:00
|
|
|
|
2024-03-01 12:05:27 +01:00
|
|
|
method existsTable*(driver: ArchiveDriver, tableName: string):
|
|
|
|
Future[ArchiveDriverResult[bool]] {.base, async.} = discard
|
|
|
|
|