pub struct Courier { /* private fields */ }Expand description
Top-level runtime. Owns every pipeline; run blocks until all of them
exit (cancellation, upstream closure, or unrecoverable error).
Implementations§
Source§impl Courier
impl Courier
pub fn new(pipelines: Vec<Pipeline>) -> Self
Sourcepub fn with_observability(
self,
observability: Option<ObservabilityConfig>,
) -> Self
pub fn with_observability( self, observability: Option<ObservabilityConfig>, ) -> Self
Attach the observability config parsed from [observability].
Builder shape so tests and Registry::build_courier keep using
Courier::new(...) without a forced extra argument.
pub fn observability(&self) -> Option<&ObservabilityConfig>
Sourcepub fn spawn(self, cancel: CancellationToken) -> Vec<JoinHandle<()>>
pub fn spawn(self, cancel: CancellationToken) -> Vec<JoinHandle<()>>
Spawn every pipeline as tokio tasks under the given cancel token.
Caller is responsible for awaiting the returned handles and firing
the token on shutdown. run wraps this with a SIGINT handler.
pub async fn run(self)
Auto Trait Implementations§
impl Freeze for Courier
impl !RefUnwindSafe for Courier
impl Send for Courier
impl Sync for Courier
impl Unpin for Courier
impl UnsafeUnpin for Courier
impl !UnwindSafe for Courier
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request