mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-10 06:46:24 +00:00
560f949a8b
* Add postgres_driver/migrations.nim * Postgres and archive logic adaptation to the migration implementation * libwaku: adapt node_lifecycle_request.nim to migration refactoring * test_app.nim: add more detail for test that only fails in CI * postgres migrations: store the migration scripts inside the resulting wakunode binary instead of external .sql files.
85 lines
3.2 KiB
Nim
85 lines
3.2 KiB
Nim
when (NimMajor, NimMinor) < (1, 4):
|
|
{.push raises: [Defect].}
|
|
else:
|
|
{.push raises: [].}
|
|
|
|
import
|
|
std/options,
|
|
stew/results,
|
|
chronos
|
|
import
|
|
../waku_core,
|
|
../common/error_handling,
|
|
./common
|
|
|
|
const DefaultPageSize*: uint = 25
|
|
|
|
type
|
|
ArchiveDriverResult*[T] = Result[T, string]
|
|
ArchiveDriver* = ref object of RootObj
|
|
|
|
type ArchiveRow* = (PubsubTopic, WakuMessage, seq[byte], Timestamp)
|
|
|
|
# ArchiveDriver interface
|
|
|
|
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
|
|
|
|
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 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):
|
|
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
|
|
|