feat: enable update clash info
This commit is contained in:
parent
0d5bfc0997
commit
65fb2ca2d5
@ -32,6 +32,15 @@ static CLASH_CONFIG: &str = "config.yaml";
|
|||||||
// todo: be able to change config field
|
// todo: be able to change config field
|
||||||
impl Clash {
|
impl Clash {
|
||||||
pub fn new() -> Clash {
|
pub fn new() -> Clash {
|
||||||
|
Clash {
|
||||||
|
info: Clash::get_info(),
|
||||||
|
sidecar: None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// parse the clash's config.yaml
|
||||||
|
/// get some information
|
||||||
|
fn get_info() -> ClashInfo {
|
||||||
let clash_config = config::read_yaml::<Mapping>(dirs::app_home_dir().join(CLASH_CONFIG));
|
let clash_config = config::read_yaml::<Mapping>(dirs::app_home_dir().join(CLASH_CONFIG));
|
||||||
|
|
||||||
let key_port_1 = Value::String("port".to_string());
|
let key_port_1 = Value::String("port".to_string());
|
||||||
@ -76,17 +85,20 @@ impl Clash {
|
|||||||
_ => None,
|
_ => None,
|
||||||
};
|
};
|
||||||
|
|
||||||
Clash {
|
ClashInfo {
|
||||||
info: ClashInfo {
|
status: "init".into(),
|
||||||
status: "init".into(),
|
port,
|
||||||
port,
|
server,
|
||||||
server,
|
secret,
|
||||||
secret,
|
|
||||||
},
|
|
||||||
sidecar: None,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// update the clash info
|
||||||
|
pub fn update_info(&mut self) -> Result<(), String> {
|
||||||
|
self.info = Clash::get_info();
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
/// run clash sidecar
|
/// run clash sidecar
|
||||||
pub fn run_sidecar(&mut self) -> Result<(), String> {
|
pub fn run_sidecar(&mut self) -> Result<(), String> {
|
||||||
let app_dir = dirs::app_home_dir();
|
let app_dir = dirs::app_home_dir();
|
||||||
@ -127,6 +139,7 @@ impl Clash {
|
|||||||
|
|
||||||
/// restart clash sidecar
|
/// restart clash sidecar
|
||||||
pub fn restart_sidecar(&mut self) -> Result<(), String> {
|
pub fn restart_sidecar(&mut self) -> Result<(), String> {
|
||||||
|
self.update_info()?;
|
||||||
self.drop_sidecar()?;
|
self.drop_sidecar()?;
|
||||||
self.run_sidecar()
|
self.run_sidecar()
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user