karapace/crates/karapace-cli/src/commands/snapshots.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

39 lines
1.2 KiB
Rust

use super::{json_pretty, resolve_env_id, EXIT_SUCCESS};
use karapace_core::Engine;
use karapace_store::StoreLayout;
use std::path::Path;
pub fn run(engine: &Engine, store_path: &Path, env_id: &str, json: bool) -> Result<u8, String> {
let _layout = StoreLayout::new(store_path);
let resolved = resolve_env_id(engine, env_id)?;
let snapshots = engine
.list_snapshots(&resolved)
.map_err(|e| e.to_string())?;
if json {
let entries: Vec<_> = snapshots
.iter()
.map(|s| {
serde_json::json!({
"hash": s.hash,
"tar_hash": s.tar_hash,
"parent": s.parent,
})
})
.collect();
let payload = serde_json::json!({
"env_id": resolved,
"snapshots": entries,
});
println!("{}", json_pretty(&payload)?);
} else if snapshots.is_empty() {
println!("no snapshots for {env_id}");
} else {
println!("snapshots for {env_id}:");
for s in &snapshots {
println!(" {} (tar: {})", &s.hash[..12], &s.tar_hash[..12]);
}
}
Ok(EXIT_SUCCESS)
}