use crate::authenticated::{discovery::types, Mailbox};
use commonware_cryptography::PublicKey;
use commonware_utils::channel::fallible::AsyncFallibleExt;
#[derive(Clone, Debug)]
pub enum Message<C: PublicKey> {
BitVec(types::BitVec),
Peers(Vec<types::Info<C>>),
Kill,
}
impl<C: PublicKey> Mailbox<Message<C>> {
pub async fn bit_vec(&mut self, bit_vec: types::BitVec) {
self.0.send_lossy(Message::BitVec(bit_vec)).await;
}
pub async fn peers(&mut self, peers: Vec<types::Info<C>>) {
self.0.send_lossy(Message::Peers(peers)).await;
}
pub async fn kill(&mut self) {
self.0.send_lossy(Message::Kill).await;
}
}