vector/sinks/redis/
mod.rsmod config;
mod request_builder;
mod service;
mod sink;
#[cfg(test)]
mod tests;
#[cfg(feature = "redis-integration-tests")]
#[cfg(test)]
mod integration_tests;
use bytes::Bytes;
use redis::RedisError;
use snafu::Snafu;
use crate::sinks::prelude::*;
use self::config::Method;
use super::util::EncodedLength;
#[derive(Debug, Snafu)]
pub(super) enum RedisSinkError {
#[snafu(display("Creating Redis producer failed: {}", source))]
RedisCreateFailed { source: RedisError },
#[snafu(display("Error sending query: {}", source))]
SendError { source: RedisError },
}
#[derive(Clone, Copy, Debug, Derivative)]
#[derivative(Default)]
pub enum DataType {
#[derivative(Default)]
List(Method),
Channel,
}
pub(super) struct RedisEvent {
event: Event,
key: String,
}
impl Finalizable for RedisEvent {
fn take_finalizers(&mut self) -> EventFinalizers {
self.event.take_finalizers()
}
}
impl ByteSizeOf for RedisEvent {
fn allocated_bytes(&self) -> usize {
self.event.allocated_bytes()
}
}
impl GetEventCountTags for RedisEvent {
fn get_tags(&self) -> TaggedEventsSent {
self.event.get_tags()
}
}
impl EstimatedJsonEncodedSizeOf for RedisEvent {
fn estimated_json_encoded_size_of(&self) -> JsonSize {
self.event.estimated_json_encoded_size_of()
}
}
#[derive(Clone)]
pub(super) struct RedisRequest {
request: Vec<RedisKvEntry>,
finalizers: EventFinalizers,
metadata: RequestMetadata,
}
impl Finalizable for RedisRequest {
fn take_finalizers(&mut self) -> EventFinalizers {
std::mem::take(&mut self.finalizers)
}
}
impl MetaDescriptive for RedisRequest {
fn get_metadata(&self) -> &RequestMetadata {
&self.metadata
}
fn metadata_mut(&mut self) -> &mut RequestMetadata {
&mut self.metadata
}
}
#[derive(Debug, Clone)]
pub(super) struct RedisKvEntry {
key: String,
value: Bytes,
}
impl EncodedLength for RedisKvEntry {
fn encoded_length(&self) -> usize {
self.value.len()
}
}