summaryrefslogtreecommitdiff
path: root/src/cmd/inspect.rs
diff options
context:
space:
mode:
authorLars Wirzenius <liw@liw.fi>2022-03-22 17:10:02 +0000
committerLars Wirzenius <liw@liw.fi>2022-03-22 17:10:02 +0000
commit4a9b26903d48d622f7f2a01eb54eec88e92da868 (patch)
tree6d1a5f4fa835cd217d256ac3cdd5baec5902a2af /src/cmd/inspect.rs
parent7ae1f33ad0cd0df227e83997268ce2f3540db8d7 (diff)
parent018fcd28c8dbf84d34cc370496139f678664ca8f (diff)
downloadobnam2-4a9b26903d48d622f7f2a01eb54eec88e92da868.tar.gz
Merge branch 'liw/schema-refactor' into 'main'
add backup database schema to evolove; break server database Closes #194 and #192 See merge request obnam/obnam!222
Diffstat (limited to 'src/cmd/inspect.rs')
-rw-r--r--src/cmd/inspect.rs40
1 files changed, 40 insertions, 0 deletions
diff --git a/src/cmd/inspect.rs b/src/cmd/inspect.rs
new file mode 100644
index 0000000..d5a75c6
--- /dev/null
+++ b/src/cmd/inspect.rs
@@ -0,0 +1,40 @@
+//! The `inspect` subcommand.
+
+use crate::client::BackupClient;
+use crate::config::ClientConfig;
+use crate::error::ObnamError;
+
+use log::info;
+use structopt::StructOpt;
+use tempfile::NamedTempFile;
+use tokio::runtime::Runtime;
+
+/// Make a backup.
+#[derive(Debug, StructOpt)]
+pub struct Inspect {
+ /// Reference to generation to inspect.
+ #[structopt()]
+ gen_id: String,
+}
+
+impl Inspect {
+ /// Run the command.
+ pub fn run(&self, config: &ClientConfig) -> Result<(), ObnamError> {
+ let rt = Runtime::new()?;
+ rt.block_on(self.run_async(config))
+ }
+
+ async fn run_async(&self, config: &ClientConfig) -> Result<(), ObnamError> {
+ let temp = NamedTempFile::new()?;
+ let client = BackupClient::new(config)?;
+ let genlist = client.list_generations().await?;
+ let gen_id = genlist.resolve(&self.gen_id)?;
+ info!("generation id is {}", gen_id.as_chunk_id());
+
+ let gen = client.fetch_generation(&gen_id, temp.path()).await?;
+ let meta = gen.meta()?;
+ println!("schema_version: {}", meta.schema_version());
+
+ Ok(())
+ }
+}