7 releases

0.3.0 Jan 30, 2024
0.2.0 Dec 3, 2023
0.1.5 Jan 7, 2023
0.1.4 Jun 20, 2022
0.0.1 Apr 28, 2022

#1714 in Embedded development

Download history 393/week @ 2024-08-25 281/week @ 2024-09-01 240/week @ 2024-09-08 249/week @ 2024-09-15 339/week @ 2024-09-22 202/week @ 2024-09-29 221/week @ 2024-10-06 371/week @ 2024-10-13 209/week @ 2024-10-20 304/week @ 2024-10-27 311/week @ 2024-11-03 364/week @ 2024-11-10 263/week @ 2024-11-17 151/week @ 2024-11-24 153/week @ 2024-12-01 115/week @ 2024-12-08

804 downloads per month

Custom license

255KB
4.5K SLoC

Rust-mqtt

About

Rust-mqtt is native MQTT client for both std and no_std environments. Client library provides async API which can be used with various executors. Currently, supporting only MQTTv5 but everything is prepared to extend support also for MQTTv3 which is planned during year 2022.

Async executors

For desktop usage I recommend using Tokio async executor and for embedded there is prepared wrapper for Drogue device framework in the Drogue-IoT project examples mqtt module.

Restrains

Client supports following:

  • QoS 0 & QoS 1 (All QoS 2 packets are mapped for future client extension)
  • Only clean session
  • Retain not supported
  • Auth packet not supported
  • Packet size is not limited, it is totally up to user (packet size and buffer sizes have to align)

Building

cargo build

Running tests

Integration tests are written using tokio network tcp stack and can be find under tokio_net.

cargo test unit
cargo test integration
cargo test load

Minimum supported Rust version (MSRV)

Rust-mqtt is guaranteed to compile on stable Rust 1.75 and up. It might compile with older versions but that may change in any new patch release.

Acknowledgment

This project could not be in state in which currently is without Ulf Lilleengen and rest of the community from Drogue IoT.

Contact

For any information contact me on email ond.babec@gmail.com

Dependencies

~510–740KB
~15K SLoC