vector/sinks/util/
metadata.rsuse std::num::NonZeroUsize;
use vector_lib::request_metadata::{GetEventCountTags, GroupedCountByteSize, RequestMetadata};
use vector_lib::{config, ByteSizeOf, EstimatedJsonEncodedSizeOf};
use super::request_builder::EncodeResult;
#[derive(Clone, Default)]
pub struct RequestMetadataBuilder {
event_count: usize,
events_byte_size: usize,
grouped_events_byte_size: GroupedCountByteSize,
}
impl RequestMetadataBuilder {
pub fn from_events<E>(events: &[E]) -> Self
where
E: ByteSizeOf + GetEventCountTags + EstimatedJsonEncodedSizeOf,
{
let mut size = config::telemetry().create_request_count_byte_size();
let mut events_byte_size = 0;
for event in events {
events_byte_size += event.size_of();
size.add_event(event, event.estimated_json_encoded_size_of());
}
Self {
event_count: events.len(),
events_byte_size,
grouped_events_byte_size: size,
}
}
pub fn from_event<E>(event: &E) -> Self
where
E: ByteSizeOf + GetEventCountTags + EstimatedJsonEncodedSizeOf,
{
let mut size = config::telemetry().create_request_count_byte_size();
size.add_event(event, event.estimated_json_encoded_size_of());
Self {
event_count: 1,
events_byte_size: event.size_of(),
grouped_events_byte_size: size,
}
}
pub const fn new(
event_count: usize,
events_byte_size: usize,
grouped_events_byte_size: GroupedCountByteSize,
) -> Self {
Self {
event_count,
events_byte_size,
grouped_events_byte_size,
}
}
pub fn track_event<E>(&mut self, event: E)
where
E: ByteSizeOf + GetEventCountTags + EstimatedJsonEncodedSizeOf,
{
self.event_count += 1;
self.events_byte_size += event.size_of();
let json_size = event.estimated_json_encoded_size_of();
self.grouped_events_byte_size.add_event(&event, json_size);
}
pub fn with_request_size(&self, size: NonZeroUsize) -> RequestMetadata {
let size = size.get();
RequestMetadata::new(
self.event_count,
self.events_byte_size,
size,
size,
self.grouped_events_byte_size.clone(),
)
}
pub fn build<T>(&self, result: &EncodeResult<T>) -> RequestMetadata {
RequestMetadata::new(
self.event_count,
self.events_byte_size,
result.uncompressed_byte_size,
result
.compressed_byte_size
.unwrap_or(result.uncompressed_byte_size),
result.transformed_json_size.clone(),
)
}
}