1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use crate::workflows::steps::{StepFutureResult, StepOutputs};
use crate::StreamId;
use downcast_rs::{impl_downcast, Downcast};
pub trait ExternalStreamHandler {
fn prepare_stream(&mut self, stream_name: &str, outputs: &mut StepOutputs);
fn stop_stream(&mut self);
fn handle_resolved_future(
&mut self,
future: Box<dyn StreamHandlerFutureResult>,
outputs: &mut StepOutputs,
) -> ResolvedFutureStatus;
}
pub trait ExternalStreamHandlerGenerator {
fn generate(&self, stream_id: StreamId) -> Box<dyn ExternalStreamHandler + Sync + Send>;
}
pub struct StreamHandlerFutureWrapper {
pub stream_id: StreamId,
pub future: Box<dyn StreamHandlerFutureResult + Sync + Send>,
}
impl StepFutureResult for StreamHandlerFutureWrapper {}
impl_downcast!(StreamHandlerFutureResult);
pub trait StreamHandlerFutureResult: Downcast {}
pub enum ResolvedFutureStatus {
Success,
StreamShouldBeStopped,
}