2022-08-11 18:59:26 +08:00
|
|
|
use hbb_common::log;
|
|
|
|
|
2022-11-14 15:41:43 +08:00
|
|
|
/// shared by flutter and sciter main function
|
|
|
|
///
|
|
|
|
/// [Note]
|
|
|
|
/// If it returns [`None`], then the process will terminate, and flutter gui will not be started.
|
|
|
|
/// If it returns [`Some`], then the process will continue, and flutter gui will be started.
|
2022-09-15 17:41:10 +08:00
|
|
|
pub fn core_main() -> Option<Vec<String>> {
|
|
|
|
// https://docs.rs/flexi_logger/latest/flexi_logger/error_info/index.html#write
|
|
|
|
// though async logger more efficient, but it also causes more problems, disable it for now
|
|
|
|
// let mut _async_logger_holder: Option<flexi_logger::LoggerHandle> = None;
|
|
|
|
let mut args = Vec::new();
|
2022-10-11 14:52:46 +08:00
|
|
|
let mut flutter_args = Vec::new();
|
2022-09-15 17:41:10 +08:00
|
|
|
let mut i = 0;
|
2022-09-29 09:00:04 +08:00
|
|
|
let mut _is_elevate = false;
|
|
|
|
let mut _is_run_as_system = false;
|
2022-10-13 09:58:46 +08:00
|
|
|
let mut _is_flutter_connect = false;
|
2022-11-10 14:38:25 +08:00
|
|
|
let mut arg_exe = Default::default();
|
2022-09-15 17:41:10 +08:00
|
|
|
for arg in std::env::args() {
|
|
|
|
// to-do: how to pass to flutter?
|
2022-11-10 14:38:25 +08:00
|
|
|
if i == 0 {
|
|
|
|
arg_exe = arg;
|
2022-09-15 17:41:10 +08:00
|
|
|
} else if i > 0 {
|
2022-10-13 09:58:46 +08:00
|
|
|
#[cfg(feature = "flutter")]
|
|
|
|
if arg == "--connect" {
|
|
|
|
_is_flutter_connect = true;
|
|
|
|
}
|
2022-09-29 09:00:04 +08:00
|
|
|
if arg == "--elevate" {
|
|
|
|
_is_elevate = true;
|
|
|
|
} else if arg == "--run-as-system" {
|
|
|
|
_is_run_as_system = true;
|
|
|
|
} else {
|
|
|
|
args.push(arg);
|
|
|
|
}
|
2022-08-11 18:59:26 +08:00
|
|
|
}
|
2022-09-15 17:41:10 +08:00
|
|
|
i += 1;
|
|
|
|
}
|
2022-10-13 09:58:46 +08:00
|
|
|
#[cfg(feature = "flutter")]
|
|
|
|
if _is_flutter_connect {
|
2022-10-11 19:52:03 +08:00
|
|
|
return core_main_invoke_new_connection(std::env::args());
|
2022-10-12 16:06:15 +08:00
|
|
|
}
|
2022-11-10 14:38:25 +08:00
|
|
|
let click_setup = cfg!(windows) && args.is_empty() && crate::common::is_setup(&arg_exe);
|
|
|
|
if click_setup {
|
|
|
|
args.push("--install".to_owned());
|
|
|
|
flutter_args.push("--install".to_string());
|
2022-09-15 17:41:10 +08:00
|
|
|
}
|
2022-10-11 14:52:46 +08:00
|
|
|
if args.contains(&"--noinstall".to_string()) {
|
|
|
|
args.clear();
|
|
|
|
}
|
2022-09-15 17:41:10 +08:00
|
|
|
if args.len() > 0 && args[0] == "--version" {
|
|
|
|
println!("{}", crate::VERSION);
|
|
|
|
return None;
|
|
|
|
}
|
|
|
|
#[cfg(debug_assertions)]
|
|
|
|
{
|
2022-09-13 21:19:08 +08:00
|
|
|
use hbb_common::env_logger::*;
|
|
|
|
init_from_env(Env::default().filter_or(DEFAULT_FILTER_ENV, "info"));
|
2022-09-15 17:41:10 +08:00
|
|
|
}
|
|
|
|
#[cfg(not(debug_assertions))]
|
|
|
|
{
|
|
|
|
let mut path = hbb_common::config::Config::log_path();
|
|
|
|
if args.len() > 0 && args[0].starts_with("--") {
|
|
|
|
let name = args[0].replace("--", "");
|
|
|
|
if !name.is_empty() {
|
|
|
|
path.push(name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
use flexi_logger::*;
|
|
|
|
if let Ok(x) = Logger::try_with_env_or_str("debug") {
|
|
|
|
// _async_logger_holder =
|
|
|
|
x.log_to_file(FileSpec::default().directory(path))
|
|
|
|
//.write_mode(WriteMode::Async)
|
|
|
|
.format(opt_format)
|
|
|
|
.rotate(
|
|
|
|
Criterion::Age(Age::Day),
|
|
|
|
Naming::Timestamps,
|
|
|
|
Cleanup::KeepLogFiles(6),
|
|
|
|
)
|
|
|
|
.start()
|
|
|
|
.ok();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if args.is_empty() {
|
|
|
|
std::thread::spawn(move || crate::start_server(false));
|
|
|
|
} else {
|
|
|
|
#[cfg(windows)]
|
|
|
|
{
|
|
|
|
use crate::platform;
|
|
|
|
if args[0] == "--uninstall" {
|
|
|
|
if let Err(err) = platform::uninstall_me() {
|
|
|
|
log::error!("Failed to uninstall: {}", err);
|
|
|
|
}
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--after-install" {
|
|
|
|
if let Err(err) = platform::run_after_install() {
|
|
|
|
log::error!("Failed to after-install: {}", err);
|
|
|
|
}
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--before-uninstall" {
|
|
|
|
if let Err(err) = platform::run_before_uninstall() {
|
|
|
|
log::error!("Failed to before-uninstall: {}", err);
|
|
|
|
}
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--update" {
|
|
|
|
hbb_common::allow_err!(platform::update_me());
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--reinstall" {
|
|
|
|
hbb_common::allow_err!(platform::uninstall_me());
|
|
|
|
hbb_common::allow_err!(platform::install_me(
|
|
|
|
"desktopicon startmenu",
|
|
|
|
"".to_owned(),
|
|
|
|
false,
|
|
|
|
false,
|
|
|
|
));
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--silent-install" {
|
|
|
|
hbb_common::allow_err!(platform::install_me(
|
|
|
|
"desktopicon startmenu",
|
|
|
|
"".to_owned(),
|
|
|
|
true,
|
|
|
|
args.len() > 1,
|
|
|
|
));
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--extract" {
|
|
|
|
#[cfg(feature = "with_rc")]
|
|
|
|
hbb_common::allow_err!(crate::rc::extract_resources(&args[1]));
|
|
|
|
return None;
|
2022-10-29 21:59:45 +08:00
|
|
|
} else if args[0] == "--tray" {
|
2022-11-10 21:25:12 +08:00
|
|
|
crate::tray::start_tray();
|
2022-10-29 21:59:45 +08:00
|
|
|
return None;
|
2022-09-15 17:41:10 +08:00
|
|
|
}
|
2022-05-30 16:16:20 +08:00
|
|
|
}
|
2022-09-15 17:41:10 +08:00
|
|
|
if args[0] == "--remove" {
|
|
|
|
if args.len() == 2 {
|
|
|
|
// sleep a while so that process of removed exe exit
|
|
|
|
std::thread::sleep(std::time::Duration::from_secs(1));
|
|
|
|
std::fs::remove_file(&args[1]).ok();
|
|
|
|
return None;
|
|
|
|
}
|
|
|
|
} else if args[0] == "--service" {
|
|
|
|
log::info!("start --service");
|
|
|
|
crate::start_os_service();
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--server" {
|
2022-09-07 20:08:12 +08:00
|
|
|
log::info!("start --server");
|
2022-11-04 19:20:51 +08:00
|
|
|
#[cfg(target_os = "windows")]
|
2022-09-07 20:08:12 +08:00
|
|
|
{
|
2022-09-15 17:41:10 +08:00
|
|
|
crate::start_server(true);
|
|
|
|
return None;
|
2022-09-07 20:08:12 +08:00
|
|
|
}
|
|
|
|
#[cfg(target_os = "macos")]
|
|
|
|
{
|
2022-09-16 00:32:34 +08:00
|
|
|
std::thread::spawn(move || crate::start_server(true));
|
2022-09-15 17:41:10 +08:00
|
|
|
// to-do: for flutter, starting tray not ready yet, or we can reuse sciter's tray implementation.
|
|
|
|
}
|
2022-11-10 23:26:09 +08:00
|
|
|
#[cfg(target_os = "linux")]
|
2022-11-04 19:20:51 +08:00
|
|
|
{
|
2022-11-04 19:28:30 +08:00
|
|
|
let handler = std::thread::spawn(move || crate::start_server(true));
|
2022-11-10 23:26:09 +08:00
|
|
|
crate::tray::start_tray();
|
2022-11-04 19:28:30 +08:00
|
|
|
// revent server exit when encountering errors from tray
|
2022-11-10 23:26:09 +08:00
|
|
|
hbb_common::allow_err!(handler.join());
|
2022-11-04 19:20:51 +08:00
|
|
|
}
|
2022-09-15 17:41:10 +08:00
|
|
|
} else if args[0] == "--import-config" {
|
|
|
|
if args.len() == 2 {
|
|
|
|
let filepath;
|
|
|
|
let path = std::path::Path::new(&args[1]);
|
|
|
|
if !path.is_absolute() {
|
|
|
|
let mut cur = std::env::current_dir().unwrap();
|
|
|
|
cur.push(path);
|
|
|
|
filepath = cur.to_str().unwrap().to_string();
|
|
|
|
} else {
|
|
|
|
filepath = path.to_str().unwrap().to_string();
|
|
|
|
}
|
|
|
|
import_config(&filepath);
|
|
|
|
}
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--password" {
|
|
|
|
if args.len() == 2 {
|
|
|
|
crate::ipc::set_permanent_password(args[1].to_owned()).unwrap();
|
2022-09-07 20:08:12 +08:00
|
|
|
}
|
2022-09-15 17:41:10 +08:00
|
|
|
return None;
|
|
|
|
} else if args[0] == "--check-hwcodec-config" {
|
|
|
|
#[cfg(feature = "hwcodec")]
|
|
|
|
scrap::hwcodec::check_config();
|
|
|
|
return None;
|
|
|
|
} else if args[0] == "--cm" {
|
|
|
|
// call connection manager to establish connections
|
|
|
|
// meanwhile, return true to call flutter window to show control panel
|
|
|
|
#[cfg(feature = "flutter")]
|
|
|
|
crate::flutter::connection_manager::start_listen_ipc_thread();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//_async_logger_holder.map(|x| x.flush());
|
2022-10-11 14:52:46 +08:00
|
|
|
#[cfg(feature = "flutter")]
|
|
|
|
return Some(flutter_args);
|
|
|
|
#[cfg(not(feature = "flutter"))]
|
|
|
|
return Some(args);
|
2022-09-15 17:41:10 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
fn import_config(path: &str) {
|
|
|
|
use hbb_common::{config::*, get_exe_time, get_modified_time};
|
|
|
|
let path2 = path.replace(".toml", "2.toml");
|
|
|
|
let path2 = std::path::Path::new(&path2);
|
|
|
|
let path = std::path::Path::new(path);
|
|
|
|
log::info!("import config from {:?} and {:?}", path, path2);
|
|
|
|
let config: Config = load_path(path.into());
|
|
|
|
if config.is_empty() {
|
|
|
|
log::info!("Empty source config, skipped");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if get_modified_time(&path) > get_modified_time(&Config::file())
|
|
|
|
&& get_modified_time(&path) < get_exe_time()
|
|
|
|
{
|
|
|
|
if store_path(Config::file(), config).is_err() {
|
|
|
|
log::info!("config written");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
let config2: Config2 = load_path(path2.into());
|
|
|
|
if get_modified_time(&path2) > get_modified_time(&Config2::file()) {
|
|
|
|
if store_path(Config2::file(), config2).is_err() {
|
|
|
|
log::info!("config2 written");
|
2022-08-25 17:35:45 +08:00
|
|
|
}
|
2022-05-30 16:16:20 +08:00
|
|
|
}
|
|
|
|
}
|
2022-10-11 19:52:03 +08:00
|
|
|
|
|
|
|
/// invoke a new connection
|
|
|
|
///
|
|
|
|
/// [Note]
|
2022-10-13 09:58:46 +08:00
|
|
|
/// this is for invoke new connection from dbus.
|
2022-11-14 15:41:43 +08:00
|
|
|
/// If it returns [`None`], then the process will terminate, and flutter gui will not be started.
|
|
|
|
/// If it returns [`Some`], then the process will continue, and flutter gui will be started.
|
2022-10-13 09:58:46 +08:00
|
|
|
#[cfg(feature = "flutter")]
|
2022-11-10 14:38:25 +08:00
|
|
|
fn core_main_invoke_new_connection(mut args: std::env::Args) -> Option<Vec<String>> {
|
2022-10-13 09:58:46 +08:00
|
|
|
args.position(|element| {
|
|
|
|
return element == "--connect";
|
|
|
|
})
|
|
|
|
.unwrap();
|
2022-10-11 19:52:03 +08:00
|
|
|
let peer_id = args.next().unwrap_or("".to_string());
|
|
|
|
if peer_id.is_empty() {
|
|
|
|
eprintln!("please provide a valid peer id");
|
|
|
|
return None;
|
|
|
|
}
|
|
|
|
#[cfg(target_os = "linux")]
|
|
|
|
{
|
|
|
|
use crate::dbus::invoke_new_connection;
|
|
|
|
|
|
|
|
match invoke_new_connection(peer_id) {
|
|
|
|
Ok(()) => {
|
|
|
|
return None;
|
|
|
|
}
|
|
|
|
Err(err) => {
|
|
|
|
log::error!("{}", err.as_ref());
|
|
|
|
// return Some to invoke this new connection by self
|
|
|
|
return Some(Vec::new());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-11-10 23:26:09 +08:00
|
|
|
#[cfg(not(target_os = "linux"))]
|
2022-11-14 15:41:43 +08:00
|
|
|
return Some(Vec::new());
|
2022-10-11 19:52:03 +08:00
|
|
|
}
|