5 releases

Uses old Rust 2015

0.1.4 Aug 6, 2023
0.1.3 Aug 5, 2022
0.1.2 Aug 9, 2018
0.1.1 Mar 24, 2018
0.1.0 Dec 3, 2017

#853 in Network programming

Download history 1255/week @ 2024-07-20 1315/week @ 2024-07-27 871/week @ 2024-08-03 1135/week @ 2024-08-10 1288/week @ 2024-08-17 1284/week @ 2024-08-24 1200/week @ 2024-08-31 821/week @ 2024-09-07 1006/week @ 2024-09-14 917/week @ 2024-09-21 1038/week @ 2024-09-28 914/week @ 2024-10-05 1819/week @ 2024-10-12 1515/week @ 2024-10-19 797/week @ 2024-10-26 491/week @ 2024-11-02

4,661 downloads per month
Used in 10 crates

Apache-2.0/MIT

21KB
222 lines

TunTap

Travis Build Status

TUN/TAP wrapper for Rust.

The TUN/TAP allows implementing a virtual network adapter in userspace. This provides the bindings for Rust.

Create an Iface object and send or recv packets. Making some sense of the packets is, however, out of scope, you need something else for that.

There's documentation and some examples.

Known issues

  • Tested only on Linux. Probably doesn't work anywhere else, but pull requests adding support for other OSes are welcome.
  • The asynchronous interface is very minimal and probably inefficient. It'll need to be extended to allow more flexible or efficient use.

Testing

In order to run the tests correctly, a tun10 device with 10.10.10.1/24 needs to be created first. You can simply run:

sh tests/setup.sh

To remove it:

sh tests/clean.sh

Sudo permission is required.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies

~0–1.5MB
~24K SLoC