iggy_cli/commands/binary_partitions/
delete_partitions.rs1use crate::commands::cli_command::{CliCommand, PRINT_TARGET};
20use anyhow::Context;
21use async_trait::async_trait;
22use iggy_common::Client;
23use iggy_common::Identifier;
24use iggy_common::delete_partitions::DeletePartitions;
25use tracing::{Level, event};
26
27pub struct DeletePartitionsCmd {
28 delete_partitions: DeletePartitions,
29}
30
31impl DeletePartitionsCmd {
32 pub fn new(stream_id: Identifier, topic_id: Identifier, partitions_count: u32) -> Self {
33 Self {
34 delete_partitions: DeletePartitions {
35 stream_id,
36 topic_id,
37 partitions_count,
38 },
39 }
40 }
41}
42
43#[async_trait]
44impl CliCommand for DeletePartitionsCmd {
45 fn explain(&self) -> String {
46 let mut partitions = String::from("partition");
47 if self.delete_partitions.partitions_count > 1 {
48 partitions.push('s');
49 };
50
51 format!(
52 "delete {} {partitions} for topic with ID: {} and stream with ID: {}",
53 self.delete_partitions.partitions_count,
54 self.delete_partitions.topic_id,
55 self.delete_partitions.stream_id
56 )
57 }
58
59 async fn execute_cmd(&mut self, client: &dyn Client) -> anyhow::Result<(), anyhow::Error> {
60 let mut partitions = String::from("partition");
61 if self.delete_partitions.partitions_count > 1 {
62 partitions.push('s');
63 };
64
65 client
66 .delete_partitions(
67 &self.delete_partitions.stream_id,
68 &self.delete_partitions.topic_id,
69 self.delete_partitions.partitions_count,
70 )
71 .await
72 .with_context(|| {
73 format!(
74 "Problem deleting {} {partitions} for topic with ID: {} and stream with ID: {}",
75 self.delete_partitions.partitions_count,
76 self.delete_partitions.topic_id,
77 self.delete_partitions.stream_id
78 )
79 })?;
80
81 event!(target: PRINT_TARGET, Level::INFO,
82 "Deleted {} {partitions} for topic with ID: {} and stream with ID: {}",
83 self.delete_partitions.partitions_count,
84 self.delete_partitions.topic_id,
85 self.delete_partitions.stream_id,
86 );
87
88 Ok(())
89 }
90}