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/>.
|
* 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};
|
use super::{CliModule, CliModuleArgs};
|
||||||
|
|
||||||
|
@ -29,6 +31,7 @@ pub fn new() -> CliModule {
|
||||||
#[allow(clippy::needless_update)]
|
#[allow(clippy::needless_update)]
|
||||||
CliModule {
|
CliModule {
|
||||||
requires_paths: true,
|
requires_paths: true,
|
||||||
|
requires_config: true,
|
||||||
enable_logs: false,
|
enable_logs: false,
|
||||||
subcommand: "launcher".to_string(),
|
subcommand: "launcher".to_string(),
|
||||||
entry: launcher_main,
|
entry: launcher_main,
|
||||||
|
@ -39,25 +42,45 @@ pub fn new() -> CliModule {
|
||||||
#[cfg(feature = "modulo")]
|
#[cfg(feature = "modulo")]
|
||||||
fn launcher_main(args: CliModuleArgs) -> i32 {
|
fn launcher_main(args: CliModuleArgs) -> i32 {
|
||||||
let paths = args.paths.expect("missing paths in launcher main");
|
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");
|
let icon_paths = crate::icon::load_icon_paths(&paths.runtime).expect("unable to load icon paths");
|
||||||
|
|
||||||
// TODO: should move wizard to "init" subcommand?
|
// TODO: should move wizard to "init" subcommand?
|
||||||
|
|
||||||
let is_legacy_version_page_enabled = util::is_legacy_version_running(&paths.runtime);
|
let is_legacy_version_page_enabled = util::is_legacy_version_running(&paths.runtime);
|
||||||
let runtime_dir_clone = paths.runtime.clone();
|
let runtime_dir_clone = paths.runtime.clone();
|
||||||
let is_legacy_version_running_handler = Box::new(move || {
|
let is_legacy_version_running_handler =
|
||||||
util::is_legacy_version_running(&runtime_dir_clone)
|
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 {
|
espanso_modulo::wizard::show(WizardOptions {
|
||||||
version: crate::VERSION.to_string(),
|
version: crate::VERSION.to_string(),
|
||||||
is_welcome_page_enabled: true, // TODO
|
is_welcome_page_enabled: true, // TODO
|
||||||
is_move_bundle_page_enabled: false, // TODO
|
is_move_bundle_page_enabled: false, // TODO
|
||||||
is_legacy_version_page_enabled,
|
is_legacy_version_page_enabled,
|
||||||
is_migrate_page_enabled: true, // TODO,
|
is_migrate_page_enabled,
|
||||||
is_add_path_page_enabled: true, // TODO
|
is_add_path_page_enabled: true, // TODO
|
||||||
is_accessibility_page_enabled: true, // TODO
|
is_accessibility_page_enabled: true, // TODO
|
||||||
window_icon_path: icon_paths
|
window_icon_path: icon_paths
|
||||||
.wizard_icon
|
.wizard_icon
|
||||||
.map(|path| path.to_string_lossy().to_string()),
|
.map(|path| path.to_string_lossy().to_string()),
|
||||||
|
@ -68,7 +91,7 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
|
||||||
accessibility_image_2_path: None,
|
accessibility_image_2_path: None,
|
||||||
handlers: WizardHandlers {
|
handlers: WizardHandlers {
|
||||||
is_legacy_version_running: Some(is_legacy_version_running_handler),
|
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,
|
add_to_path: None,
|
||||||
enable_accessibility: None,
|
enable_accessibility: None,
|
||||||
is_accessibility_enabled: None,
|
is_accessibility_enabled: None,
|
||||||
|
@ -83,4 +106,4 @@ fn launcher_main(args: CliModuleArgs) -> i32 {
|
||||||
#[cfg(not(feature = "modulo"))]
|
#[cfg(not(feature = "modulo"))]
|
||||||
fn launcher_main(_: CliModuleArgs) -> i32 {
|
fn launcher_main(_: CliModuleArgs) -> i32 {
|
||||||
// TODO: handle what happens here
|
// TODO: handle what happens here
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,15 +17,62 @@
|
||||||
* along with espanso. If not, see <https://www.gnu.org/licenses/>.
|
* 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 {
|
pub fn is_legacy_version_running(runtime_path: &Path) -> bool {
|
||||||
let legacy_lock_file = acquire_legacy_lock(runtime_path);
|
let legacy_lock_file = acquire_legacy_lock(runtime_path);
|
||||||
if legacy_lock_file.is_none() {
|
if legacy_lock_file.is_none() {
|
||||||
true
|
true
|
||||||
} else {
|
} else {
|
||||||
false
|
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