feat: Use inquire::Confirm instead of raw std::io::Read for K8sAnywhere installation confirmation prompt

This commit is contained in:
Jean-Gabriel Gill-Couture 2025-04-23 11:56:55 -04:00
parent 45668638e1
commit 213fb25686
5 changed files with 10 additions and 12 deletions

1
Cargo.lock generated
View File

@ -1344,6 +1344,7 @@ dependencies = [
"harmony_macros",
"harmony_types",
"http 1.3.1",
"inquire",
"k8s-openapi",
"kube",
"libredfish",

View File

@ -34,6 +34,7 @@ k8s-openapi = { version = "0.24.0", features = ["v1_30"] }
serde_yaml = "0.9.34"
serde-value = "0.7.0"
http = "1.2.0"
inquire = "0.7.5"
[workspace.dependencies.uuid]
version = "1.11.0"

View File

@ -30,3 +30,4 @@ k8s-openapi = { workspace = true }
serde_yaml = { workspace = true }
http = { workspace = true }
serde-value = { workspace = true }
inquire.workspace = true

View File

@ -1,6 +1,7 @@
use std::io;
use async_trait::async_trait;
use inquire::Confirm;
use log::{info, warn};
use tokio::sync::OnceCell;
@ -76,18 +77,12 @@ impl K8sAnywhereTopology {
info!("No kubernetes configuration found");
if !k8s_anywhere_config.autoinstall {
info!(
"Harmony autoinstallation is not activated, do you wish to launch autoinstallation? (y/N) : "
);
let mut input = String::new();
let confirmation = Confirm::new( "Harmony autoinstallation is not activated, do you wish to launch autoinstallation? : ")
.with_default(false)
.prompt()
.expect("Unexpected prompt error");
io::stdin()
.read_line(&mut input)
.expect("Failed to read line");
let input = input.trim();
if !input.eq_ignore_ascii_case("y") {
if !confirmation {
warn!(
"Installation cancelled, K8sAnywhere could not initialize a valid Kubernetes client"
);

View File

@ -10,7 +10,7 @@ assert_cmd = "2.0.17"
clap = { version = "4.5.35", features = ["derive"] }
harmony = { path = "../harmony" }
harmony_tui = { path = "../harmony_tui", optional = true }
inquire = "0.7.5"
inquire.workspace = true
tokio.workspace = true