Struct mz_storage_types::sinks::KafkaSinkConnection
source · pub struct KafkaSinkConnection<C: ConnectionAccess = InlinedConnection> {Show 14 fields
pub connection_id: CatalogItemId,
pub connection: C::Kafka,
pub format: KafkaSinkFormat<C>,
pub relation_key_indices: Option<Vec<usize>>,
pub key_desc_and_indices: Option<(RelationDesc, Vec<usize>)>,
pub headers_index: Option<usize>,
pub value_desc: RelationDesc,
pub partition_by: Option<MirScalarExpr>,
pub topic: String,
pub topic_options: KafkaTopicOptions,
pub compression_type: KafkaSinkCompressionType,
pub progress_group_id: KafkaIdStyle,
pub transactional_id: KafkaIdStyle,
pub topic_metadata_refresh_interval: Duration,
}
Fields§
§connection_id: CatalogItemId
§connection: C::Kafka
§format: KafkaSinkFormat<C>
§relation_key_indices: Option<Vec<usize>>
A natural key of the sinked relation (view or source).
key_desc_and_indices: Option<(RelationDesc, Vec<usize>)>
The user-specified key for the sink.
headers_index: Option<usize>
The index of the column containing message headers value, if any.
value_desc: RelationDesc
§partition_by: Option<MirScalarExpr>
An expression that, if present, computes a hash value that should be used to determine the partition for each message.
topic: String
§topic_options: KafkaTopicOptions
Options to use when creating the topic if it doesn’t already exist.
compression_type: KafkaSinkCompressionType
§progress_group_id: KafkaIdStyle
§transactional_id: KafkaIdStyle
§topic_metadata_refresh_interval: Duration
Implementations§
source§impl KafkaSinkConnection
impl KafkaSinkConnection
sourcepub fn client_id(
&self,
configs: &ConfigSet,
connection_context: &ConnectionContext,
sink_id: GlobalId,
) -> String
pub fn client_id( &self, configs: &ConfigSet, connection_context: &ConnectionContext, sink_id: GlobalId, ) -> String
Returns the client ID to register with librdkafka with.
The caller is responsible for providing the sink ID as it is not known
to KafkaSinkConnection
.
sourcepub fn progress_topic(
&self,
connection_context: &ConnectionContext,
) -> Cow<'_, str>
pub fn progress_topic( &self, connection_context: &ConnectionContext, ) -> Cow<'_, str>
Returns the name of the progress topic to use for the sink.
sourcepub fn progress_group_id(
&self,
connection_context: &ConnectionContext,
sink_id: GlobalId,
) -> String
pub fn progress_group_id( &self, connection_context: &ConnectionContext, sink_id: GlobalId, ) -> String
Returns the ID for the consumer group the sink will use to read the progress topic on resumption.
The caller is responsible for providing the sink ID as it is not known
to KafkaSinkConnection
.
sourcepub fn transactional_id(
&self,
connection_context: &ConnectionContext,
sink_id: GlobalId,
) -> String
pub fn transactional_id( &self, connection_context: &ConnectionContext, sink_id: GlobalId, ) -> String
Returns the transactional ID to use for the sink.
The caller is responsible for providing the sink ID as it is not known
to KafkaSinkConnection
.
source§impl<C: ConnectionAccess> KafkaSinkConnection<C>
impl<C: ConnectionAccess> KafkaSinkConnection<C>
sourcepub fn alter_compatible(
&self,
id: GlobalId,
other: &KafkaSinkConnection<C>,
) -> Result<(), AlterError>
pub fn alter_compatible( &self, id: GlobalId, other: &KafkaSinkConnection<C>, ) -> Result<(), AlterError>
Determines if self
is compatible with another StorageSinkConnection
,
in such a way that it is possible to turn self
into other
through a
valid series of transformations (e.g. no transformation or ALTER CONNECTION
).
Trait Implementations§
source§impl<C: ConnectionAccess + Arbitrary> Arbitrary for KafkaSinkConnection<C>
impl<C: ConnectionAccess + Arbitrary> Arbitrary for KafkaSinkConnection<C>
§type Parameters = (<CatalogItemId as Arbitrary>::Parameters, <<C as ConnectionAccess>::Kafka as Arbitrary>::Parameters, <KafkaSinkFormat<C> as Arbitrary>::Parameters, <Option<Vec<usize>> as Arbitrary>::Parameters, <Option<(RelationDesc, Vec<usize>)> as Arbitrary>::Parameters, <Option<usize> as Arbitrary>::Parameters, <RelationDesc as Arbitrary>::Parameters, <Option<MirScalarExpr> as Arbitrary>::Parameters, <String as Arbitrary>::Parameters, (<KafkaTopicOptions as Arbitrary>::Parameters, <KafkaSinkCompressionType as Arbitrary>::Parameters, <KafkaIdStyle as Arbitrary>::Parameters, <KafkaIdStyle as Arbitrary>::Parameters, <Duration as Arbitrary>::Parameters))
type Parameters = (<CatalogItemId as Arbitrary>::Parameters, <<C as ConnectionAccess>::Kafka as Arbitrary>::Parameters, <KafkaSinkFormat<C> as Arbitrary>::Parameters, <Option<Vec<usize>> as Arbitrary>::Parameters, <Option<(RelationDesc, Vec<usize>)> as Arbitrary>::Parameters, <Option<usize> as Arbitrary>::Parameters, <RelationDesc as Arbitrary>::Parameters, <Option<MirScalarExpr> as Arbitrary>::Parameters, <String as Arbitrary>::Parameters, (<KafkaTopicOptions as Arbitrary>::Parameters, <KafkaSinkCompressionType as Arbitrary>::Parameters, <KafkaIdStyle as Arbitrary>::Parameters, <KafkaIdStyle as Arbitrary>::Parameters, <Duration as Arbitrary>::Parameters))
arbitrary_with
accepts for configuration
of the generated Strategy
. Parameters must implement Default
.§type Strategy = Map<(<CatalogItemId as Arbitrary>::Strategy, <<C as ConnectionAccess>::Kafka as Arbitrary>::Strategy, <KafkaSinkFormat<C> as Arbitrary>::Strategy, <Option<Vec<usize>> as Arbitrary>::Strategy, <Option<(RelationDesc, Vec<usize>)> as Arbitrary>::Strategy, <Option<usize> as Arbitrary>::Strategy, <RelationDesc as Arbitrary>::Strategy, <Option<MirScalarExpr> as Arbitrary>::Strategy, <String as Arbitrary>::Strategy, (<KafkaTopicOptions as Arbitrary>::Strategy, <KafkaSinkCompressionType as Arbitrary>::Strategy, <KafkaIdStyle as Arbitrary>::Strategy, <KafkaIdStyle as Arbitrary>::Strategy, <Duration as Arbitrary>::Strategy)), fn(_: (CatalogItemId, <C as ConnectionAccess>::Kafka, KafkaSinkFormat<C>, Option<Vec<usize>>, Option<(RelationDesc, Vec<usize>)>, Option<usize>, RelationDesc, Option<MirScalarExpr>, String, (KafkaTopicOptions, KafkaSinkCompressionType, KafkaIdStyle, KafkaIdStyle, Duration))) -> KafkaSinkConnection<C>>
type Strategy = Map<(<CatalogItemId as Arbitrary>::Strategy, <<C as ConnectionAccess>::Kafka as Arbitrary>::Strategy, <KafkaSinkFormat<C> as Arbitrary>::Strategy, <Option<Vec<usize>> as Arbitrary>::Strategy, <Option<(RelationDesc, Vec<usize>)> as Arbitrary>::Strategy, <Option<usize> as Arbitrary>::Strategy, <RelationDesc as Arbitrary>::Strategy, <Option<MirScalarExpr> as Arbitrary>::Strategy, <String as Arbitrary>::Strategy, (<KafkaTopicOptions as Arbitrary>::Strategy, <KafkaSinkCompressionType as Arbitrary>::Strategy, <KafkaIdStyle as Arbitrary>::Strategy, <KafkaIdStyle as Arbitrary>::Strategy, <Duration as Arbitrary>::Strategy)), fn(_: (CatalogItemId, <C as ConnectionAccess>::Kafka, KafkaSinkFormat<C>, Option<Vec<usize>>, Option<(RelationDesc, Vec<usize>)>, Option<usize>, RelationDesc, Option<MirScalarExpr>, String, (KafkaTopicOptions, KafkaSinkCompressionType, KafkaIdStyle, KafkaIdStyle, Duration))) -> KafkaSinkConnection<C>>
Strategy
used to generate values of type Self
.source§fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
fn arbitrary_with(_top: Self::Parameters) -> Self::Strategy
source§impl<C: Clone + ConnectionAccess> Clone for KafkaSinkConnection<C>
impl<C: Clone + ConnectionAccess> Clone for KafkaSinkConnection<C>
source§fn clone(&self) -> KafkaSinkConnection<C>
fn clone(&self) -> KafkaSinkConnection<C>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl<C: Debug + ConnectionAccess> Debug for KafkaSinkConnection<C>
impl<C: Debug + ConnectionAccess> Debug for KafkaSinkConnection<C>
source§impl<'de, C> Deserialize<'de> for KafkaSinkConnection<C>
impl<'de, C> Deserialize<'de> for KafkaSinkConnection<C>
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
source§impl<R: ConnectionResolver> IntoInlineConnection<KafkaSinkConnection, R> for KafkaSinkConnection<ReferencedConnection>
impl<R: ConnectionResolver> IntoInlineConnection<KafkaSinkConnection, R> for KafkaSinkConnection<ReferencedConnection>
fn into_inline_connection(self, r: R) -> KafkaSinkConnection
source§impl<C: PartialEq + ConnectionAccess> PartialEq for KafkaSinkConnection<C>
impl<C: PartialEq + ConnectionAccess> PartialEq for KafkaSinkConnection<C>
source§impl RustType<ProtoKafkaSinkConnectionV2> for KafkaSinkConnection
impl RustType<ProtoKafkaSinkConnectionV2> for KafkaSinkConnection
source§fn into_proto(&self) -> ProtoKafkaSinkConnectionV2
fn into_proto(&self) -> ProtoKafkaSinkConnectionV2
Self
into a Proto
value.source§fn from_proto(
proto: ProtoKafkaSinkConnectionV2,
) -> Result<Self, TryFromProtoError>
fn from_proto( proto: ProtoKafkaSinkConnectionV2, ) -> Result<Self, TryFromProtoError>
source§fn into_proto_owned(self) -> Proto
fn into_proto_owned(self) -> Proto
Self::into_proto
that types can
optionally implement, otherwise, the default implementation
delegates to Self::into_proto
.source§impl<C> Serialize for KafkaSinkConnection<C>
impl<C> Serialize for KafkaSinkConnection<C>
impl<C: Eq + ConnectionAccess> Eq for KafkaSinkConnection<C>
impl<C: ConnectionAccess> StructuralPartialEq for KafkaSinkConnection<C>
Auto Trait Implementations§
impl<C> Freeze for KafkaSinkConnection<C>
impl<C> RefUnwindSafe for KafkaSinkConnection<C>
impl<C> Send for KafkaSinkConnection<C>
impl<C> Sync for KafkaSinkConnection<C>
impl<C> Unpin for KafkaSinkConnection<C>
impl<C> UnwindSafe for KafkaSinkConnection<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
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<T> FmtForward for T
impl<T> FmtForward for T
source§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.source§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.source§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.source§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.source§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.source§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.source§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.source§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.source§impl<T> FutureExt for T
impl<T> FutureExt for T
source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
source§impl<T, U> OverrideFrom<Option<&T>> for Uwhere
U: OverrideFrom<T>,
impl<T, U> OverrideFrom<Option<&T>> for Uwhere
U: OverrideFrom<T>,
source§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
source§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moresource§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read moresource§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
source§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
source§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.source§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.source§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.source§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> ProgressEventTimestamp for T
impl<T> ProgressEventTimestamp for T
source§impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
impl<P, R> ProtoType<R> for Pwhere
R: RustType<P>,
source§fn into_rust(self) -> Result<R, TryFromProtoError>
fn into_rust(self) -> Result<R, TryFromProtoError>
RustType::from_proto
.source§fn from_rust(rust: &R) -> P
fn from_rust(rust: &R) -> P
RustType::into_proto
.source§impl<'a, S, T> Semigroup<&'a S> for Twhere
T: Semigroup<S>,
impl<'a, S, T> Semigroup<&'a S> for Twhere
T: Semigroup<S>,
source§fn plus_equals(&mut self, rhs: &&'a S)
fn plus_equals(&mut self, rhs: &&'a S)
std::ops::AddAssign
, for types that do not implement AddAssign
.source§impl<T> Tap for T
impl<T> Tap for T
source§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read moresource§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read moresource§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read moresource§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read moresource§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read moresource§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read moresource§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.source§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.source§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.source§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.source§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.source§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.source§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.