sat-rs/fsrc-core/src/event_man.rs

443 lines
17 KiB
Rust
Raw Normal View History

2022-10-26 00:23:10 +02:00
//! Event management and forwarding
2022-10-28 02:02:28 +02:00
//!
//! This module provides components to perform event routing. The most important component for this
//! task is the [EventManager]. It has a map of event listeners and uses a dynamic [EventReceiver]
//! instance to receive all events and then route them to event subscribers where appropriate.
//!
//! One common use case for satellite systems is to offer a light-weight publish-subscribe mechanism
//! and IPC mechanism for software and hardware events which are also packaged as telemetry.
//! This can be done with the [EventManager] like this:
//!
//! 1. Provide a concrete [SendEventProvider] implementation and a concrete [EventReceiver]
//! implementation. These abstraction allow to use different message queue backends.
//! A straightforward implementation where dynamic memory allocation is not a big concern could
//! use [std::sync::mpsc::channel] to do this. It is recommended that these implementations
//! derive [Clone].
//! 2. Each event creator gets a sender component which allows it to send events to the manager.
//! 3. The event manager receives all receiver ends so all events are routed to the
//! manager.
//! 4. Each event receiver and/or subscriber gets a receiver component. The sender component is
//! used with the [SendEventProvider] trait and the subscription API provided by the
2022-10-29 01:10:51 +02:00
//! [EventManager] to subscribe for individual events, whole group of events or all events
//!
//! Some components like a PUS Event Service or PUS Event Action Service might require all
//! events to package them as telemetry or start actions where applicable.
//! Other components might only be interested in certain events. For example, a thermal system
//! handler might only be interested in temperature events generated by a thermal sensor component.
2022-10-28 02:02:28 +02:00
use crate::events::{GenericEvent, LargestEventRaw, LargestGroupIdRaw};
2022-08-20 23:21:36 +02:00
use alloc::boxed::Box;
use alloc::vec;
use alloc::vec::Vec;
use hashbrown::HashMap;
2022-06-10 18:10:40 +02:00
#[derive(PartialEq, Eq, Hash, Copy, Clone)]
enum ListenerType {
2022-10-28 02:02:28 +02:00
Single(LargestEventRaw),
Group(LargestGroupIdRaw),
All,
2022-06-10 18:10:40 +02:00
}
2022-10-28 02:02:28 +02:00
pub trait SendEventProvider<Provider: GenericEvent> {
type Error;
2022-06-11 01:59:39 +02:00
fn id(&self) -> u32;
2022-10-28 02:02:28 +02:00
fn send_no_data(&mut self, event: Provider) -> Result<(), Self::Error> {
self.send(event, None)
2022-10-27 23:56:47 +02:00
}
2022-10-28 02:02:28 +02:00
fn send(&mut self, event: Provider, aux_data: Option<&[u8]>) -> Result<(), Self::Error>;
}
2022-10-28 02:02:28 +02:00
struct Listener<E, Event: GenericEvent> {
2022-06-11 01:59:39 +02:00
ltype: ListenerType,
2022-10-28 02:02:28 +02:00
send_provider: Box<dyn SendEventProvider<Event, Error = E>>,
}
2022-10-28 02:02:28 +02:00
/// Generic abstraction for an event receiver.
pub trait EventReceiver<Event: GenericEvent> {
/// This function has to be provided by any event receiver. A receive call may or may not return
/// an event.
///
/// To allow returning arbitrary additional auxiliary data, a mutable slice is passed to the
/// [Self::receive] call as well. Receivers can write data to this slice, but care must be taken
/// to avoid panics due to size missmatches or out of bound writes.
fn receive(&mut self, aux_data: &mut [u8]) -> Option<Event>;
2022-06-10 18:10:40 +02:00
}
2022-10-28 02:02:28 +02:00
/// Generic event manager implementation.
pub struct EventManager<E, Event: GenericEvent> {
aux_data_buf: Vec<u8>,
listeners: HashMap<ListenerType, Vec<Listener<E, Event>>>,
event_receiver: Box<dyn EventReceiver<Event>>,
2022-06-10 18:10:40 +02:00
}
2022-10-24 01:51:33 +02:00
pub enum HandlerResult<Provider: GenericEvent> {
2022-06-11 01:59:39 +02:00
Empty,
2022-10-23 15:58:54 +02:00
Handled(u32, Provider),
2022-06-11 01:59:39 +02:00
}
2022-10-28 02:02:28 +02:00
impl<E, Event: GenericEvent + Copy> EventManager<E, Event> {
pub fn new(event_receiver: Box<dyn EventReceiver<Event>>, buf_len_aux_data: usize) -> Self {
2022-06-10 19:22:05 +02:00
EventManager {
2022-10-28 02:02:28 +02:00
aux_data_buf: vec![0; buf_len_aux_data],
2022-06-10 19:22:05 +02:00
listeners: HashMap::new(),
event_receiver,
}
}
2022-06-11 01:59:39 +02:00
pub fn subscribe_single(
&mut self,
2022-10-28 02:02:28 +02:00
event: Event,
dest: impl SendEventProvider<Event, Error = E> + 'static,
2022-06-11 01:59:39 +02:00
) {
2022-10-23 18:36:33 +02:00
self.update_listeners(ListenerType::Single(event.raw_as_largest_type()), dest);
2022-06-10 18:10:40 +02:00
}
2022-06-10 19:22:05 +02:00
pub fn subscribe_group(
&mut self,
2022-10-28 02:02:28 +02:00
group_id: LargestGroupIdRaw,
dest: impl SendEventProvider<Event, Error = E> + 'static,
2022-06-10 19:22:05 +02:00
) {
2022-06-10 18:10:40 +02:00
self.update_listeners(ListenerType::Group(group_id), dest);
}
2022-10-28 02:02:28 +02:00
pub fn subscribe_all(&mut self, dest: impl SendEventProvider<Event, Error = E> + 'static) {
self.update_listeners(ListenerType::All, dest);
2022-10-23 15:58:54 +02:00
}
2022-10-28 02:02:28 +02:00
/// Helper function which removes single subscriptions for which a group subscription already
/// exists.
pub fn remove_single_subscriptions_for_group(
2022-10-23 15:58:54 +02:00
&mut self,
2022-10-28 02:02:28 +02:00
group_id: LargestGroupIdRaw,
2022-10-28 02:02:50 +02:00
dest: impl SendEventProvider<Event, Error = E> + 'static,
2022-10-23 15:58:54 +02:00
) {
2022-10-28 02:02:28 +02:00
if self.listeners.contains_key(&ListenerType::Group(group_id)) {
for (ltype, listeners) in &mut self.listeners {
if let ListenerType::Single(_) = ltype {
2022-10-28 02:02:50 +02:00
listeners.retain(|f| f.send_provider.id() != dest.id());
2022-10-28 02:02:28 +02:00
}
}
}
2022-10-23 15:58:54 +02:00
}
}
2022-10-23 18:36:33 +02:00
2022-10-24 01:51:33 +02:00
impl<E, Provider: GenericEvent + Copy> EventManager<E, Provider> {
2022-06-10 19:22:05 +02:00
fn update_listeners(
&mut self,
key: ListenerType,
2022-10-28 02:02:28 +02:00
dest: impl SendEventProvider<Provider, Error = E> + 'static,
2022-06-10 19:22:05 +02:00
) {
2022-08-20 23:21:36 +02:00
if !self.listeners.contains_key(&key) {
self.listeners.insert(
key,
vec![Listener {
ltype: key,
2022-10-28 02:02:28 +02:00
send_provider: Box::new(dest),
2022-08-20 23:21:36 +02:00
}],
);
2022-06-10 18:10:40 +02:00
} else {
let vec = self.listeners.get_mut(&key).unwrap();
2022-06-11 01:59:39 +02:00
// To prevent double insertions
for entry in vec.iter() {
2022-10-28 02:02:28 +02:00
if entry.ltype == key && entry.send_provider.id() == dest.id() {
2022-06-11 12:27:03 +02:00
return;
2022-06-11 01:59:39 +02:00
}
}
2022-06-10 19:22:05 +02:00
vec.push(Listener {
2022-06-11 01:59:39 +02:00
ltype: key,
2022-10-28 02:02:28 +02:00
send_provider: Box::new(dest),
2022-06-10 19:22:05 +02:00
});
2022-06-10 18:10:40 +02:00
}
}
2022-10-23 15:58:54 +02:00
pub fn try_event_handling(&mut self) -> Result<HandlerResult<Provider>, E> {
2022-06-11 01:59:39 +02:00
let mut err_status = None;
let mut num_recipients = 0;
2022-10-27 23:56:47 +02:00
let mut send_handler =
|event: Provider, aux_data: Option<&[u8]>, llist: &mut Vec<Listener<E, Provider>>| {
for listener in llist.iter_mut() {
2022-10-28 02:02:28 +02:00
if let Err(e) = listener.send_provider.send(event, aux_data) {
2022-10-27 23:56:47 +02:00
err_status = Some(Err(e));
} else {
num_recipients += 1;
}
2022-06-10 18:10:40 +02:00
}
2022-10-27 23:56:47 +02:00
};
2022-10-28 02:02:28 +02:00
if let Some(event) = self
.event_receiver
.receive(self.aux_data_buf.as_mut_slice())
{
2022-10-23 18:36:33 +02:00
let single_key = ListenerType::Single(event.raw_as_largest_type());
2022-06-11 01:59:39 +02:00
if self.listeners.contains_key(&single_key) {
2022-10-27 23:56:47 +02:00
send_handler(
event,
2022-10-28 02:02:28 +02:00
Some(self.aux_data_buf.as_slice()),
2022-10-27 23:56:47 +02:00
self.listeners.get_mut(&single_key).unwrap(),
);
2022-06-11 01:59:39 +02:00
}
2022-10-23 18:36:33 +02:00
let group_key = ListenerType::Group(event.group_id_as_largest_type());
2022-06-11 01:59:39 +02:00
if self.listeners.contains_key(&group_key) {
2022-10-28 02:02:28 +02:00
send_handler(
event,
Some(self.aux_data_buf.as_slice()),
self.listeners.get_mut(&group_key).unwrap(),
);
}
if let Some(all_receivers) = self.listeners.get_mut(&ListenerType::All) {
send_handler(event, Some(self.aux_data_buf.as_slice()), all_receivers);
2022-06-11 01:59:39 +02:00
}
if let Some(err) = err_status {
return err;
}
return Ok(HandlerResult::Handled(num_recipients, event));
2022-06-10 18:10:40 +02:00
}
2022-06-11 01:59:39 +02:00
Ok(HandlerResult::Empty)
2022-06-10 18:10:40 +02:00
}
}
#[cfg(test)]
mod tests {
2022-10-28 02:02:28 +02:00
use super::{EventReceiver, HandlerResult, SendEventProvider};
2022-06-16 15:45:22 +02:00
use crate::event_man::EventManager;
2022-10-24 01:51:33 +02:00
use crate::events::{EventU32, GenericEvent, Severity};
2022-08-20 23:21:36 +02:00
use alloc::boxed::Box;
2022-06-10 19:22:05 +02:00
use std::sync::mpsc::{channel, Receiver, SendError, Sender};
2022-06-11 01:59:39 +02:00
use std::time::Duration;
2022-10-28 02:02:28 +02:00
use std::{thread, vec};
use vec::Vec;
2022-06-10 19:22:05 +02:00
2022-10-27 23:56:47 +02:00
type EventAndParams<'a> = (EventU32, Option<&'a [u8]>);
2022-10-28 02:02:28 +02:00
struct MpscEventReceiver {
mpsc_receiver: Receiver<(EventU32, Option<Vec<u8>>)>,
2022-06-10 19:22:05 +02:00
}
2022-10-27 23:56:47 +02:00
2022-10-28 02:02:28 +02:00
impl EventReceiver<EventU32> for MpscEventReceiver {
fn receive(&mut self, aux_data: &mut [u8]) -> Option<EventU32> {
if let Some((event, params)) = self.mpsc_receiver.try_recv().ok() {
if let Some(params) = params {
if params.len() < aux_data.len() {
aux_data[0..params.len()].copy_from_slice(params.as_slice())
}
}
return Some(event);
2022-10-27 23:56:47 +02:00
}
None
2022-06-10 19:22:05 +02:00
}
}
2022-06-11 01:59:39 +02:00
#[derive(Clone)]
2022-10-27 23:56:47 +02:00
struct MpscEventSenderQueue<'a> {
2022-06-11 01:59:39 +02:00
id: u32,
2022-10-27 23:56:47 +02:00
mpsc_sender: Sender<EventAndParams<'a>>,
2022-06-10 19:22:05 +02:00
}
2022-10-28 02:02:28 +02:00
impl<'a> SendEventProvider<EventU32> for MpscEventSenderQueue<'a> {
2022-10-27 23:56:47 +02:00
type Error = SendError<EventAndParams<'a>>;
2022-06-10 19:22:05 +02:00
2022-06-11 01:59:39 +02:00
fn id(&self) -> u32 {
self.id
}
2022-10-28 02:02:28 +02:00
fn send(&mut self, event: EventU32, _aux_data: Option<&[u8]>) -> Result<(), Self::Error> {
2022-10-27 23:56:47 +02:00
self.mpsc_sender.send((event, None))
2022-06-10 19:22:05 +02:00
}
}
2022-10-27 23:56:47 +02:00
fn check_next_event(expected: EventU32, receiver: &Receiver<EventAndParams>) {
2022-06-11 01:59:39 +02:00
for _ in 0..5 {
if let Ok(event) = receiver.try_recv() {
2022-10-27 23:56:47 +02:00
assert_eq!(event.0, expected);
2022-06-11 01:59:39 +02:00
break;
}
thread::sleep(Duration::from_millis(1));
}
}
2022-10-24 01:51:33 +02:00
fn check_handled_event(
res: HandlerResult<EventU32>,
expected: EventU32,
expected_num_sent: u32,
) {
2022-06-11 01:59:39 +02:00
assert!(matches!(res, HandlerResult::Handled { .. }));
2022-06-11 02:00:44 +02:00
if let HandlerResult::Handled(num_recipients, event) = res {
assert_eq!(event, expected);
assert_eq!(num_recipients, expected_num_sent);
2022-06-11 01:59:39 +02:00
}
}
#[test]
2022-06-11 01:59:39 +02:00
fn test_basic() {
2022-06-10 19:22:05 +02:00
let (event_sender, manager_queue) = channel();
2022-10-28 02:02:28 +02:00
let event_man_receiver = MpscEventReceiver {
2022-06-10 19:22:05 +02:00
mpsc_receiver: manager_queue,
};
2022-10-27 23:56:47 +02:00
let mut event_man: EventManager<SendError<EventAndParams>, EventU32> =
2022-10-28 02:02:28 +02:00
EventManager::new(Box::new(event_man_receiver), 128);
2022-10-24 01:51:33 +02:00
let event_grp_0 = EventU32::new(Severity::INFO, 0, 0).unwrap();
let event_grp_1_0 = EventU32::new(Severity::HIGH, 1, 0).unwrap();
2022-06-10 19:22:05 +02:00
let (single_event_sender, single_event_receiver) = channel();
let single_event_listener = MpscEventSenderQueue {
2022-06-11 01:59:39 +02:00
id: 0,
2022-06-10 19:22:05 +02:00
mpsc_sender: single_event_sender,
};
2022-06-11 01:59:39 +02:00
event_man.subscribe_single(event_grp_0, single_event_listener);
let (group_event_sender_0, group_event_receiver_0) = channel();
2022-06-10 19:22:05 +02:00
let group_event_listener = MpscEventSenderQueue {
2022-06-11 01:59:39 +02:00
id: 1,
mpsc_sender: group_event_sender_0,
2022-06-10 19:22:05 +02:00
};
event_man.subscribe_group(event_grp_1_0.group_id(), group_event_listener);
2022-06-11 01:59:39 +02:00
// Test event with one listener
event_sender
2022-10-27 23:56:47 +02:00
.send((event_grp_0, None))
2022-06-11 01:59:39 +02:00
.expect("Sending single error failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_grp_0, 1);
check_next_event(event_grp_0, &single_event_receiver);
// Test event which is sent to all group listeners
event_sender
2022-10-27 23:56:47 +02:00
.send((event_grp_1_0, None))
2022-06-11 01:59:39 +02:00
.expect("Sending group error failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_grp_1_0, 1);
check_next_event(event_grp_1_0, &group_event_receiver_0);
}
/// Test listening for multiple groups
#[test]
fn test_multi_group() {
let (event_sender, manager_queue) = channel();
2022-10-28 02:02:28 +02:00
let event_man_receiver = MpscEventReceiver {
2022-06-11 01:59:39 +02:00
mpsc_receiver: manager_queue,
};
2022-10-27 23:56:47 +02:00
let mut event_man: EventManager<SendError<EventAndParams>, EventU32> =
2022-10-28 02:02:28 +02:00
EventManager::new(Box::new(event_man_receiver), 128);
2022-06-11 01:59:39 +02:00
let res = event_man.try_event_handling();
assert!(res.is_ok());
let hres = res.unwrap();
assert!(matches!(hres, HandlerResult::Empty));
2022-10-24 01:51:33 +02:00
let event_grp_0 = EventU32::new(Severity::INFO, 0, 0).unwrap();
let event_grp_1_0 = EventU32::new(Severity::HIGH, 1, 0).unwrap();
2022-06-11 01:59:39 +02:00
let (event_grp_0_sender, event_grp_0_receiver) = channel();
let event_grp_0_and_1_listener = MpscEventSenderQueue {
id: 0,
mpsc_sender: event_grp_0_sender,
};
event_man.subscribe_group(event_grp_0.group_id(), event_grp_0_and_1_listener.clone());
event_man.subscribe_group(event_grp_1_0.group_id(), event_grp_0_and_1_listener);
event_sender
2022-10-27 23:56:47 +02:00
.send((event_grp_0, None))
2022-06-11 01:59:39 +02:00
.expect("Sending Event Group 0 failed");
event_sender
2022-10-27 23:56:47 +02:00
.send((event_grp_1_0, None))
2022-06-11 01:59:39 +02:00
.expect("Sendign Event Group 1 failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_grp_0, 1);
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_grp_1_0, 1);
check_next_event(event_grp_0, &event_grp_0_receiver);
check_next_event(event_grp_1_0, &event_grp_0_receiver);
}
/// Test listening to the same event from multiple listeners. Also test listening
/// to both group and single events from one listener
#[test]
fn test_listening_to_same_event_and_multi_type() {
let (event_sender, manager_queue) = channel();
2022-10-28 02:02:28 +02:00
let event_man_receiver = MpscEventReceiver {
2022-06-11 01:59:39 +02:00
mpsc_receiver: manager_queue,
};
2022-10-27 23:56:47 +02:00
let mut event_man: EventManager<SendError<EventAndParams>, EventU32> =
2022-10-28 02:02:28 +02:00
EventManager::new(Box::new(event_man_receiver), 128);
2022-10-24 01:51:33 +02:00
let event_0 = EventU32::new(Severity::INFO, 0, 5).unwrap();
let event_1 = EventU32::new(Severity::HIGH, 1, 0).unwrap();
2022-06-11 01:59:39 +02:00
let (event_0_tx_0, event_0_rx_0) = channel();
let (event_0_tx_1, event_0_rx_1) = channel();
let event_listener_0 = MpscEventSenderQueue {
id: 0,
mpsc_sender: event_0_tx_0,
};
let event_listener_1 = MpscEventSenderQueue {
id: 1,
mpsc_sender: event_0_tx_1,
};
event_man.subscribe_single(event_0, event_listener_0.clone());
event_man.subscribe_single(event_0, event_listener_1);
event_sender
2022-10-27 23:56:47 +02:00
.send((event_0, None))
2022-06-11 01:59:39 +02:00
.expect("Triggering Event 0 failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_0, 2);
check_next_event(event_0, &event_0_rx_0);
check_next_event(event_0, &event_0_rx_1);
event_man.subscribe_group(event_1.group_id(), event_listener_0.clone());
event_sender
2022-10-27 23:56:47 +02:00
.send((event_0, None))
2022-06-11 01:59:39 +02:00
.expect("Triggering Event 0 failed");
event_sender
2022-10-27 23:56:47 +02:00
.send((event_1, None))
2022-06-11 01:59:39 +02:00
.expect("Triggering Event 1 failed");
// 3 Events messages will be sent now
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_0, 2);
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_1, 1);
// Both the single event and the group event should arrive now
check_next_event(event_0, &event_0_rx_0);
check_next_event(event_1, &event_0_rx_0);
// Double insertion should be detected, result should remain the same
event_man.subscribe_group(event_1.group_id(), event_listener_0);
event_sender
2022-10-27 23:56:47 +02:00
.send((event_1, None))
2022-06-11 01:59:39 +02:00
.expect("Triggering Event 1 failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_1, 1);
}
2022-10-29 01:10:51 +02:00
#[test]
fn test_all_events_listener() {
let (event_sender, manager_queue) = channel();
let event_man_receiver = MpscEventReceiver {
mpsc_receiver: manager_queue,
};
let mut event_man: EventManager<SendError<EventAndParams>, EventU32> =
EventManager::new(Box::new(event_man_receiver), 128);
let event_0 = EventU32::new(Severity::INFO, 0, 5).unwrap();
let event_1 = EventU32::new(Severity::HIGH, 1, 0).unwrap();
let (event_0_tx_0, all_events_rx) = channel();
let all_events_listener = MpscEventSenderQueue {
id: 0,
mpsc_sender: event_0_tx_0,
};
event_man.subscribe_all(all_events_listener);
event_sender
.send((event_0, None))
.expect("Triggering event 0 failed");
event_sender
.send((event_1, None))
.expect("Triggering event 1 failed");
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_0, 1);
let res = event_man.try_event_handling();
assert!(res.is_ok());
check_handled_event(res.unwrap(), event_1, 1);
check_next_event(event_0, &all_events_rx);
check_next_event(event_1, &all_events_rx);
}
2022-06-10 19:22:05 +02:00
}