pub struct ProcessorContext<'ctx, 'd, KOut, VOut> { /* private fields */ }Expand description
Handed to Processor::process. forward boxes the record and queues it
for each child node (the driver drains the queue).
Two lifetimes: 'ctx is the borrow of the Dispatch reference itself;
'd is the lifetime of the data inside Dispatch (buffers, slices, etc.).
Keeping them separate avoids lifetime-invariance issues when constructing a
ProcessorContext from a &mut Dispatch<'d> with an independently-scoped
outer borrow 'ctx.
Implementations§
Source§impl<'ctx, 'd, KOut, VOut> ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> ProcessorContext<'ctx, 'd, KOut, VOut>
Sourcepub fn forward(&mut self, record: Record<KOut, VOut>)
pub fn forward(&mut self, record: Record<KOut, VOut>)
Forward a record to all child nodes. The record is cloned per child for
fan-out; the last child receives the original by move (so the common
single-child case performs zero clones). Mirrors the JVM
ProcessorContext.forward(Record), which takes the record by value.
Sourcepub fn get_state_store<K2: Send + Sync + 'static, V2: Send + 'static>(
&mut self,
name: &str,
) -> Option<&mut dyn KeyValueStore<K2, V2>>
pub fn get_state_store<K2: Send + Sync + 'static, V2: Send + 'static>( &mut self, name: &str, ) -> Option<&mut dyn KeyValueStore<K2, V2>>
Access a connected state store, typed. None if absent or the K/V types
don’t match. Fetch it per-record (do not hold across process calls).
Sourcepub async fn global_get<GK: Send + Sync + 'static, VG: Send + 'static>(
&mut self,
store: &str,
key: &GK,
) -> Option<VG>
pub async fn global_get<GK: Send + Sync + 'static, VG: Send + 'static>( &mut self, store: &str, key: &GK, ) -> Option<VG>
Look up a value in a connected GLOBAL store (fully-replicated, shared across
tasks). Returns an owned value — no borrow escapes the shared manager’s lock,
so the lookup future need not be held across forward. None on miss /
type mismatch. Fetch it per-record (do not hold across process calls).
Sourcepub fn get_window_store<K2: Send + Sync + 'static, V2: Send + 'static>(
&mut self,
name: &str,
) -> Option<&mut dyn WindowStore<K2, V2>>
pub fn get_window_store<K2: Send + Sync + 'static, V2: Send + 'static>( &mut self, name: &str, ) -> Option<&mut dyn WindowStore<K2, V2>>
Access a connected window store, typed. None if absent or the K/V types
don’t match. Fetch it per-record (do not hold across process calls).
Sourcepub fn get_join_window_store<K2: Send + Sync + 'static, V2: Send + 'static>(
&mut self,
name: &str,
) -> Option<&mut dyn JoinWindowStore<K2, V2>>
pub fn get_join_window_store<K2: Send + Sync + 'static, V2: Send + 'static>( &mut self, name: &str, ) -> Option<&mut dyn JoinWindowStore<K2, V2>>
Access a connected join-window store (retainDuplicates), typed. None if
absent or the K/V types don’t match. Fetch it per-record (do not hold
across process calls).
Sourcepub fn get_session_store<K2: Send + Sync + 'static, V2: Send + 'static>(
&mut self,
name: &str,
) -> Option<&mut dyn SessionStore<K2, V2>>
pub fn get_session_store<K2: Send + Sync + 'static, V2: Send + 'static>( &mut self, name: &str, ) -> Option<&mut dyn SessionStore<K2, V2>>
Access a connected session store, typed. None if absent or the K/V types
don’t match. Fetch it per-record (do not hold across process calls).
Sourcepub fn get_versioned_store<K2: Send + Sync + 'static, V2: Send + 'static>(
&mut self,
name: &str,
) -> Option<&mut dyn VersionedKeyValueStore<K2, V2>>
pub fn get_versioned_store<K2: Send + Sync + 'static, V2: Send + 'static>( &mut self, name: &str, ) -> Option<&mut dyn VersionedKeyValueStore<K2, V2>>
Access a connected versioned store (KIP-889), typed. None if absent or
the K/V types don’t match. Fetch it per-record (do not hold across
process calls).
Sourcepub fn record_context(&self) -> &RecordContext
pub fn record_context(&self) -> &RecordContext
Metadata of the source record currently being processed.
Sourcepub fn store_is_cached(&self, name: &str) -> bool
pub fn store_is_cached(&self, name: &str) -> bool
Whether the named KV state store is record-cached (so this processor should suppress its immediate forward and let the cache flush forward the deduped change). False for absent/non-KV/uncached stores.
Sourcepub fn schedule<P>(
&mut self,
interval: Duration,
ty: PunctuationType,
punctuator: P,
) -> Cancellablewhere
P: Punctuator<KOut, VOut>,
pub fn schedule<P>(
&mut self,
interval: Duration,
ty: PunctuationType,
punctuator: P,
) -> Cancellablewhere
P: Punctuator<KOut, VOut>,
Schedule a periodic Punctuator. Callable from init or process.
interval must be positive. Returns a Cancellable to stop it.
Auto Trait Implementations§
impl<'ctx, 'd, KOut, VOut> !RefUnwindSafe for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> !Sync for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> !UnwindSafe for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> Freeze for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> Send for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> Unpin for ProcessorContext<'ctx, 'd, KOut, VOut>
impl<'ctx, 'd, KOut, VOut> UnsafeUnpin for ProcessorContext<'ctx, 'd, KOut, VOut>
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSend for T
impl<T> DowncastSend for T
impl<T> Fruit for T
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>
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>
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 more