mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-27 07:06:42 +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>
77 lines
2.4 KiB
Nim
77 lines
2.4 KiB
Nim
# Unused yet. Kept for future use.
|
|
#[ when (NimMajor, NimMinor) < (1, 4):
|
|
{.push raises: [Defect].}
|
|
else:
|
|
{.push raises: [].}
|
|
|
|
import std/[times, tables, options], chronicles, chronos, stew/results
|
|
|
|
import ./raw_bindings, ../waku_core/time
|
|
|
|
logScope:
|
|
topics = "waku sync"
|
|
|
|
type WakuSyncStorageManager* = ref object
|
|
storages: OrderedTable[string, Storage]
|
|
# Map of dateTime and Storage objects. DateTime is of the format YYYYMMDDHH
|
|
maxHours: int64
|
|
|
|
proc new*(
|
|
T: type WakuSyncStorageManager,
|
|
hoursToStore: times.Duration = initDuration(minutes = 120),
|
|
): T =
|
|
return WakuSyncStorageManager(maxHours: hoursToStore.inHours)
|
|
|
|
proc getRecentStorage*(self: WakuSyncStorageManager): Result[Option[Storage], string] =
|
|
if self.storages.len() == 0:
|
|
return ok(none(Storage))
|
|
var storageToFetch: Storage
|
|
#is there a more effective way to fetch last element?
|
|
for k, storage in self.storages:
|
|
storageToFetch = storage
|
|
|
|
return ok(some(storageToFetch))
|
|
|
|
proc deleteOldestStorage*(self: WakuSyncStorageManager) =
|
|
var storageToDelete: Storage
|
|
var time: string
|
|
#is there a more effective way to fetch first element?
|
|
for k, storage in self.storages:
|
|
storageToDelete = storage
|
|
time = k
|
|
break
|
|
|
|
if self.storages.pop(time, storageToDelete):
|
|
delete(storageToDelete)
|
|
|
|
proc retrieveStorage*(
|
|
self: WakuSyncStorageManager, time: Timestamp
|
|
): Result[Option[Storage], string] =
|
|
var timestamp: Timestamp
|
|
if time == 0:
|
|
timestamp = timestampInSeconds(getNowInNanosecondTime())
|
|
debug "timestamp not provided, using now to fetch storage", timestamp = timestamp
|
|
else:
|
|
timestamp = timestampInSeconds(time)
|
|
let tsTime = times.fromUnix(timestamp)
|
|
let dateTime = times.format(tsTime, "yyyyMMddHH", utc())
|
|
|
|
var storage: Storage = self.storages.getOrDefault(dateTime)
|
|
if storage == nil:
|
|
#create a new storage
|
|
# TODO: May need synchronization??
|
|
# Limit number of storages to configured duration
|
|
let hours = self.storages.len()
|
|
if hours == self.maxHours:
|
|
#Need to delete oldest storage at this point, but what if that is being synced?
|
|
self.deleteOldestStorage()
|
|
info "number of storages reached, deleting the oldest"
|
|
info "creating a new storage for ", time = dateTime
|
|
storage = Storage.new().valueOr:
|
|
error "storage creation failed"
|
|
return err(error)
|
|
self.storages[dateTime] = storage
|
|
|
|
return ok(some(storage))
|
|
]#
|