7 unstable releases

0.4.2 Jan 7, 2025
0.4.1 Jan 7, 2025
0.3.0 Sep 23, 2023
0.2.0 Jul 21, 2023
0.1.1 Jun 9, 2022

#46 in macOS and iOS APIs

Download history 15/week @ 2024-09-25 13/week @ 2024-10-02 6/week @ 2024-11-27 13/week @ 2024-12-04 14/week @ 2024-12-11 3/week @ 2024-12-18 119/week @ 2025-01-01 244/week @ 2025-01-08

368 downloads per month

MIT license

47KB
1K SLoC

vmnet

Docs.rs

Apple's vmnet.framework bindings for Rust.

Installation

Add this to your Cargo.toml:

[dependencies]
vmnet = "0"

Usage

Ensure that your software either has an com.apple.vm.networking entitlement or is running with elevated privileges.

Start a NAT interface and receive some packets destined to it:

let shared_mode = Shared {
    subnet_options: None,
    ..Default::default()
};

let mut iface = Interface::new(Mode::Shared(shared_mode), Options::default()).unwrap();

let (tx, rx) = sync::mpsc::sync_channel(0);

iface.set_event_callback(Events::PACKETS_AVAILABLE, move |events, params| {
    if let Some(Parameter::EstimatedPacketsAvailable(pkts)) = params.get(ParameterKind::EstimatedPacketsAvailable) {
        tx.send(pkts);
    }
}).unwrap();

let pkts = rx.recv().unwrap();
println!("receiving {} packets...", pkts);
for _ in 0..pkts {
    let mut buf: [u8; 1514] = [0; 1514];
    println!("{:?}", iface.read(&mut buf));
}

drop(rx);
iface.finalize().unwrap();

Quirks and missing functionality

  • due to Apple's usage of blocks as a way to retrieve API call results, some methods like set_event_callback() require the provided closure to have a 'static lifetime
    • this manifests itself in not being able to use Interface from such closure
    • however, this can be easily worked around by using interior mutability pattern or simply by using the callback as a signal carrier
  • due to API_AVAILABLE macro not being supported it is assumed that this package is running on macOS 11.0 or newer

Dependencies

~1–1.6MB
~34K SLoC