X-Git-Url: https://git.r.bdr.sh/rbdr/blog/blobdiff_plain/d620665f6b2e1ae5db4c98a09e35bd63133ae87f..c667f2401b3ada832f8456d1661ea3fba667fc91:/src/command/publish_archive.rs?ds=sidebyside diff --git a/src/command/publish_archive.rs b/src/command/publish_archive.rs index 4275c38..c727c16 100644 --- a/src/command/publish_archive.rs +++ b/src/command/publish_archive.rs @@ -1,4 +1,8 @@ -use std::io::Result; +use std::io::{Error, ErrorKind::Other, Result}; +use crate::configuration::Configuration; +use std::process::{Command, Stdio}; + +const COMMAND: &str = "rsync"; pub struct PublishArchive; @@ -13,8 +17,27 @@ impl super::Command for PublishArchive { vec![] } - fn execute(&self, input: Option<&String>) -> Result<()> { - println!("Publish Archive: {:?}!", input); + fn execute(&self, input: Option<&String>, configuration: &Configuration, _: &String) -> Result<()> { + + let input = input + .ok_or_else(|| Error::new(Other, "You must provide a location to publish the archive"))?; + + Command::new(COMMAND) + .arg("--version") + .stdout(Stdio::null()) + .stderr(Stdio::null()) + .status() + .map_err(|_| Error::new(Other, "Publishing requires rsync"))?; + + + Command::new(COMMAND) + .arg("-r") + .arg(format!("{}/", &configuration.archive_output_directory.display())) + .arg(input.as_str()) + .stdout(Stdio::null()) + .stderr(Stdio::null()) + .status() + .map_err(|_| Error::new(Other, "Rsync failed to publish."))?; return Ok(()) } @@ -27,6 +50,6 @@ impl super::Command for PublishArchive { } fn help(&self) -> &'static str { - "\tPublishes the archive to a remote host." + "\tPublishes the archive to a remote host" } }