feat(core): implement wizard migration handler
This commit is contained in:
parent
363a5cf2ef
commit
e992fe4f0c
|
@ -17,7 +17,9 @@
|
|||
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
use espanso_modulo::wizard::{WizardHandlers, WizardOptions};
|
||||
use espanso_modulo::wizard::{MigrationResult, WizardHandlers, WizardOptions};
|
||||
|
||||
use self::util::MigrationError;
|
||||
|
||||
use super::{CliModule, CliModuleArgs};
|
||||
|
||||
|
@ -29,6 +31,7 @@ pub fn new() -> CliModule {
|
|||
#[allow(clippy::needless_update)]
|
||||
CliModule {
|
||||
requires_paths: true,
|
||||
requires_config: true,
|
||||
enable_logs: false,
|
||||
subcommand: "launcher".to_string(),
|
||||
entry: launcher_main,
|
||||
|
@ -39,15 +42,35 @@ pub fn new() -> CliModule {
|
|||
#[cfg(feature = "modulo")]
|
||||
fn launcher_main(args: CliModuleArgs) -> i32 {
|
||||
let paths = args.paths.expect("missing paths in launcher main");
|
||||
let cli_args = args.cli_args.expect("missing cli_args in launcher main");
|
||||
let icon_paths = crate::icon::load_icon_paths(&paths.runtime).expect("unable to load icon paths");
|
||||
|
||||
// TODO: should move wizard to "init" subcommand?
|
||||
|
||||
let is_legacy_version_page_enabled = util::is_legacy_version_running(&paths.runtime);
|
||||
let runtime_dir_clone = paths.runtime.clone();
|
||||
let is_legacy_version_running_handler = Box::new(move || {
|
||||
util::is_legacy_version_running(&runtime_dir_clone)
|
||||
let is_legacy_version_running_handler =
|
||||
Box::new(move || util::is_legacy_version_running(&runtime_dir_clone));
|
||||
|
||||
let is_migrate_page_enabled = args.is_legacy_config;
|
||||
let paths_clone = paths.clone();
|
||||
let backup_and_migrate_handler =
|
||||
Box::new(move || match util::migrate_configuration(&paths_clone) {
|
||||
Ok(_) => {
|
||||
MigrationResult::Success
|
||||
}
|
||||
Err(error) => {
|
||||
match error.downcast_ref::<MigrationError>() {
|
||||
Some(MigrationError::DirtyError) => {
|
||||
MigrationResult::DirtyFailure
|
||||
}
|
||||
Some(MigrationError::CleanError) => {
|
||||
MigrationResult::CleanFailure
|
||||
}
|
||||
_ => {
|
||||
MigrationResult::UnknownFailure
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
espanso_modulo::wizard::show(WizardOptions {
|
||||
|
@ -55,7 +78,7 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
|
|||
is_welcome_page_enabled: true, // TODO
|
||||
is_move_bundle_page_enabled: false, // TODO
|
||||
is_legacy_version_page_enabled,
|
||||
is_migrate_page_enabled: true, // TODO,
|
||||
is_migrate_page_enabled,
|
||||
is_add_path_page_enabled: true, // TODO
|
||||
is_accessibility_page_enabled: true, // TODO
|
||||
window_icon_path: icon_paths
|
||||
|
@ -68,7 +91,7 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
|
|||
accessibility_image_2_path: None,
|
||||
handlers: WizardHandlers {
|
||||
is_legacy_version_running: Some(is_legacy_version_running_handler),
|
||||
backup_and_migrate: None,
|
||||
backup_and_migrate: Some(backup_and_migrate_handler),
|
||||
add_to_path: None,
|
||||
enable_accessibility: None,
|
||||
is_accessibility_enabled: None,
|
||||
|
|
|
@ -17,9 +17,13 @@
|
|||
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
use std::path::Path;
|
||||
use std::{path::Path, process::Command};
|
||||
|
||||
use crate::lock::acquire_legacy_lock;
|
||||
use anyhow::Result;
|
||||
use thiserror::Error;
|
||||
use espanso_path::Paths;
|
||||
|
||||
use crate::{exit_code::{MIGRATE_CLEAN_FAILURE, MIGRATE_DIRTY_FAILURE}, lock::acquire_legacy_lock};
|
||||
|
||||
pub fn is_legacy_version_running(runtime_path: &Path) -> bool {
|
||||
let legacy_lock_file = acquire_legacy_lock(runtime_path);
|
||||
|
@ -29,3 +33,46 @@ pub fn is_legacy_version_running(runtime_path: &Path) -> bool {
|
|||
false
|
||||
}
|
||||
}
|
||||
|
||||
pub fn migrate_configuration(paths: &Paths) -> Result<()> {
|
||||
let espanso_exe_path = std::env::current_exe()?;
|
||||
let mut command = Command::new(&espanso_exe_path.to_string_lossy().to_string());
|
||||
command.args(&["migrate", "--noconfirm"]);
|
||||
command.env(
|
||||
"ESPANSO_CONFIG_DIR",
|
||||
paths.config.to_string_lossy().to_string(),
|
||||
);
|
||||
command.env(
|
||||
"ESPANSO_PACKAGE_DIR",
|
||||
paths.packages.to_string_lossy().to_string(),
|
||||
);
|
||||
command.env(
|
||||
"ESPANSO_RUNTIME_DIR",
|
||||
paths.runtime.to_string_lossy().to_string(),
|
||||
);
|
||||
|
||||
let mut child = command.spawn()?;
|
||||
let result = child.wait()?;
|
||||
|
||||
if result.success() {
|
||||
Ok(())
|
||||
} else {
|
||||
match result.code() {
|
||||
Some(code) if code == MIGRATE_CLEAN_FAILURE => Err(MigrationError::CleanError.into()),
|
||||
Some(code) if code == MIGRATE_DIRTY_FAILURE=> Err(MigrationError::DirtyError.into()),
|
||||
_ => Err(MigrationError::UnexpectedError.into())
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Error, Debug)]
|
||||
pub enum MigrationError {
|
||||
#[error("clean error")]
|
||||
CleanError,
|
||||
|
||||
#[error("dirty error")]
|
||||
DirtyError,
|
||||
|
||||
#[error("unexpected error")]
|
||||
UnexpectedError,
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user