A bunch of cross-platform network tools for fetching interfaces, multicast addresses, local ip addresses, private ip addresses, public ip addresses and etc.
A bunch of cross-platform network tools for fetching interfaces, multicast addresses, local ip addresses, private ip addresses, public ip addresses and etc.
[dependencies]
getifs = "0.2"
- Fetching all interfaces: examples/interfaces.rs
- Fetching all interface addresses (excluding multicast addrs): examples/addrs.rs
- Fetching all interface multicast addresses: exampels/multicast_addrs.rs
- Fetching gateway addresses: examples/gateway.rs
- Fetching local ip addresses: examples/local_ip_addrs.rs
- Fetching ip addresses by RFC: examples/filter_by_rfc.rs
OS | Approach |
---|---|
Linux | socket(AF_NETLINK, SOCK_RAW | SOCK_CLOEXEC, NETLINK_ROUTE) |
BSD-like | sysctl |
Windows | GetAdaptersAddresses |
When implementing agnostic-mdns
(an mDNS crate), I found that Rust was missing a crate to help play with network interfaces and addresses.
All of current network interfaces crates do not support fetching MTU
and multicast addresses, and almost all of them are using libc::getifaddrs
. This crate
tries to avoid unneeded allocation and use more underlying method to achieve the same functionalities.
Hence, getifs
is here, which contain a bunch of cross-platform network tools for fetching interfaces, multicast addresses, local ip addresses, private ip addresses, public ip addresses and etc.
- Support fetching routing tables (0.3.0)
iprobe
: Probe if the host system supports IPv4, IPv6 and IPv4-mapped-IPv6.iprfc
: Known RFCs for IP addresses.
- The code in this crate is inspired by Golang's
interface.go
and HashiCorp's go-sockaddr.
getifs
is under the terms of both the MIT license and the
Apache License (Version 2.0).
See LICENSE-APACHE, LICENSE-MIT for details.
Copyright (c) 2025 Al Liu.