2023-03-02 10:41:41 +00:00
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
else:
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
|
|
|
|
import
|
|
|
|
std/sequtils,
|
|
|
|
stew/byteutils,
|
2023-11-22 14:23:43 +00:00
|
|
|
stew/endians2,
|
2023-03-02 10:41:41 +00:00
|
|
|
nimcrypto/sha2
|
|
|
|
import
|
2023-04-19 11:29:23 +00:00
|
|
|
../topics,
|
2023-03-02 10:41:41 +00:00
|
|
|
./message
|
|
|
|
|
|
|
|
|
|
|
|
## 14/WAKU2-MESSAGE: Deterministic message hashing
|
|
|
|
## https://rfc.vac.dev/spec/14/#deterministic-message-hashing
|
|
|
|
|
2023-11-22 16:32:56 +00:00
|
|
|
type WakuMessageHash* = array[32, byte]
|
2023-03-02 10:41:41 +00:00
|
|
|
|
|
|
|
|
2023-11-22 16:32:56 +00:00
|
|
|
converter toBytesArray*(digest: MDigest[256]): WakuMessageHash =
|
2023-03-02 10:41:41 +00:00
|
|
|
digest.data
|
|
|
|
|
|
|
|
converter toBytes*(digest: MDigest[256]): seq[byte] =
|
|
|
|
toSeq(digest.data)
|
|
|
|
|
2023-11-22 16:32:56 +00:00
|
|
|
proc computeMessageHash*(pubsubTopic: PubsubTopic, msg: WakuMessage): WakuMessageHash =
|
2023-03-02 10:41:41 +00:00
|
|
|
var ctx: sha256
|
|
|
|
ctx.init()
|
|
|
|
defer: ctx.clear()
|
|
|
|
|
|
|
|
ctx.update(pubsubTopic.toBytes())
|
|
|
|
ctx.update(msg.payload)
|
|
|
|
ctx.update(msg.contentTopic.toBytes())
|
|
|
|
ctx.update(msg.meta)
|
2023-11-22 14:23:43 +00:00
|
|
|
ctx.update(toBytesBE(uint64(msg.timestamp)))
|
2023-03-02 10:41:41 +00:00
|
|
|
|
|
|
|
return ctx.finish() # Computes the hash
|