use crate::commands::cli_command::{CliCommand, PRINT_TARGET};
use anyhow::Context;
use async_trait::async_trait;
use comfy_table::Table;
use iggy_common::Client;
use iggy_common::{Consumer, ConsumerKind, Identifier};
use tracing::{Level, event};
pub struct GetConsumerOffsetCmd {
consumer: Consumer,
stream_id: Identifier,
topic_id: Identifier,
partition_id: u32,
}
impl GetConsumerOffsetCmd {
pub fn new(
consumer_id: Identifier,
stream_id: Identifier,
topic_id: Identifier,
partition_id: u32,
kind: ConsumerKind,
) -> Self {
Self {
consumer: Consumer {
kind,
id: consumer_id,
},
stream_id,
topic_id,
partition_id,
}
}
pub fn get_consumer_info(&self) -> String {
match self.consumer.kind {
ConsumerKind::Consumer => {
format!("consumer with ID: {}", self.consumer.id)
}
ConsumerKind::ConsumerGroup => format!("consumer group with ID: {}", self.consumer.id),
}
}
}
#[async_trait]
impl CliCommand for GetConsumerOffsetCmd {
fn explain(&self) -> String {
format!(
"get consumer offset for {} for stream with ID: {} and topic with ID: {} and partition with ID: {}",
self.get_consumer_info(),
self.stream_id,
self.topic_id,
self.partition_id,
)
}
async fn execute_cmd(&mut self, client: &dyn Client) -> anyhow::Result<(), anyhow::Error> {
let consumer_offset = client.get_consumer_offset(&self.consumer, &self.stream_id, &self.topic_id, Some(self.partition_id)).await.with_context(|| {
format!(
"Problem getting consumer offset for {} for stream with ID: {} and topic with ID: {} and partition with ID: {}",
self.get_consumer_info(), self.stream_id, self.topic_id, self.partition_id
)
})?;
if consumer_offset.is_none() {
event!(target: PRINT_TARGET, Level::INFO, "Consumer offset for {} for stream with ID: {} and topic with ID: {} and partition with ID: {} was not found", self.get_consumer_info(), self.stream_id, self.topic_id, self.partition_id);
return Ok(());
}
let consumer_offset = consumer_offset.unwrap();
let mut table = Table::new();
table.set_header(vec!["Property", "Value"]);
table.add_row(vec![
"Consumer ID",
format!("{}", self.consumer.id).as_str(),
]);
table.add_row(vec!["Stream ID", format!("{}", self.stream_id).as_str()]);
table.add_row(vec!["Topic ID", format!("{}", self.topic_id).as_str()]);
table.add_row(vec![
"Partition ID",
format!("{}", consumer_offset.partition_id).as_str(),
]);
table.add_row(vec![
"Current offset",
format!("{}", consumer_offset.current_offset).as_str(),
]);
table.add_row(vec![
"Stored offset",
format!("{}", consumer_offset.stored_offset).as_str(),
]);
event!(target: PRINT_TARGET, Level::INFO, "{table}");
Ok(())
}
}