blob: 2f1e5c36dc7d31b488ecc0f144c1bdae99d0757e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
// `error_chain!` can recurse deeply
#![recursion_limit = "1024"]
extern crate talpid_core;
#[macro_use]
extern crate clap;
#[macro_use]
extern crate error_chain;
extern crate log;
extern crate env_logger;
use std::sync::Mutex;
use std::sync::mpsc::{self, Receiver};
use talpid_core::net::RemoteAddr;
use talpid_core::tunnel::{TunnelEvent, TunnelMonitor};
mod cli;
error_chain!{}
quick_main!(run);
fn run() -> Result<()> {
init_logger()?;
let args = cli::parse_args_or_exit();
main_loop(&args.remotes)
}
pub fn init_logger() -> Result<()> {
env_logger::init().chain_err(|| "Failed to bootstrap logging system")
}
fn main_loop(remotes: &[RemoteAddr]) -> Result<()> {
let mut remotes_iter = remotes.iter().cloned().cycle();
let (monitor, rx) = create_tunnel_monitor()?;
loop {
monitor.start(remotes_iter.next().unwrap()).chain_err(|| "Unable to start OpenVPN")?;
while let Ok(msg) = rx.recv() {
match msg {
TunnelEvent::Shutdown => {
println!("Monitored process exited");
break;
}
TunnelEvent::Up => println!("Tunnel UP"),
TunnelEvent::Down => println!("Tunnel DOWN"),
}
}
std::thread::sleep(std::time::Duration::from_millis(500));
}
}
fn create_tunnel_monitor() -> Result<(TunnelMonitor, Receiver<TunnelEvent>)> {
let (event_tx, event_rx) = mpsc::channel();
let event_tx_mutex = Mutex::new(event_tx);
let on_event = move |event: TunnelEvent| {
event_tx_mutex.lock().unwrap().send(event).expect("Unable to send on tx_lock");
};
let monitor = TunnelMonitor::new(on_event).chain_err(|| "Unable to start OpenVPN monitor")?;
Ok((monitor, event_rx))
}
|