70 lines
1.8 KiB
Nim
Raw Permalink Normal View History

2025-02-11 14:02:30 +01:00
import pkg/chronicles
import pkg/chronos
import pkg/questionable
import pkg/questionable/results
import ../list
import ../state
2025-02-12 13:25:37 +01:00
import ../services/metrics
2025-02-11 14:02:30 +01:00
import ../component
import ../utils/asyncdataevent
logScope:
topics = "dhtmetrics"
type DhtMetrics* = ref object of Component
state: State
ok: List
nok: List
2025-02-11 14:29:41 +01:00
sub: AsyncDataEventSubscription
metrics: Metrics
proc handleCheckEvent(
d: DhtMetrics, event: DhtNodeCheckEventData
): Future[?!void] {.async.} =
if event.isOk:
?await d.ok.add(event.id)
?await d.nok.remove(event.id)
else:
?await d.ok.remove(event.id)
?await d.nok.add(event.id)
d.metrics.setOkNodes(d.ok.len)
d.metrics.setNokNodes(d.nok.len)
return success()
2025-02-11 14:02:30 +01:00
method start*(d: DhtMetrics): Future[?!void] {.async.} =
2025-02-12 14:12:21 +01:00
info "Starting..."
2025-02-11 14:29:41 +01:00
?await d.ok.load()
?await d.nok.load()
proc onCheck(event: DhtNodeCheckEventData): Future[?!void] {.async.} =
await d.handleCheckEvent(event)
d.sub = d.state.events.dhtNodeCheck.subscribe(onCheck)
2025-02-12 14:43:12 +01:00
proc logDhtMetrics(): Future[?!void] {.async: (raises: []), gcsafe.} =
trace "Metrics", ok = d.ok.len, nok = d.nok.len
return success()
await d.state.whileRunning(logDhtMetrics, 1.minutes)
2025-02-11 14:02:30 +01:00
return success()
method stop*(d: DhtMetrics): Future[?!void] {.async.} =
2025-02-11 14:29:41 +01:00
await d.state.events.dhtNodeCheck.unsubscribe(d.sub)
2025-02-11 14:02:30 +01:00
return success()
proc new*(
2025-02-11 14:29:41 +01:00
T: type DhtMetrics, state: State, okList: List, nokList: List, metrics: Metrics
2025-02-11 14:02:30 +01:00
): DhtMetrics =
2025-02-11 14:29:41 +01:00
DhtMetrics(state: state, ok: okList, nok: nokList, metrics: metrics)
2025-02-11 14:02:30 +01:00
2025-02-11 14:29:41 +01:00
proc createDhtMetrics*(state: State, metrics: Metrics): ?!DhtMetrics =
2025-02-11 14:02:30 +01:00
without okList =? createList(state.config.dataDir, "dhtok"), err:
return failure(err)
without nokList =? createList(state.config.dataDir, "dhtnok"), err:
return failure(err)
2025-02-11 14:29:41 +01:00
success(DhtMetrics.new(state, okList, nokList, metrics))