use std::collections::HashMap;
use lib::Error;
use rdkafka::{ClientConfig, config::FromClientConfig};
mod cluster_config;
mod consumer_config;
mod global_config;
mod internal_config;
mod yozefu_config;
pub use cluster_config::ClusterConfig;
pub use cluster_config::KAFKA_PROPERTIES_WITH_LOCATIONS;
pub use cluster_config::SENSITIVE_KAFKA_PROPERTIES;
pub use cluster_config::SchemaRegistryConfig;
pub use consumer_config::ConsumerConfig;
pub use global_config::GlobalConfig;
pub use internal_config::InternalConfig;
pub use yozefu_config::YozefuConfig;
pub trait Configuration {
fn kafka_config_map(&self) -> HashMap<String, String>;
fn create_kafka_consumer<T>(&self) -> Result<T, Error>
where
T: FromClientConfig,
{
Self::kafka_client_config_from_properties(self.kafka_config_map().clone())
.create()
.map_err(std::convert::Into::into)
}
fn kafka_client_config_from_properties(
kafka_properties: HashMap<String, String>,
) -> ClientConfig {
let mut config = ClientConfig::new();
config.set_log_level(rdkafka::config::RDKafkaLogLevel::Emerg);
for (key, value) in kafka_properties {
config.set(key, value);
}
config
}
}