pub struct Publisher<T, C: CodecType> { /* private fields */ }Expand description
A typed publisher that implements Sink.
§Type Parameters
T- The message type that will be serialized for publishing.C- The codec type used for serialization.
§Note on Error Handling
The Sink implementation uses fire-and-forget semantics for efficiency.
Publish errors are not propagated back through the Sink interface.
For applications requiring guaranteed delivery or error handling:
- Use
Publisher::publishfor direct publish with error handling - Use
Client::publishfor basic NATS - Use
JetStreamContext::publishfor JetStream
§Example
use intercom::{Client, MsgPackCodec};
use serde::{Deserialize, Serialize};
use futures::SinkExt;
#[derive(Serialize, Deserialize)]
struct MyMessage {
content: String,
}
let client = Client::<MsgPackCodec>::connect("nats://localhost:4222").await?;
let mut publisher = client.publisher::<MyMessage>("subject");
// Use Sink trait methods
publisher.send(MyMessage { content: "hello".into() }).await?;
// Or use feed + flush for batching
publisher.feed(MyMessage { content: "msg1".into() }).await?;
publisher.feed(MyMessage { content: "msg2".into() }).await?;
publisher.flush().await?;Implementations§
Source§impl<T: Serialize, C: CodecType> Publisher<T, C>
impl<T: Serialize, C: CodecType> Publisher<T, C>
Sourcepub async fn publish(&self, message: &T) -> Result<()>
pub async fn publish(&self, message: &T) -> Result<()>
Publish a message directly with error handling.
Unlike the Sink implementation, this method returns any publish errors.
§Example
use intercom::{Client, MsgPackCodec};
use serde::{Deserialize, Serialize};
#[derive(Serialize, Deserialize)]
struct MyMessage { content: String }
let client = Client::<MsgPackCodec>::connect("nats://localhost:4222").await?;
let publisher = client.publisher::<MyMessage>("subject");
// Direct publish with error handling
publisher.publish(&MyMessage { content: "hello".into() }).await?;Trait Implementations§
Source§impl<T: Serialize + Unpin, C: CodecType + Unpin> Sink<T> for Publisher<T, C>
impl<T: Serialize + Unpin, C: CodecType + Unpin> Sink<T> for Publisher<T, C>
Source§fn poll_ready(
self: Pin<&mut Self>,
_cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>
fn poll_ready( self: Pin<&mut Self>, _cx: &mut Context<'_>, ) -> Poll<Result<(), Self::Error>>
Attempts to prepare the
Sink to receive a value. Read moreSource§fn start_send(self: Pin<&mut Self>, item: T) -> Result<(), Self::Error>
fn start_send(self: Pin<&mut Self>, item: T) -> Result<(), Self::Error>
Begin the process of sending a value to the sink.
Each call to this function must be preceded by a successful call to
poll_ready which returned Poll::Ready(Ok(())). Read moreAuto Trait Implementations§
impl<T, C> Freeze for Publisher<T, C>
impl<T, C> !RefUnwindSafe for Publisher<T, C>
impl<T, C> Send for Publisher<T, C>where
T: Send,
impl<T, C> Sync for Publisher<T, C>where
T: Sync,
impl<T, C> Unpin for Publisher<T, C>
impl<T, C> !UnwindSafe for Publisher<T, C>
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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, Item> SinkExt<Item> for T
impl<T, Item> SinkExt<Item> for T
Source§fn with<U, Fut, F, E>(self, f: F) -> With<Self, Item, U, Fut, F>
fn with<U, Fut, F, E>(self, f: F) -> With<Self, Item, U, Fut, F>
Composes a function in front of the sink. Read more
Source§fn with_flat_map<U, St, F>(self, f: F) -> WithFlatMap<Self, Item, U, St, F>
fn with_flat_map<U, St, F>(self, f: F) -> WithFlatMap<Self, Item, U, St, F>
Composes a function in front of the sink. Read more
Source§fn sink_map_err<E, F>(self, f: F) -> SinkMapErr<Self, F>
fn sink_map_err<E, F>(self, f: F) -> SinkMapErr<Self, F>
Transforms the error returned by the sink.
Source§fn sink_err_into<E>(self) -> SinkErrInto<Self, Item, E>
fn sink_err_into<E>(self) -> SinkErrInto<Self, Item, E>
Map this sink’s error to a different error type using the
Into trait. Read moreSource§fn buffer(self, capacity: usize) -> Buffer<Self, Item>where
Self: Sized,
fn buffer(self, capacity: usize) -> Buffer<Self, Item>where
Self: Sized,
Adds a fixed-size buffer to the current sink. Read more
Source§fn flush(&mut self) -> Flush<'_, Self, Item>where
Self: Unpin,
fn flush(&mut self) -> Flush<'_, Self, Item>where
Self: Unpin,
Flush the sink, processing all pending items. Read more
Source§fn send(&mut self, item: Item) -> Send<'_, Self, Item>where
Self: Unpin,
fn send(&mut self, item: Item) -> Send<'_, Self, Item>where
Self: Unpin,
A future that completes after the given item has been fully processed
into the sink, including flushing. Read more
Source§fn feed(&mut self, item: Item) -> Feed<'_, Self, Item>where
Self: Unpin,
fn feed(&mut self, item: Item) -> Feed<'_, Self, Item>where
Self: Unpin,
A future that completes after the given item has been received
by the sink. Read more
Source§fn send_all<'a, St>(&'a mut self, stream: &'a mut St) -> SendAll<'a, Self, St>
fn send_all<'a, St>(&'a mut self, stream: &'a mut St) -> SendAll<'a, Self, St>
A future that completes after the given stream has been fully processed
into the sink, including flushing. Read more
Source§fn right_sink<Si1>(self) -> Either<Si1, Self>
fn right_sink<Si1>(self) -> Either<Si1, Self>
Source§fn poll_ready_unpin(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>where
Self: Unpin,
fn poll_ready_unpin(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>where
Self: Unpin,
A convenience method for calling
Sink::poll_ready on Unpin
sink types.Source§fn start_send_unpin(&mut self, item: Item) -> Result<(), Self::Error>where
Self: Unpin,
fn start_send_unpin(&mut self, item: Item) -> Result<(), Self::Error>where
Self: Unpin,
A convenience method for calling
Sink::start_send on Unpin
sink types.