Skip to main content

PushSubscription

Struct PushSubscription 

Source
pub struct PushSubscription { /* private fields */ }
Expand description

A push-based subscription handle.

Receives ChangeEvents as they are pushed by the Ring 1 dispatcher. Dropping this handle automatically cancels the subscription in the SubscriptionRegistry.

Works naturally with tokio::select! and while let:

tokio::select! {
    event = sub.recv() => handle(event),
    _ = shutdown.recv() => break,
}

Implementations§

Source§

impl PushSubscription

Source

pub fn new( id: SubscriptionId, receiver: Receiver<ChangeEvent>, registry: Arc<SubscriptionRegistry>, query: String, ) -> Self

Creates a new push subscription.

This is pub(crate) — external callers create subscriptions via the pipeline or engine API, which resolves the query to a source_id and registers in the SubscriptionRegistry.

Source

pub async fn recv(&mut self) -> Result<ChangeEvent, PushSubscriptionError>

Receives the next change event.

Awaits until an event is available or the subscription is closed.

§Errors
Source

pub fn try_recv(&mut self) -> Option<Result<ChangeEvent, PushSubscriptionError>>

Tries to receive without blocking.

Returns None if no event is immediately available. Returns Some(Err(...)) on lagged, closed, or cancelled.

Source

pub fn pause(&self) -> bool

Pauses the subscription.

While paused, events are either buffered or dropped depending on the backpressure configuration. Returns true if the subscription was active and is now paused.

Source

pub fn resume(&self) -> bool

Resumes a paused subscription.

Returns true if the subscription was paused and is now active.

Source

pub fn cancel(&mut self)

Cancels the subscription.

After cancellation, recv() returns PushSubscriptionError::Cancelled. The subscription is removed from the registry.

Source

pub fn id(&self) -> SubscriptionId

Returns the subscription ID.

Source

pub fn query(&self) -> &str

Returns the query string for this subscription.

Source

pub fn is_cancelled(&self) -> bool

Returns true if the subscription has been cancelled.

Source

pub fn metrics(&self) -> Option<SubscriptionMetrics>

Returns subscription metrics from the registry.

Trait Implementations§

Source§

impl Drop for PushSubscription

Source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more