Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
9 changes: 9 additions & 0 deletions crates/redisctl/src/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -953,6 +953,9 @@ pub enum CloudSubscriptionCommands {
/// Subscription configuration as JSON string or @file.json
#[arg(long)]
data: String,
/// Async operation options
#[command(flatten)]
async_ops: crate::commands::cloud::async_utils::AsyncOperationArgs,
},

/// Update subscription configuration
Expand All @@ -962,6 +965,9 @@ pub enum CloudSubscriptionCommands {
/// Update configuration as JSON string or @file.json
#[arg(long)]
data: String,
/// Async operation options
#[command(flatten)]
async_ops: crate::commands::cloud::async_utils::AsyncOperationArgs,
},

/// Delete a subscription
Expand All @@ -971,6 +977,9 @@ pub enum CloudSubscriptionCommands {
/// Skip confirmation prompt
#[arg(long)]
force: bool,
/// Async operation options
#[command(flatten)]
async_ops: crate::commands::cloud::async_utils::AsyncOperationArgs,
},

/// Get available Redis versions
Expand Down
17 changes: 14 additions & 3 deletions crates/redisctl/src/commands/cloud/subscription.rs
Original file line number Diff line number Diff line change
Expand Up @@ -49,33 +49,44 @@ pub async fn handle_subscription_command(
CloudSubscriptionCommands::Get { id } => {
get_subscription(conn_mgr, profile_name, *id, output_format, query).await
}
CloudSubscriptionCommands::Create { data } => {
CloudSubscriptionCommands::Create { data, async_ops } => {
subscription_impl::create_subscription(
conn_mgr,
profile_name,
data,
async_ops,
output_format,
query,
)
.await
}
CloudSubscriptionCommands::Update { id, data } => {
CloudSubscriptionCommands::Update {
id,
data,
async_ops,
} => {
subscription_impl::update_subscription(
conn_mgr,
profile_name,
*id,
data,
async_ops,
output_format,
query,
)
.await
}
CloudSubscriptionCommands::Delete { id, force } => {
CloudSubscriptionCommands::Delete {
id,
force,
async_ops,
} => {
subscription_impl::delete_subscription(
conn_mgr,
profile_name,
*id,
*force,
async_ops,
output_format,
query,
)
Expand Down
88 changes: 34 additions & 54 deletions crates/redisctl/src/commands/cloud/subscription_impl.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
//! Implementation of additional subscription commands

use super::async_utils::{AsyncOperationArgs, handle_async_response};
use super::utils::*;
use crate::cli::OutputFormat;
use crate::connection::ConnectionManager;
Expand Down Expand Up @@ -41,6 +42,7 @@ pub async fn create_subscription(
conn_mgr: &ConnectionManager,
profile_name: Option<&str>,
data: &str,
async_ops: &AsyncOperationArgs,
output_format: OutputFormat,
query: Option<&str>,
) -> CliResult<()> {
Expand All @@ -52,26 +54,16 @@ pub async fn create_subscription(
.await
.context("Failed to create subscription")?;

let result = if let Some(q) = query {
apply_jmespath(&response, q)?
} else {
response
};

match output_format {
OutputFormat::Table => {
println!("Subscription created successfully");
if let Some(task_id) = result.get("taskId") {
println!("Task ID: {}", task_id);
}
if let Some(sub_id) = result.get("resourceId") {
println!("Subscription ID: {}", sub_id);
}
}
_ => print_json_or_yaml(result, output_format)?,
}

Ok(())
handle_async_response(
conn_mgr,
profile_name,
response,
async_ops,
output_format,
query,
"Subscription created successfully",
)
.await
}

/// Update subscription configuration
Expand All @@ -80,6 +72,7 @@ pub async fn update_subscription(
profile_name: Option<&str>,
id: u32,
data: &str,
async_ops: &AsyncOperationArgs,
output_format: OutputFormat,
query: Option<&str>,
) -> CliResult<()> {
Expand All @@ -91,23 +84,16 @@ pub async fn update_subscription(
.await
.context("Failed to update subscription")?;

let result = if let Some(q) = query {
apply_jmespath(&response, q)?
} else {
response
};

match output_format {
OutputFormat::Table => {
println!("Subscription updated successfully");
if let Some(task_id) = result.get("taskId") {
println!("Task ID: {}", task_id);
}
}
_ => print_json_or_yaml(result, output_format)?,
}

Ok(())
handle_async_response(
conn_mgr,
profile_name,
response,
async_ops,
output_format,
query,
"Subscription updated successfully",
)
.await
}

/// Delete a subscription
Expand All @@ -116,6 +102,7 @@ pub async fn delete_subscription(
profile_name: Option<&str>,
id: u32,
force: bool,
async_ops: &AsyncOperationArgs,
output_format: OutputFormat,
query: Option<&str>,
) -> CliResult<()> {
Expand Down Expand Up @@ -143,23 +130,16 @@ pub async fn delete_subscription(
.await
.context("Failed to delete subscription")?;

let result = if let Some(q) = query {
apply_jmespath(&response, q)?
} else {
response
};

match output_format {
OutputFormat::Table => {
println!("Subscription deletion initiated");
if let Some(task_id) = result.get("taskId") {
println!("Task ID: {}", task_id);
}
}
_ => print_json_or_yaml(result, output_format)?,
}

Ok(())
handle_async_response(
conn_mgr,
profile_name,
response,
async_ops,
output_format,
query,
"Subscription deletion initiated",
)
.await
}

/// Redis version info for table display
Expand Down
Loading