X-Git-Url: https://git.r.bdr.sh/rbdr/blog/blobdiff_plain/2998247083406f914b3647cedd19abf5507bf2c6..57351e3349ace090ea14b7814b84e5297e917770:/src/remote/mod.rs diff --git a/src/remote/mod.rs b/src/remote/mod.rs index e69de29..19514af 100644 --- a/src/remote/mod.rs +++ b/src/remote/mod.rs @@ -0,0 +1,65 @@ +mod git; + +use std::fs::{create_dir_all, remove_file, write, File}; +use std::io::{Error, ErrorKind::Other, Read, Result}; +use std::path::PathBuf; + +use git::Git; + +pub trait Remote { + fn can_handle(&self, remote: &str) -> bool; + fn sync_up(&self, remote: &str, directory: &PathBuf) -> Result<()>; + fn sync_down(&self, remote: &str, directory: &PathBuf) -> Result<()>; +} + +pub fn add(config_directory: &PathBuf, remote_config: &PathBuf, remote: &String) -> Result<()> { + create_dir_all(config_directory)?; + write(remote_config, remote)?; + Ok(()) +} + +pub fn remove(remote_config: &PathBuf) -> Result<()> { + if remote_config.exists() { + remove_file(remote_config)? + } + Ok(()) +} + +pub fn sync_up(data_directory: &PathBuf, remote_config: &PathBuf) -> Result<()> { + let remote_address = read_remote(remote_config) + .ok_or_else(|| Error::new(Other, "No remote is configured"))?; + create_dir_all(data_directory)?; + let remotes = available_remotes(); + for remote in remotes { + if remote.can_handle(&remote_address) { + return remote.sync_up(&remote_address, data_directory); + } + } + Err(Error::new(Other, "No valid strategies found for your configured remote.")) +} + +pub fn sync_down(data_directory: &PathBuf, remote_config: &PathBuf) -> Result<()> { + let remote_address = read_remote(remote_config) + .ok_or_else(|| Error::new(Other, "No remote is configured"))?; + create_dir_all(data_directory)?; + let remotes = available_remotes(); + for remote in remotes { + if remote.can_handle(&remote_address) { + return remote.sync_down(&remote_address, data_directory); + } + } + Err(Error::new(Other, "No valid strategies found for your configured remote.")) +} + +fn available_remotes() -> Vec> { + vec![ + Box::new(Git::new()) + ] +} + +fn read_remote(file_path: &PathBuf) -> Option { + let mut file = File::open(file_path).ok()?; + let mut contents = String::new(); + file.read_to_string(&mut contents).ok()?; + Some(contents) +}