Browse Source
A fan-out actor takes an incoming message and forwards it to a set of actors. This allows our `oracle::Actor` to be unaware, how many other actors are interested in the attestation, thus simplifying it.refactor/no-log-handler
Thomas Eizinger
3 years ago
5 changed files with 47 additions and 24 deletions
@ -0,0 +1,29 @@ |
|||||
|
use xtra::prelude::MessageChannel; |
||||
|
|
||||
|
/// A fan-out actor takes every incoming message and forwards it to a set of other actors.
|
||||
|
pub struct Actor<M: xtra::Message<Result = ()>> { |
||||
|
receivers: Vec<Box<dyn MessageChannel<M>>>, |
||||
|
} |
||||
|
|
||||
|
impl<M: xtra::Message<Result = ()>> Actor<M> { |
||||
|
pub fn new(receivers: &[&dyn MessageChannel<M>]) -> Self { |
||||
|
Self { |
||||
|
receivers: receivers.iter().map(|c| c.clone_channel()).collect(), |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
impl<M> xtra::Actor for Actor<M> where M: xtra::Message<Result = ()> {} |
||||
|
|
||||
|
#[async_trait::async_trait] |
||||
|
impl<M> xtra::Handler<M> for Actor<M> |
||||
|
where |
||||
|
M: xtra::Message<Result = ()> + Clone + Sync + 'static, |
||||
|
{ |
||||
|
async fn handle(&mut self, message: M, _: &mut xtra::Context<Self>) { |
||||
|
for receiver in &self.receivers { |
||||
|
// Not sure why here is no `do_send_async` ...
|
||||
|
let _ = receiver.do_send(message.clone()); |
||||
|
} |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue