1
0
Fork 0

[WINDOWS] Add bin folder in path

This commit is contained in:
Florian RICHER (MrDev023) 2021-07-24 22:38:33 +02:00
parent bb6d50d76c
commit 98564956ac
9 changed files with 101 additions and 13 deletions

12
Cargo.lock generated
View file

@ -46,6 +46,7 @@ dependencies = [
"serde_json",
"structopt",
"tar",
"winreg 0.9.0",
"zip",
]
@ -770,7 +771,7 @@ dependencies = [
"wasm-bindgen",
"wasm-bindgen-futures",
"web-sys",
"winreg",
"winreg 0.7.0",
]
[[package]]
@ -1251,6 +1252,15 @@ dependencies = [
"winapi",
]
[[package]]
name = "winreg"
version = "0.9.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "16cdb3898397cf7f624c294948669beafaeebc5577d5ec53d0afb76633593597"
dependencies = [
"winapi",
]
[[package]]
name = "xattr"
version = "0.2.2"

View file

@ -15,3 +15,6 @@ zip = "0.5"
tar = "0.4"
flate2 = "1.0"
dirs = "3.0"
[target.'cfg(windows)'.dependencies]
winreg = "0.9"

View file

@ -4,8 +4,6 @@ use crate::common::utils::downloader;
use crate::common::utils::extractor;
use crate::common::utils::installer;
// use std::process::Command;
pub fn install() -> Result<(), String> {
println!("Installing FVM");

View file

@ -0,0 +1,19 @@
#[cfg(target_os = "windows")]
mod windows;
pub fn configure() -> Result<(), String> {
#[cfg(target_os = "windows")]
windows::configure().ok_or(format!("Failed to configure environment"))?;
#[cfg(not(target_os = "windows"))]
#[cfg(not(target_os = "linux"))]
#[cfg(not(target_os = "macos"))]
{
Err(format!("OS not supported"))
}
#[cfg(any(target_os = "windows", target_os = "linux", target_os = "macos"))]
{
Ok(())
}
}

View file

@ -0,0 +1,45 @@
use winreg::RegKey;
use winreg::enums::*;
use crate::common::utils::installer;
pub enum ConfigEnvMode {
ADD,
REMOVE
}
fn env_exist(path_env: &str, binary_folder: &str) -> bool {
for env in path_env.split(';') {
if env == binary_folder {
return true
}
}
false
}
pub fn configure_env(mode: ConfigEnvMode) -> Option<()> {
let hklm = RegKey::predef(HKEY_CURRENT_USER);
let environment = hklm.open_subkey_with_flags("Environment", KEY_READ | KEY_WRITE).ok()?;
let mut reg_value : String = environment.get_value("PATH").ok()?;
let binary_folder_path = installer::get_install_dir(installer::InstallType::Command).ok()?;
let binary_folder_str = binary_folder_path.to_str()?;
match mode {
ConfigEnvMode::ADD => {
if !env_exist(reg_value.as_str(), binary_folder_str) {
reg_value.push_str(format!(";{}", binary_folder_str).as_str()); // Add binary folder to path
environment.set_value("PATH", &reg_value).ok()?;
println!("[INFO] Folder {} added to PATH", binary_folder_str);
}
},
ConfigEnvMode::REMOVE => {
if env_exist(reg_value.as_str(), binary_folder_str) {
let new_value = reg_value.replace(format!(";{}", binary_folder_str).as_str(), ""); // Remove binary folder to path
environment.set_value("PATH", &new_value).ok()?;
println!("[INFO] Folder {} removed to PATH", binary_folder_str);
}
}
}
Some(())
}

View file

@ -0,0 +1,7 @@
mod env;
pub fn configure() -> Option<()> {
env::configure_env(env::ConfigEnvMode::ADD)?;
Some(())
}

View file

@ -6,11 +6,16 @@ pub enum InstallType {
Config
}
pub fn get_install_dir() -> Result<PathBuf, String> {
pub fn get_install_dir(install_type: InstallType) -> Result<PathBuf, String> {
let home_dir = dirs::home_dir()
.ok_or(format!("Failed to get home_directory"))?;
Ok(home_dir.join(super::super::INSTALL_FOLDER))
let subfolder = match install_type {
InstallType::Command => "bin",
InstallType::Config => "configs"
};
Ok(home_dir.join(super::super::INSTALL_FOLDER).join(subfolder))
}
fn copy_dir_all(src: impl AsRef<Path>, dst: impl AsRef<Path>) -> io::Result<()> {
@ -30,12 +35,7 @@ fn copy_dir_all(src: impl AsRef<Path>, dst: impl AsRef<Path>) -> io::Result<()>
pub fn install(source_path: &str, install_type: InstallType) -> Option <()> {
let source_folder = std::path::Path::new(super::super::TEMP_FOLDER).join(source_path);
let subfolder = match install_type {
InstallType::Command => "bin",
InstallType::Config => "configs"
};
let install_folder = get_install_dir().ok()?.join(subfolder);
let install_folder = get_install_dir(install_type).ok()?;
copy_dir_all(source_folder, install_folder).ok()?;
Some(())
}

View file

@ -2,3 +2,4 @@ pub mod downloader;
pub mod extractor;
pub mod git;
pub mod installer;
pub mod configure;

View file

@ -10,6 +10,11 @@ mod macos;
pub mod common;
fn main() {
if let Err(err) = common::utils::configure::configure() {
eprintln!("[ERROR] {}", err);
return;
}
#[cfg(target_os = "windows")]
windows::start();