pub struct StreamMetadata {
pub process_id: Uuid,
pub stream_id: Uuid,
pub dependencies_metadata: Vec<UserDefinedType>,
pub objects_metadata: Vec<UserDefinedType>,
pub tags: Vec<String>,
pub properties: Arc<Vec<u8>>,
}Expand description
Analytics-optimized stream metadata.
This struct is designed for analytics use cases where stream properties need to be
efficiently serialized to JSONB format multiple times. Unlike StreamInfo, which
uses HashMap<String, String> for properties, this struct stores pre-serialized
JSONB data to eliminate redundant serialization overhead.
Fields§
§process_id: Uuid§stream_id: Uuid§dependencies_metadata: Vec<UserDefinedType>§objects_metadata: Vec<UserDefinedType>§properties: Arc<Vec<u8>>Implementations§
Source§impl StreamMetadata
impl StreamMetadata
Sourcepub fn from_stream_info(
stream_info: &StreamInfo,
) -> Result<StreamMetadata, Error>
pub fn from_stream_info( stream_info: &StreamInfo, ) -> Result<StreamMetadata, Error>
Creates StreamMetadata from StreamInfo by converting properties to JSONB format.
Trait Implementations§
Source§impl Clone for StreamMetadata
impl Clone for StreamMetadata
Source§fn clone(&self) -> StreamMetadata
fn clone(&self) -> StreamMetadata
Returns a duplicate 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 Freeze for StreamMetadata
impl RefUnwindSafe for StreamMetadata
impl Send for StreamMetadata
impl Sync for StreamMetadata
impl Unpin for StreamMetadata
impl UnwindSafe for StreamMetadata
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,
§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> 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 more§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].