From 3eabfdfb85aa05215d9d11c3f13b56fbfa4e040d Mon Sep 17 00:00:00 2001 From: Vincenzo Palazzo Date: Fri, 12 Apr 2024 15:20:54 +0200 Subject: [PATCH] fixup! feat(core): nurse clean up the global repository Signed-off-by: Vincenzo Palazzo --- coffee_cmd/src/coffee_term/command_show.rs | 15 +++++------- coffee_cmd/src/main.rs | 2 +- coffee_core/src/coffee.rs | 27 ++++++++++++---------- coffee_core/src/nurse/strategy.rs | 16 ++++--------- coffee_github/src/repository.rs | 8 +++---- coffee_httpd/src/httpd/server.rs | 4 +++- coffee_lib/src/plugin_manager.rs | 2 +- coffee_lib/src/repository.rs | 9 ++++---- coffee_plugin/src/plugin/plugin_mod.rs | 6 ++++- 9 files changed, 44 insertions(+), 45 deletions(-) diff --git a/coffee_cmd/src/coffee_term/command_show.rs b/coffee_cmd/src/coffee_term/command_show.rs index 28497d84..ec48a992 100644 --- a/coffee_cmd/src/coffee_term/command_show.rs +++ b/coffee_cmd/src/coffee_term/command_show.rs @@ -114,18 +114,15 @@ pub fn show_nurse_verify(nurse_verify: &ChainOfResponsibilityStatus) -> Result<( } } Defect::CoffeeGlobalrepoCleanup(networks) => { - let defect = format!( - "Global repository migration completed for the networks: {}", - networks - .iter() - .map(|(network, _)| format!("{network} ")) - .collect::() - .trim_end() - ); + let defect = "Network specific repository missing"; + let networks = networks + .iter() + .map(|(network, _)| network.clone()) + .collect::>(); table.push([ term::format::positive("●").into(), term::format::bold(defect.to_owned()), - term::format::highlight("_".to_owned()), + term::format::highlight(networks.join(", ")), ]); } } diff --git a/coffee_cmd/src/main.rs b/coffee_cmd/src/main.rs index ee379490..68d80abe 100644 --- a/coffee_cmd/src/main.rs +++ b/coffee_cmd/src/main.rs @@ -90,7 +90,7 @@ async fn run(args: CoffeeArgs, mut coffee: CoffeeManager) -> Result<(), CoffeeEr match action { Some(RemoteAction::Add { name, url }) => { let mut spinner = term::spinner(format!("Fetch remote from {url}")); - let result = coffee.add_remote(&name, &url).await; + let result = coffee.add_remote(&name, &url, false).await; if let Err(err) = &result { spinner.error(format!("Error while add remote: {err}")); return result; diff --git a/coffee_core/src/coffee.rs b/coffee_core/src/coffee.rs index 0ed4adf2..16a6c399 100644 --- a/coffee_core/src/coffee.rs +++ b/coffee_core/src/coffee.rs @@ -1,7 +1,6 @@ //! Coffee mod implementation use std::collections::HashMap; use std::fmt::Debug; -use std::path::Path; use std::vec::Vec; use async_trait::async_trait; @@ -21,7 +20,7 @@ use coffee_lib::plugin_manager::PluginManager; use coffee_lib::repository::Repository; use coffee_lib::types::response::*; use coffee_lib::url::URL; -use coffee_lib::utils::{check_dir_or_make_if_missing, copy_dir_if_exist, rm_dir_if_exist}; +use coffee_lib::utils::rm_dir_if_exist; use coffee_lib::{commit_id, error, get_repo_info, sh}; use coffee_storage::model::repository::{Kind, Repository as RepositoryInfo}; use coffee_storage::nosql_db::NoSQlStorage; @@ -427,8 +426,8 @@ impl PluginManager for CoffeeManager { Ok(()) } - async fn add_remote(&mut self, name: &str, url: &str) -> Result<(), CoffeeError> { - if self.repos.contains_key(name) { + async fn add_remote(&mut self, name: &str, url: &str, force: bool) -> Result<(), CoffeeError> { + if !force && self.repos.contains_key(name) { return Err(error!("repository with name: {name} already exists")); } let url = URL::new(&self.config.path(), url, name); @@ -544,17 +543,22 @@ impl PluginManager for CoffeeManager { let mut actions = self.patch_repository_locally_absent(repos.to_vec()).await?; nurse_actions.append(&mut actions); } + // FIXME: this should act just for a single network not for everyone Defect::CoffeeGlobalrepoCleanup(networks) => { - let global_repo = format!("{}/repositories", self.config.root_path); - for (network, path) in networks { - log::info!("{network} - {path}"); - check_dir_or_make_if_missing(path.to_owned()).await?; - if !Path::exists(Path::new(&path)) { - copy_dir_if_exist(&global_repo, path).await?; + for network in networks { + log::debug!("reindexing repository for the network `{:?}`", network); + let iter = self + .repos + .iter() + .map(|(name, repo)| (name.to_owned(), repo.url())) + .collect::>(); + for (name, url) in iter { + self.add_remote(&name, &url.url_string, true).await?; } nurse_actions - .push(NurseStatus::MovingGlobalRepostoryTo(network.to_owned())); + .push(NurseStatus::MovingGlobalRepostoryTo(network.1.to_owned())); } + let global_repo = format!("{}/repositories", self.config.root_path); rm_dir_if_exist(&global_repo).await?; } } @@ -587,7 +591,6 @@ impl PluginManager for CoffeeManager { .get_mut(repo_name) .ok_or_else(|| error!("repository with name: {repo_name} not found"))?; - repo.change_root_path(&self.config.path()); match repo.recover().await { Ok(_) => { log::info!("repository {} recovered", repo_name.clone()); diff --git a/coffee_core/src/nurse/strategy.rs b/coffee_core/src/nurse/strategy.rs index 0ecfc555..79ff2b4b 100644 --- a/coffee_core/src/nurse/strategy.rs +++ b/coffee_core/src/nurse/strategy.rs @@ -90,19 +90,13 @@ impl Handler for CoffeeRepositoryDirCleanUp { self: Arc, coffee: &CoffeeManager, ) -> Result, CoffeeError> { - let networks = ["testnet", "signet", "bitcoin", "liquid"]; + let networks = coffee.config.network; // Check whether there exists a network-specific repositories folder for each network. let mut directory_moving = vec![]; - for network in networks { - let network_dir = format!("{}/{network}", coffee.config.root_path); - if !Path::exists(Path::new(&network_dir)) { - log::debug!("network dir `{network_dir}` not found"); - continue; - } - let subpath_repo = format!("{}/{network}/repositories", coffee.config.root_path); - if !Path::exists(Path::new(&subpath_repo)) { - directory_moving.push((network.to_string(), subpath_repo)); - } + let network_dir = format!("{}/{network}", coffee.config.root_path); + let subpath_repo = format!("{}/{network}/repositories", coffee.config.root_path); + if !Path::exists(Path::new(&subpath_repo)) { + directory_moving.push((network.to_string(), subpath_repo)); } if directory_moving.is_empty() { return Ok(None); diff --git a/coffee_github/src/repository.rs b/coffee_github/src/repository.rs index fa6f7e25..1e6d5ffa 100644 --- a/coffee_github/src/repository.rs +++ b/coffee_github/src/repository.rs @@ -233,10 +233,6 @@ impl Repository for Github { } } - fn change_root_path(&mut self, path: &str) { - self.url.set_coffee_path(path); - } - async fn upgrade( &mut self, plugins: &Vec, @@ -343,6 +339,10 @@ impl Repository for Github { fn as_any(&self) -> &dyn Any { self } + + fn plugins(&mut self) -> &mut Vec { + &mut self.plugins + } } impl From for Github { diff --git a/coffee_httpd/src/httpd/server.rs b/coffee_httpd/src/httpd/server.rs index dc429fd5..ebfaed0c 100644 --- a/coffee_httpd/src/httpd/server.rs +++ b/coffee_httpd/src/httpd/server.rs @@ -130,7 +130,9 @@ async fn coffee_remote_add( let repository_url = &body.repository_url; let mut coffee = data.coffee.lock().await; - let result = coffee.add_remote(repository_name, repository_url).await; + let result = coffee + .add_remote(repository_name, repository_url, false) + .await; handle_httpd_response!(result, "Repository '{repository_name}' added successfully") } diff --git a/coffee_lib/src/plugin_manager.rs b/coffee_lib/src/plugin_manager.rs index 103b77e1..78efa0df 100644 --- a/coffee_lib/src/plugin_manager.rs +++ b/coffee_lib/src/plugin_manager.rs @@ -28,7 +28,7 @@ pub trait PluginManager { async fn upgrade(&mut self, repo: &str, verbose: bool) -> Result; /// add the remote repository to the plugin manager. - async fn add_remote(&mut self, name: &str, url: &str) -> Result<(), CoffeeError>; + async fn add_remote(&mut self, name: &str, url: &str, force: bool) -> Result<(), CoffeeError>; /// remove the remote repository from the plugin manager. async fn rm_remote(&mut self, name: &str) -> Result<(), CoffeeError>; diff --git a/coffee_lib/src/repository.rs b/coffee_lib/src/repository.rs index 586a51de..ffa7ee8e 100644 --- a/coffee_lib/src/repository.rs +++ b/coffee_lib/src/repository.rs @@ -34,11 +34,6 @@ pub trait Repository: Any { /// recover the repository from the commit id. async fn recover(&mut self) -> Result<(), CoffeeError>; - /// While migrating there is a possibility that we should - /// move an old repository into a new path. So this - /// is semplyfing this process. - fn change_root_path(&mut self, path: &str); - /// return the name of the repository. fn name(&self) -> String; @@ -46,4 +41,8 @@ pub trait Repository: Any { fn url(&self) -> URL; fn as_any(&self) -> &dyn Any; + + /// Return the vector of plugin + /// that are inside the repository + fn plugins(&mut self) -> &mut Vec; } diff --git a/coffee_plugin/src/plugin/plugin_mod.rs b/coffee_plugin/src/plugin/plugin_mod.rs index 4f3fa403..9ad79237 100644 --- a/coffee_plugin/src/plugin/plugin_mod.rs +++ b/coffee_plugin/src/plugin/plugin_mod.rs @@ -119,7 +119,11 @@ fn coffee_remote(plugin: &mut Plugin, request: Value) -> Result coffee.add_remote(&request.name, &request.url()).await, + RemoteCmd::Add => { + coffee + .add_remote(&request.name, &request.url(), false) + .await + } RemoteCmd::Rm => coffee.rm_remote(&request.name).await, } })