49 lines
1.6 KiB
Rust
Raw Normal View History

//! Waku message [event](https://rfc.vac.dev/spec/36/#events) related items
//!
//! Asynchronous events require a callback to be registered.
//! An example of an asynchronous event that might be emitted is receiving a message.
2024-02-14 16:52:21 -04:00
//! When an event is emitted, this callback will be triggered receiving an [`Event`]
// crates
use serde::{Deserialize, Serialize};
// internal
2024-02-14 16:52:21 -04:00
use crate::general::WakuMessage;
use std::str;
use crate::MessageHash;
/// Waku event
/// For now just WakuMessage is supported
#[non_exhaustive]
#[derive(Serialize, Deserialize, Debug)]
2024-02-14 16:52:21 -04:00
#[serde(tag = "eventType", rename_all = "camelCase")]
pub enum Event {
2024-02-14 16:52:21 -04:00
#[serde(rename = "message")]
WakuMessage(WakuMessageEvent),
Unrecognized(serde_json::Value),
}
/// Type of `event` field for a `message` event
#[derive(Serialize, Deserialize, Debug)]
#[serde(rename_all = "camelCase")]
pub struct WakuMessageEvent {
/// The pubsub topic on which the message was received
2024-02-22 10:57:02 -04:00
pub pubsub_topic: String,
/// The message hash
pub message_hash: MessageHash,
/// The message in [`WakuMessage`] format
2024-02-22 10:57:02 -04:00
pub waku_message: WakuMessage,
}
#[cfg(test)]
mod tests {
2024-02-14 16:52:21 -04:00
use crate::Event;
#[test]
2024-02-14 16:52:21 -04:00
fn deserialize_message_event() {
let s = "{\"eventType\":\"message\",\"messageHash\":\"0x26ff3d7fbc950ea2158ce62fd76fd745eee0323c9eac23d0713843b0f04ea27c\",\"pubsubTopic\":\"/waku/2/default-waku/proto\",\"wakuMessage\":{\"payload\":\"SGkgZnJvbSDwn6aAIQ==\",\"contentTopic\":\"/toychat/2/huilong/proto\",\"timestamp\":1665580926660}}";
2024-02-14 16:52:21 -04:00
let evt: Event = serde_json::from_str(s).unwrap();
assert!(matches!(evt, Event::WakuMessage(_)));
}
}