Struct akka_projection_rs_grpc::proto::event_consumer_service_client::EventConsumerServiceClient
source · pub struct EventConsumerServiceClient<T> { /* private fields */ }
Expand description
EventConsumerService runs on the consumer side and allows a producer to initiate/push events to the consumer.
- Events are stored in the event journal on the producer side.
- Producer side starts an Akka Projection which locally tracks its offset and as projection handler pushes events to a consuming EventConsumerService
- Consumer stores events directly into a journal
- Consumer side projections can run against the local journal
Implementations§
source§impl<T> EventConsumerServiceClient<T>where
T: GrpcService<BoxBody>,
T::Error: Into<StdError>,
T::ResponseBody: Body<Data = Bytes> + Send + 'static,
<T::ResponseBody as Body>::Error: Into<StdError> + Send,
impl<T> EventConsumerServiceClient<T>where T: GrpcService<BoxBody>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,
pub fn new(inner: T) -> Self
pub fn with_origin(inner: T, origin: Uri) -> Self
pub fn with_interceptor<F>( inner: T, interceptor: F ) -> EventConsumerServiceClient<InterceptedService<T, F>>where F: Interceptor, T::ResponseBody: Default, T: Service<Request<BoxBody>, Response = Response<<T as GrpcService<BoxBody>>::ResponseBody>>, <T as Service<Request<BoxBody>>>::Error: Into<StdError> + Send + Sync,
sourcepub fn send_compressed(self, encoding: CompressionEncoding) -> Self
pub fn send_compressed(self, encoding: CompressionEncoding) -> Self
Compress requests with the given encoding.
This requires the server to support it otherwise it might respond with an error.
sourcepub fn accept_compressed(self, encoding: CompressionEncoding) -> Self
pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self
Enable decompressing responses.
sourcepub fn max_decoding_message_size(self, limit: usize) -> Self
pub fn max_decoding_message_size(self, limit: usize) -> Self
Limits the maximum size of a decoded message.
Default: 4MB
sourcepub fn max_encoding_message_size(self, limit: usize) -> Self
pub fn max_encoding_message_size(self, limit: usize) -> Self
Limits the maximum size of an encoded message.
Default: usize::MAX
pub async fn consume_event( &mut self, request: impl IntoStreamingRequest<Message = ConsumeEventIn> ) -> Result<Response<Streaming<ConsumeEventOut>>, Status>
Trait Implementations§
source§impl<T: Clone> Clone for EventConsumerServiceClient<T>
impl<T: Clone> Clone for EventConsumerServiceClient<T>
source§fn clone(&self) -> EventConsumerServiceClient<T>
fn clone(&self) -> EventConsumerServiceClient<T>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreAuto Trait Implementations§
impl<T> RefUnwindSafe for EventConsumerServiceClient<T>where T: RefUnwindSafe,
impl<T> Send for EventConsumerServiceClient<T>where T: Send,
impl<T> Sync for EventConsumerServiceClient<T>where T: Sync,
impl<T> Unpin for EventConsumerServiceClient<T>where T: Unpin,
impl<T> UnwindSafe for EventConsumerServiceClient<T>where T: UnwindSafe,
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
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§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