mirror of
https://github.com/logos-messaging/logos-messaging-nim.git
synced 2026-02-14 02:43:12 +00:00
* Fix protocol strength metric to consider connected peers only * Remove polling loop; event-driven node connection health updates * Remove 10s WakuRelay topic health polling loop; now event-driven * Change NodeHealthStatus to ConnectionStatus * Change new nodeState (rest API /health) field to connectionStatus * Add getSyncProtocolHealthInfo and getSyncNodeHealthReport * Add ConnectionStatusChangeEvent * Add RequestHealthReport * Refactor sync/async protocol health queries in the health monitor * Add EventRelayTopicHealthChange * Add EventWakuPeer emitted by PeerManager * Add Edge support for topics health requests and events * Rename "RelayTopic" -> "Topic" * Add RequestContentTopicsHealth sync request * Add EventContentTopicHealthChange * Rename RequestTopicsHealth -> RequestShardTopicsHealth * Remove health check gating from checkApiAvailability * Add basic health smoke tests * Other misc improvements, refactors, fixes Co-authored-by: NagyZoltanPeter <113987313+NagyZoltanPeter@users.noreply.github.com> Co-authored-by: Ivan FB <128452529+Ivansete-status@users.noreply.github.com>
66 lines
1.8 KiB
Nim
66 lines
1.8 KiB
Nim
{.push raises: [].}
|
|
|
|
import bearssl/rand, std/times, chronos
|
|
import stew/byteutils
|
|
import waku/utils/requests as request_utils
|
|
import waku/waku_core/[topics/content_topic, message/message, time]
|
|
import waku/requests/requests
|
|
|
|
type
|
|
MessageEnvelope* = object
|
|
contentTopic*: ContentTopic
|
|
payload*: seq[byte]
|
|
ephemeral*: bool
|
|
|
|
RequestId* = distinct string
|
|
|
|
ConnectionStatus* {.pure.} = enum
|
|
Disconnected
|
|
PartiallyConnected
|
|
Connected
|
|
|
|
proc new*(T: typedesc[RequestId], rng: ref HmacDrbgContext): T =
|
|
## Generate a new RequestId using the provided RNG.
|
|
RequestId(request_utils.generateRequestId(rng))
|
|
|
|
proc `$`*(r: RequestId): string {.inline.} =
|
|
string(r)
|
|
|
|
proc `==`*(a, b: RequestId): bool {.inline.} =
|
|
string(a) == string(b)
|
|
|
|
proc init*(
|
|
T: type MessageEnvelope,
|
|
contentTopic: ContentTopic,
|
|
payload: seq[byte] | string,
|
|
ephemeral: bool = false,
|
|
): MessageEnvelope =
|
|
when payload is seq[byte]:
|
|
MessageEnvelope(contentTopic: contentTopic, payload: payload, ephemeral: ephemeral)
|
|
else:
|
|
MessageEnvelope(
|
|
contentTopic: contentTopic, payload: payload.toBytes(), ephemeral: ephemeral
|
|
)
|
|
|
|
proc toWakuMessage*(envelope: MessageEnvelope): WakuMessage =
|
|
## Convert a MessageEnvelope to a WakuMessage.
|
|
var wm = WakuMessage(
|
|
contentTopic: envelope.contentTopic,
|
|
payload: envelope.payload,
|
|
ephemeral: envelope.ephemeral,
|
|
timestamp: getNowInNanosecondTime(),
|
|
)
|
|
|
|
## TODO: First find out if proof is needed at all
|
|
## Follow up: left it to the send logic to add RLN proof if needed and possible
|
|
# let requestedProof = (
|
|
# waitFor RequestGenerateRlnProof.request(wm, getTime().toUnixFloat())
|
|
# ).valueOr:
|
|
# warn "Failed to add RLN proof to WakuMessage: ", error = error
|
|
# return wm
|
|
|
|
# wm.proof = requestedProof.proof
|
|
return wm
|
|
|
|
{.pop.}
|