mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-16 01:45:40 +00:00
Fix topic conversion in bridge (#679)
This commit is contained in:
parent
d44eab7cd7
commit
b87984af46
@ -24,6 +24,7 @@ This release contains the following:
|
|||||||
#### API
|
#### API
|
||||||
|
|
||||||
### Fixes
|
### Fixes
|
||||||
|
- Conversion between topics for the Waku v1 <-> v2 bridge now follows the [RFC recommendation](https://rfc.vac.dev/spec/23/)
|
||||||
|
|
||||||
## 2021-06-03 v0.4
|
## 2021-06-03 v0.4
|
||||||
|
|
||||||
|
@ -50,7 +50,7 @@ procSuite "WakuBridge":
|
|||||||
v2NodeKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
v2NodeKey = crypto.PrivateKey.random(Secp256k1, rng[])[]
|
||||||
v2Node = WakuNode.new(v2NodeKey, ValidIpAddress.init("0.0.0.0"), Port(60002))
|
v2Node = WakuNode.new(v2NodeKey, ValidIpAddress.init("0.0.0.0"), Port(60002))
|
||||||
|
|
||||||
contentTopic = ContentTopic("/waku/1/1a2b3c4d/rlp")
|
contentTopic = ContentTopic("/waku/1/0x1a2b3c4d/rlp")
|
||||||
topic = [byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]
|
topic = [byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]
|
||||||
payloadV1 = "hello from V1".toBytes()
|
payloadV1 = "hello from V1".toBytes()
|
||||||
payloadV2 = "hello from V2".toBytes()
|
payloadV2 = "hello from V2".toBytes()
|
||||||
@ -74,12 +74,14 @@ procSuite "WakuBridge":
|
|||||||
# Expected cases
|
# Expected cases
|
||||||
|
|
||||||
check:
|
check:
|
||||||
toV1Topic(ContentTopic("/waku/1/00000000/rlp")) == [byte 0x00, byte 0x00, byte 0x00, byte 0x00]
|
toV1Topic(ContentTopic("/waku/1/0x00000000/rlp")) == [byte 0x00, byte 0x00, byte 0x00, byte 0x00]
|
||||||
toV2ContentTopic([byte 0x00, byte 0x00, byte 0x00, byte 0x00]) == ContentTopic("/waku/1/00000000/rlp")
|
toV2ContentTopic([byte 0x00, byte 0x00, byte 0x00, byte 0x00]) == ContentTopic("/waku/1/0x00000000/rlp")
|
||||||
toV1Topic(ContentTopic("/waku/1/ffffffff/rlp")) == [byte 0xff, byte 0xff, byte 0xff, byte 0xff]
|
toV1Topic(ContentTopic("/waku/1/0xffffffff/rlp")) == [byte 0xff, byte 0xff, byte 0xff, byte 0xff]
|
||||||
toV2ContentTopic([byte 0xff, byte 0xff, byte 0xff, byte 0xff]) == ContentTopic("/waku/1/ffffffff/rlp")
|
toV2ContentTopic([byte 0xff, byte 0xff, byte 0xff, byte 0xff]) == ContentTopic("/waku/1/0xffffffff/rlp")
|
||||||
|
toV1Topic(ContentTopic("/waku/1/0x1a2b3c4d/rlp")) == [byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]
|
||||||
|
toV2ContentTopic([byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]) == ContentTopic("/waku/1/0x1a2b3c4d/rlp")
|
||||||
|
# Topic conversion should still work where '0x' prefix is omitted from <v1 topic byte array>
|
||||||
toV1Topic(ContentTopic("/waku/1/1a2b3c4d/rlp")) == [byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]
|
toV1Topic(ContentTopic("/waku/1/1a2b3c4d/rlp")) == [byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]
|
||||||
toV2ContentTopic([byte 0x1a, byte 0x2b, byte 0x3c, byte 0x4d]) == ContentTopic("/waku/1/1a2b3c4d/rlp")
|
|
||||||
|
|
||||||
# Invalid cases
|
# Invalid cases
|
||||||
|
|
||||||
@ -89,7 +91,7 @@ procSuite "WakuBridge":
|
|||||||
|
|
||||||
expect ValueError:
|
expect ValueError:
|
||||||
# Content topic name too short
|
# Content topic name too short
|
||||||
discard toV1Topic(ContentTopic("/waku/1/112233/rlp"))
|
discard toV1Topic(ContentTopic("/waku/1/0x112233/rlp"))
|
||||||
|
|
||||||
expect ValueError:
|
expect ValueError:
|
||||||
# Content topic name not hex
|
# Content topic name not hex
|
||||||
|
@ -66,12 +66,14 @@ proc containsOrAdd(sequence: var seq[hashes.Hash], hash: hashes.Hash): bool =
|
|||||||
proc toV2ContentTopic*(v1Topic: waku_protocol.Topic): ContentTopic =
|
proc toV2ContentTopic*(v1Topic: waku_protocol.Topic): ContentTopic =
|
||||||
## Convert a 4-byte array v1 topic to a namespaced content topic
|
## Convert a 4-byte array v1 topic to a namespaced content topic
|
||||||
## with format `/waku/1/<v1-topic-bytes-as-hex>/proto`
|
## with format `/waku/1/<v1-topic-bytes-as-hex>/proto`
|
||||||
|
##
|
||||||
|
## <v1-topic-bytes-as-hex> should be prefixed with `0x`
|
||||||
|
|
||||||
var namespacedTopic = NamespacedTopic()
|
var namespacedTopic = NamespacedTopic()
|
||||||
|
|
||||||
namespacedTopic.application = "waku"
|
namespacedTopic.application = "waku"
|
||||||
namespacedTopic.version = "1"
|
namespacedTopic.version = "1"
|
||||||
namespacedTopic.topicName = v1Topic.toHex()
|
namespacedTopic.topicName = "0x" & v1Topic.toHex()
|
||||||
namespacedTopic.encoding = "rlp"
|
namespacedTopic.encoding = "rlp"
|
||||||
|
|
||||||
return ContentTopic($namespacedTopic)
|
return ContentTopic($namespacedTopic)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user