nwaku/waku/waku_sync/storage_manager.nim
Simon-Pierre Vivier 2cc86c51da
feat: Nwaku Sync (#2403)
* 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>
2024-08-13 07:27:34 -04:00

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))
]#