heim_net/nic.rs
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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
use std::fmt;
use std::net;
use heim_common::prelude::*;
use crate::sys;
/// Network interface address.
#[derive(Debug, Copy, Clone, Eq, PartialEq, Hash)]
pub enum Address {
/// IPv4 Internet protocols
Inet(net::SocketAddr),
/// IPv6 Internet protocols
Inet6(net::SocketAddr),
/// Link level interface
Link(macaddr::MacAddr),
#[doc(hidden)]
__Nonexhaustive,
}
// TODO: Consider implement `Address::to_family()` method
// which will return the `libc::c_int` value with a corresponding value
// for the current address member (ex. `AF_INET` or `AF_PACKET`)
// Do not forget that it is OS-dependant.
/// Network interface device.
pub struct Nic(sys::Nic);
wrap!(Nic, sys::Nic);
impl Nic {
/// Returns NIC name.
pub fn name(&self) -> &str {
self.as_ref().name()
}
/// Returns primary NIC address.
pub fn address(&self) -> Address {
self.as_ref().address()
}
/// Returns netmask address if available.
pub fn netmask(&self) -> Option<Address> {
self.as_ref().netmask()
}
/// Returns destination address if available.
pub fn destination(&self) -> Option<Address> {
self.as_ref().destination()
}
/// Returns `bool` indicating whether interface is up and running.
pub fn is_up(&self) -> bool {
self.as_ref().is_up()
}
/// Returns `bool` indicating whether interface is loopback.
pub fn is_loopback(&self) -> bool {
self.as_ref().is_loopback()
}
/// Returns `bool` indicating whether interface is multicast.
pub fn is_multicast(&self) -> bool {
self.as_ref().is_multicast()
}
}
impl fmt::Debug for Nic {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
f.debug_struct("Nic")
.field("name", &self.name())
.field("address", &self.address())
.field("netmask", &self.netmask())
.field("destination", &self.destination())
.field("is_up", &self.is_up())
.field("is_loopback", &self.is_loopback())
.field("is_multicast", &self.is_multicast())
.finish()
}
}
/// Returns stream which yields [Network Interface Cards].
///
/// [Network Interface Cards]: struct.Nic.html
pub fn nic() -> impl Stream<Item = Result<Nic>> {
sys::nic().map_ok(Into::into)
}