mirror of
https://github.com/serai-dex/serai.git
synced 2025-12-09 20:59:23 +00:00
44 lines
1.2 KiB
Rust
44 lines
1.2 KiB
Rust
use messages::{ProcessorMessage, CoordinatorMessage};
|
|
|
|
use message_queue::{Service, Metadata, client::MessageQueue};
|
|
|
|
#[derive(Clone, PartialEq, Eq, Debug)]
|
|
pub struct Message {
|
|
pub id: u64,
|
|
pub msg: CoordinatorMessage,
|
|
}
|
|
|
|
#[async_trait::async_trait]
|
|
pub trait Coordinator {
|
|
async fn send(&mut self, msg: ProcessorMessage);
|
|
async fn recv(&mut self) -> Message;
|
|
async fn ack(&mut self, msg: Message);
|
|
}
|
|
|
|
#[async_trait::async_trait]
|
|
impl Coordinator for MessageQueue {
|
|
async fn send(&mut self, msg: ProcessorMessage) {
|
|
let metadata = Metadata { from: self.service, to: Service::Coordinator, intent: msg.intent() };
|
|
let msg = serde_json::to_string(&msg).unwrap();
|
|
|
|
self.queue(metadata, msg.into_bytes()).await;
|
|
}
|
|
|
|
async fn recv(&mut self) -> Message {
|
|
// TODO: Use a proper expected next ID
|
|
let msg = self.next(0).await;
|
|
|
|
let id = msg.id;
|
|
|
|
// Deserialize it into a CoordinatorMessage
|
|
let msg: CoordinatorMessage =
|
|
serde_json::from_slice(&msg.msg).expect("message wasn't a JSON-encoded CoordinatorMessage");
|
|
|
|
return Message { id, msg };
|
|
}
|
|
|
|
async fn ack(&mut self, msg: Message) {
|
|
MessageQueue::ack(self, msg.id).await
|
|
}
|
|
}
|