9 releases (5 breaking)

0.6.0 Jan 20, 2021
0.5.0 Nov 27, 2020
0.4.1 Aug 24, 2020
0.4.0 Jun 14, 2020
0.1.1 Jan 2, 2019

#207 in Network programming

Download history 1645/week @ 2020-11-04 1741/week @ 2020-11-11 2057/week @ 2020-11-18 1864/week @ 2020-11-25 2446/week @ 2020-12-02 2852/week @ 2020-12-09 2754/week @ 2020-12-16 1051/week @ 2020-12-23 1567/week @ 2020-12-30 2867/week @ 2021-01-06 3507/week @ 2021-01-13 3188/week @ 2021-01-20 2155/week @ 2021-01-27 2908/week @ 2021-02-03 3931/week @ 2021-02-10 3206/week @ 2021-02-17

9,621 downloads per month
Used in 5 crates (3 directly)

MIT license

135KB
2K SLoC

Build Status

Netlink

This project aims at providing building blocks for netlink (see man 7 netlink).

Organization

  • the netlink_sys crate provides netlink sockets. Integration with mio and tokio is optional.
  • Each netlink protocol has a netlink-packet-<protocol_name> crate that provides the packets for this protocol:
  • the netlink-packet-core is the glue for all the other netlink-packet-* crates. It provides a NetlinkMessage<T> type that represent any netlink message for any sub-protocol.
  • the netlink_proto crate is an asynchronous implementation of the netlink protocol. It only depends on netlink-packet-core for the NetlinkMessage type and netlink-sys for the socket.
  • the rtnetlink crate provides higher level abstraction for the route protocol
  • the audit crate provides higher level abstractions for the audit protocol.

Altnernatives

Credits

My main resource so far has been the source code of pyroute2 (python) and netlink (golang) a lot. These two projects are great, and very nicely written. As someone who does not read C fluently, and that does not know much about netlink, they have been invaluable.

I'd also like to praise libnl for its documentation. It helped me a lot in understanding the protocol basics.

The whole packet parsing logic is inspired by @whitequark excellent blog posts (part 1, part 2 and part 3, although I've only really used the concepts described in the first blog post).

Thanks also to the people behing tokio for the amazing tool they are building, and the support they provide.

Dependencies

~4.5MB
~85K SLoC