feat(rest): add support to ephemeral field (#2525)

This commit is contained in:
richΛrd 2024-03-13 08:49:21 -04:00 committed by GitHub
parent 5a225809cd
commit c734f60d06
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 32 additions and 12 deletions

View File

@ -155,17 +155,17 @@ suite "Waku v2 Rest API - Relay":
var messages = @[
fakeWakuMessage(contentTopic = "content-topic-x", payload = toBytes("TEST-1"),
meta = toBytes("test-meta") )
meta = toBytes("test-meta"), ephemeral = true)
]
# Prevent duplicate messages
for i in 0..<2:
var msg = fakeWakuMessage(contentTopic = "content-topic-x", payload = toBytes("TEST-1"),
meta = toBytes("test-meta"))
meta = toBytes("test-meta"), ephemeral = true)
while msg == messages[i]:
msg = fakeWakuMessage(contentTopic = "content-topic-x", payload = toBytes("TEST-1"),
meta = toBytes("test-meta"))
meta = toBytes("test-meta"), ephemeral = true)
messages.add(msg)
@ -192,7 +192,8 @@ suite "Waku v2 Rest API - Relay":
msg.contentTopic.get() == "content-topic-x" and
msg.version.get() == 2 and
msg.timestamp.get() != Timestamp(0) and
msg.meta.get() == base64.encode("test-meta")
msg.meta.get() == base64.encode("test-meta") and
msg.ephemeral.get() == true
check:
cache.isPubsubSubscribed(pubSubTopic)

View File

@ -42,7 +42,8 @@ suite "Waku v2 Rest API - Relay - serialization":
payload: payload,
contentTopic: none(ContentTopic),
version: none(Natural),
timestamp: none(int64)
timestamp: none(int64),
ephemeral: none(bool)
)
# When

View File

@ -23,6 +23,7 @@ type FilterWakuMessage* = object
version*: Option[Natural]
timestamp*: Option[int64]
meta*: Option[Base64String]
ephemeral*: Option[bool]
type FilterGetMessagesResponse* = seq[FilterWakuMessage]
@ -60,7 +61,8 @@ proc toFilterWakuMessage*(msg: WakuMessage): FilterWakuMessage =
contentTopic: some(msg.contentTopic),
version: some(Natural(msg.version)),
timestamp: some(msg.timestamp),
meta: if msg.meta.len > 0: some(base64.encode(msg.meta)) else: none(Base64String)
meta: if msg.meta.len > 0: some(base64.encode(msg.meta)) else: none(Base64String),
ephemeral: some(msg.ephemeral)
)
proc toWakuMessage*(msg: FilterWakuMessage, version = 0): Result[WakuMessage, string] =
@ -70,9 +72,10 @@ proc toWakuMessage*(msg: FilterWakuMessage, version = 0): Result[WakuMessage, st
version = uint32(msg.version.get(version))
timestamp = msg.timestamp.get(0)
meta = ?msg.meta.get(Base64String("")).decode()
ephemeral = msg.ephemeral.get(false)
ok(WakuMessage(payload: payload, contentTopic: contentTopic, version: version,
timestamp: timestamp, meta: meta))
timestamp: timestamp, meta: meta, ephemeral: ephemeral))
#### Serialization and deserialization
@ -88,6 +91,8 @@ proc writeValue*(writer: var JsonWriter[RestJson], value: FilterWakuMessage)
writer.writeField("timestamp", value.timestamp.get())
if value.meta.isSome():
writer.writeField("meta", value.meta.get())
if value.ephemeral.isSome():
writer.writeField("ephemeral", value.ephemeral.get())
writer.endRecord()
proc writeValue*(writer: var JsonWriter, value: FilterLegacySubscribeRequest)
@ -143,6 +148,7 @@ proc readValue*(reader: var JsonReader[RestJson], value: var FilterWakuMessage)
version = none(Natural)
timestamp = none(int64)
meta = none(Base64String)
ephemeral = none(bool)
var keys = initHashSet[string]()
for fieldName in readObjectFields(reader):
@ -163,6 +169,8 @@ proc readValue*(reader: var JsonReader[RestJson], value: var FilterWakuMessage)
timestamp = some(reader.readValue(int64))
of "meta":
meta = some(reader.readValue(Base64String))
of "ephemeral":
ephemeral = some(reader.readValue(bool))
else:
unrecognizedFieldWarning()
@ -174,7 +182,8 @@ proc readValue*(reader: var JsonReader[RestJson], value: var FilterWakuMessage)
contentTopic: contentTopic,
version: version,
timestamp: timestamp,
meta: meta
meta: meta,
ephemeral: ephemeral,
)
proc readValue*(reader: var JsonReader[RestJson], value: var FilterLegacySubscribeRequest)

View File

@ -23,6 +23,7 @@ type RelayWakuMessage* = object
version*: Option[Natural]
timestamp*: Option[int64]
meta*: Option[Base64String]
ephemeral*: Option[bool]
type
RelayGetMessagesResponse* = seq[RelayWakuMessage]
@ -36,7 +37,8 @@ proc toRelayWakuMessage*(msg: WakuMessage): RelayWakuMessage =
contentTopic: some(msg.contentTopic),
version: some(Natural(msg.version)),
timestamp: some(msg.timestamp),
meta: if msg.meta.len > 0: some(base64.encode(msg.meta)) else: none(Base64String)
meta: if msg.meta.len > 0: some(base64.encode(msg.meta)) else: none(Base64String),
ephemeral: some(msg.ephemeral)
)
proc toWakuMessage*(msg: RelayWakuMessage, version = 0): Result[WakuMessage, string] =
@ -45,6 +47,7 @@ proc toWakuMessage*(msg: RelayWakuMessage, version = 0): Result[WakuMessage, str
contentTopic = msg.contentTopic.get(DefaultContentTopic)
version = uint32(msg.version.get(version))
meta = ?msg.meta.get(Base64String("")).decode()
ephemeral = msg.ephemeral.get(false)
var timestamp = msg.timestamp.get(0)
@ -52,7 +55,7 @@ proc toWakuMessage*(msg: RelayWakuMessage, version = 0): Result[WakuMessage, str
timestamp = getNanosecondTime(getTime().toUnixFloat())
return ok(WakuMessage(payload: payload, contentTopic: contentTopic, version: version,
timestamp: timestamp, meta: meta))
timestamp: timestamp, meta: meta, ephemeral: ephemeral))
#### Serialization and deserialization
@ -68,6 +71,8 @@ proc writeValue*(writer: var JsonWriter[RestJson], value: RelayWakuMessage)
writer.writeField("timestamp", value.timestamp.get())
if value.meta.isSome():
writer.writeField("meta", value.meta.get())
if value.ephemeral.isSome():
writer.writeField("ephemeral", value.ephemeral.get())
writer.endRecord()
proc readValue*(reader: var JsonReader[RestJson], value: var RelayWakuMessage)
@ -78,6 +83,7 @@ proc readValue*(reader: var JsonReader[RestJson], value: var RelayWakuMessage)
version = none(Natural)
timestamp = none(int64)
meta = none(Base64String)
ephemeral = none(bool)
var keys = initHashSet[string]()
for fieldName in readObjectFields(reader):
@ -98,6 +104,8 @@ proc readValue*(reader: var JsonReader[RestJson], value: var RelayWakuMessage)
timestamp = some(reader.readValue(int64))
of "meta":
meta = some(reader.readValue(Base64String))
of "ephemeral":
ephemeral = some(reader.readValue(bool))
else:
unrecognizedFieldWarning()
@ -112,5 +120,6 @@ proc readValue*(reader: var JsonReader[RestJson], value: var RelayWakuMessage)
contentTopic: contentTopic,
version: version,
timestamp: timestamp,
meta: meta
meta: meta,
ephemeral: ephemeral
)