mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-15 09:26:38 +00:00
2cc86c51da
* feat: Waku Sync Protocol * feat: state machine (#2656) * feat: pruning storage mehcanism (#2673) * feat: message transfer mechanism & tests (#2688) * update docker files * added ENR filed for sync & misc. fixes * adding new sync range param & fixes --------- Co-authored-by: Ivan FB <128452529+Ivansete-status@users.noreply.github.com> Co-authored-by: Prem Chaitanya Prathi <chaitanyaprem@gmail.com>
33 lines
922 B
Nim
33 lines
922 B
Nim
{.push raises: [].}
|
|
|
|
import std/[options], chronos, libp2p/peerId
|
|
import ../waku_core
|
|
|
|
const
|
|
DefaultSyncInterval*: Duration = 5.minutes
|
|
DefaultSyncRange*: Duration = 1.hours
|
|
RetryDelay*: Duration = 30.seconds
|
|
WakuSyncCodec* = "/vac/waku/sync/1.0.0"
|
|
DefaultMaxFrameSize* = 1048576 # 1 MiB
|
|
DefaultGossipSubJitter*: Duration = 20.seconds
|
|
|
|
type
|
|
TransferCallback* = proc(
|
|
hashes: seq[WakuMessageHash], peerId: PeerId
|
|
): Future[Result[void, string]] {.async: (raises: []), closure.}
|
|
|
|
PruneCallback* = proc(
|
|
startTime: Timestamp, endTime: Timestamp, cursor = none(WakuMessageHash)
|
|
): Future[
|
|
Result[(seq[(WakuMessageHash, Timestamp)], Option[WakuMessageHash]), string]
|
|
] {.async: (raises: []), closure.}
|
|
|
|
SyncPayload* = object
|
|
syncRange*: Option[(uint64, uint64)]
|
|
|
|
frameSize*: Option[uint64]
|
|
|
|
negentropy*: seq[byte] # negentropy protocol payload
|
|
|
|
hashes*: seq[WakuMessageHash]
|