Add if_type and flags for linux

main
shellrow 3 years ago
parent bdd5d9a617
commit c57b24a26d
  1. 13
      src/interface/types.rs
  2. 29
      src/interface/unix.rs

@ -69,9 +69,18 @@ impl InterfaceType {
#[cfg(any(target_os = "linux", target_os = "android"))] #[cfg(any(target_os = "linux", target_os = "android"))]
pub fn value(&self) -> u32 { pub fn value(&self) -> u32 {
// TODO
match *self { match *self {
_ => 0, InterfaceType::Ethernet => 1,
InterfaceType::TokenRing => 4,
InterfaceType::Fddi => 774,
InterfaceType::Ppp => 512,
InterfaceType::Loopback => 772,
InterfaceType::Ethernet3Megabit => 2,
InterfaceType::Slip => 256,
InterfaceType::Atm => 19,
InterfaceType::Wireless80211 => 801,
InterfaceType::Tunnel => 768,
_ => 999,
} }
} }

@ -10,6 +10,9 @@ use std::mem::{self, MaybeUninit};
use std::os::raw::c_char; use std::os::raw::c_char;
use std::str::from_utf8_unchecked; use std::str::from_utf8_unchecked;
use std::net::{IpAddr, Ipv4Addr, Ipv6Addr}; use std::net::{IpAddr, Ipv4Addr, Ipv6Addr};
use std::convert::TryFrom;
use std::fs::read_to_string;
use crate::interface::InterfaceType;
#[cfg(any(target_os = "macos", target_os = "openbsd", target_os = "freebsd", target_os = "netbsd", target_os = "ios"))] #[cfg(any(target_os = "macos", target_os = "openbsd", target_os = "freebsd", target_os = "netbsd", target_os = "ios"))]
pub fn interfaces() -> Vec<Interface> { pub fn interfaces() -> Vec<Interface> {
@ -79,6 +82,30 @@ pub fn interfaces() -> Vec<Interface> {
interfaces interfaces
} }
#[cfg(any(target_os = "macos", target_os = "openbsd", target_os = "freebsd", target_os = "netbsd", target_os = "ios"))]
pub fn get_interface_type(if_name: String) -> InterfaceType {
// TODO
InterfaceType::Unknown
}
#[cfg(any(target_os = "linux", target_os = "android"))]
pub fn get_interface_type(if_name: String) -> InterfaceType {
let if_type_path: String = format!("/sys/class/net/{}/type", if_name);
let r = read_to_string(if_type_path);
let if_type_string = match r {
Ok(content) => content.trim().to_string(),
Err(_) => String::from("999"),
};
match if_type_string.parse::<u32>() {
Ok(if_type) => {
InterfaceType::try_from(if_type).unwrap_or(InterfaceType::Unknown)
},
Err(_) => {
InterfaceType::Unknown
}
}
}
pub fn unix_interfaces() -> Vec<Interface> { pub fn unix_interfaces() -> Vec<Interface> {
let mut ifaces: Vec<Interface> = vec![]; let mut ifaces: Vec<Interface> = vec![];
let mut addrs: MaybeUninit<*mut libc::ifaddrs> = MaybeUninit::uninit(); let mut addrs: MaybeUninit<*mut libc::ifaddrs> = MaybeUninit::uninit();
@ -130,9 +157,11 @@ pub fn unix_interfaces() -> Vec<Interface> {
index: 0, index: 0,
name: name.clone(), name: name.clone(),
description: None, description: None,
if_type: get_interface_type(name.clone()),
mac_addr: mac.clone(), mac_addr: mac.clone(),
ipv4: ini_ipv4, ipv4: ini_ipv4,
ipv6: ini_ipv6, ipv6: ini_ipv6,
flags: addr_ref.ifa_flags,
gateway: None, gateway: None,
}; };
let mut found: bool = false; let mut found: bool = false;

Loading…
Cancel
Save