mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-08 11:59:55 +00:00
40b7bc59d0
Prevents one Processor's message from halting the entire pipeline.
42 lines
1.2 KiB
Rust
42 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 {
|
|
let msg = self.next(Service::Coordinator).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, Service::Coordinator, msg.id).await
|
|
}
|
|
}
|