2023-02-27 14:38:24 +00:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
import
|
|
|
|
stew/results,
|
|
|
|
nimcrypto/sha2,
|
|
|
|
libp2p/protocols/pubsub,
|
|
|
|
libp2p/protocols/pubsub/rpc/messages
|
|
|
|
|
|
|
|
## Message ID provider
|
|
|
|
|
|
|
|
type MessageIdProvider* = pubsub.MsgIdProvider
|
|
|
|
|
|
|
|
## Default message ID provider
|
|
|
|
# Performs a sha256 digest on the Waku Relay message payload. As Protocol Buffers v3
|
|
|
|
# deterministic serialization is not canonical between the different languages and
|
|
|
|
# implementations.
|
|
|
|
#
|
|
|
|
# See: https://gist.github.com/kchristidis/39c8b310fd9da43d515c4394c3cd9510
|
|
|
|
#
|
|
|
|
# This lack of deterministic serializaion could lead to a situation where two
|
|
|
|
# messages with the same attributes and serialized by different implementations
|
|
|
|
# have a different message ID (hash). This can impact the performance of the
|
|
|
|
# Waku Relay (Gossipsub) protocol's message cache and the gossiping process, and
|
|
|
|
# as a consequence the network.
|
|
|
|
|
2024-03-15 23:08:47 +00:00
|
|
|
proc defaultMessageIdProvider*(
|
|
|
|
message: messages.Message
|
|
|
|
): Result[MessageID, ValidationResult] =
|
2023-02-27 14:38:24 +00:00
|
|
|
let hash = sha256.digest(message.data)
|
|
|
|
ok(@(hash.data))
|
|
|
|
|
|
|
|
## Waku message Unique ID provider
|
|
|
|
# TODO: Add here the MUID provider once `meta` field RFC PR is merged
|