pub struct CdcProcessor { /* private fields */ }Expand description
CDC processor with transaction handling and deduplication
Implementations§
Source§impl CdcProcessor
impl CdcProcessor
Sourcepub async fn process_event(
&self,
event: CdcEvent,
) -> StreamResult<Vec<CdcEvent>>
pub async fn process_event( &self, event: CdcEvent, ) -> StreamResult<Vec<CdcEvent>>
Process a CDC event
Sourcepub async fn commit_transaction(
&self,
transaction_id: &str,
) -> StreamResult<Vec<CdcEvent>>
pub async fn commit_transaction( &self, transaction_id: &str, ) -> StreamResult<Vec<CdcEvent>>
Commit a transaction (call when transaction end marker received)
Sourcepub async fn rollback_transaction(
&self,
transaction_id: &str,
) -> StreamResult<()>
pub async fn rollback_transaction( &self, transaction_id: &str, ) -> StreamResult<()>
Rollback a transaction (discard events)
Sourcepub async fn get_metrics(&self) -> CdcMetrics
pub async fn get_metrics(&self) -> CdcMetrics
Get current processing metrics
Sourcepub fn to_custom_event_data(cdc_event: &CdcEvent) -> Value
pub fn to_custom_event_data(cdc_event: &CdcEvent) -> Value
Convert CDC event to StreamEvent (Custom event variant) Note: Since StreamEvent is an enum focused on RDF operations, CDC events are best handled separately or through a custom event type. This is a placeholder for potential future integration.
Sourcepub fn from_json(data: &Value) -> StreamResult<CdcEvent>
pub fn from_json(data: &Value) -> StreamResult<CdcEvent>
Parse CDC event from JSON data
Auto Trait Implementations§
impl Freeze for CdcProcessor
impl !RefUnwindSafe for CdcProcessor
impl Send for CdcProcessor
impl Sync for CdcProcessor
impl Unpin for CdcProcessor
impl UnsafeUnpin for CdcProcessor
impl !UnwindSafe for CdcProcessor
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> 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> Pointable for T
impl<T> Pointable for T
Source§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self to the equivalent element of its superset.