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
use std::collections::HashMap;
use std::net::{Ipv4Addr, SocketAddr};
use ipnet::Ipv4Net;
use crate::error::*;
use crate::wg_dev_linuxkernel::*;
pub trait WireguardDevice {
fn check_device(&self) -> BoxResult<bool>;
fn bring_up_device(&self) -> BoxResult<()>;
fn take_down_device(&self) -> BoxResult<()>;
fn set_ip(&mut self, ip: &Ipv4Addr, subnet: &Ipv4Net) -> BoxResult<()>;
fn add_route(&self, route: &str, gateway: Option<Ipv4Addr>) -> BoxResult<()>;
fn replace_route(&self, route: &str, gateway: Option<Ipv4Addr>) -> BoxResult<()>;
fn del_route(&self, route: &str, gateway: Option<Ipv4Addr>) -> BoxResult<()>;
fn set_conf(&self, conf: &str) -> BoxResult<()>;
fn sync_conf(&self, conf: &str) -> BoxResult<()>;
fn flush_all(&self) -> BoxResult<()>;
fn retrieve_conf(&self) -> BoxResult<HashMap<String, SocketAddr>>;
fn create_key_pair(&self) -> BoxResult<(String, String)>;
}
#[cfg(target_os = "linux")]
pub fn get_wireguard_device_linux<T: Into<String>>(
wg_name: T,
) -> BoxResult<Box<dyn WireguardDevice>> {
Ok(Box::new(WireguardDeviceLinux::init(wg_name)))
}
pub fn get_wireguard_device<T: Into<String>>(wg_name: T) -> BoxResult<Box<dyn WireguardDevice>> {
#[cfg(target_os = "linux")]
return get_wireguard_device_linux(wg_name);
#[cfg(not(target_os = "linux"))]
Err("Unsupported OS".into())
}