karapace/crates/karapace-cli/src/commands/restore.rs
Marco Allegretti 1416b0fc99 feat: karapace-cli — 23 commands, thin dispatcher, progress indicators
- 23 commands, each in its own module under commands/
- Thin main.rs dispatcher with clap subcommand routing
- Progress spinners (indicatif) and colored state output (console)
- Environment resolution by env_id, short_id, name, or prefix
- Structured JSON output (--json) on all query commands
- --verbose/-v for debug, --trace for trace-level logging
- KARAPACE_LOG env var for fine-grained log control
- Exit codes: 0 success, 1 failure, 2 manifest error, 3 store error
- Prerequisite check before runtime operations
- Shell completions (bash/zsh/fish/elvish/powershell) and man page generation
2026-02-22 18:37:54 +01:00

31 lines
890 B
Rust

use super::{json_pretty, resolve_env_id, EXIT_SUCCESS};
use karapace_core::{Engine, StoreLock};
use karapace_store::StoreLayout;
use std::path::Path;
pub fn run(
engine: &Engine,
store_path: &Path,
env_id: &str,
snapshot_hash: &str,
json: bool,
) -> Result<u8, String> {
let layout = StoreLayout::new(store_path);
let _lock = StoreLock::acquire(&layout.lock_file()).map_err(|e| format!("store lock: {e}"))?;
let resolved = resolve_env_id(engine, env_id)?;
engine
.restore(&resolved, snapshot_hash)
.map_err(|e| e.to_string())?;
if json {
let payload = serde_json::json!({
"env_id": resolved,
"restored_snapshot": snapshot_hash,
});
println!("{}", json_pretty(&payload)?);
} else {
println!("restored {env_id} from snapshot {snapshot_hash}");
}
Ok(EXIT_SUCCESS)
}