Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/00imvj00/mqttrs
Async Mqtt encoder and decoder for rust.
https://github.com/00imvj00/mqttrs
mqtt mqtt-library mqtt-protocol rust
Last synced: about 15 hours ago
JSON representation
Async Mqtt encoder and decoder for rust.
- Host: GitHub
- URL: https://github.com/00imvj00/mqttrs
- Owner: 00imvj00
- License: apache-2.0
- Created: 2019-02-03T05:38:42.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-12-28T14:23:14.000Z (29 days ago)
- Last Synced: 2025-01-19T10:01:43.320Z (8 days ago)
- Topics: mqtt, mqtt-library, mqtt-protocol, rust
- Language: Rust
- Size: 179 KB
- Stars: 132
- Watchers: 7
- Forks: 18
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Rust Mqtt Encoding & Decoding [![Crates.io](https://img.shields.io/crates/l/mqttrs)](LICENSE) [![Docs.rs](https://docs.rs/mqttrs/badge.svg)](https://docs.rs/mqttrs/*/mqttrs/)
`Mqttrs` is a [Rust](https://www.rust-lang.org/) crate (library) to write [MQTT
protocol](https://mqtt.org/) clients and servers.It is a codec-only library with [very few dependencies](Cargo.toml) and a [straightforward and
composable API](https://docs.rs/mqttrs/*/mqttrs/), usable with rust's standard library or with async
frameworks like [tokio](https://tokio.rs/). It is strict when decoding (e.g. returns an error when
encountering reserved values) and encoding (the API makes it impossible to generate an illegal
packet).`Mqttrs` currently requires [Rust >= 1.39](https://www.rust-lang.org/learn/get-started) and supports
[MQTT 3.1.1](http://docs.oasis-open.org/mqtt/mqtt/v3.1.1/os/mqtt-v3.1.1-os.html). Support for [MQTT
5](https://docs.oasis-open.org/mqtt/mqtt/v5.0/os/mqtt-v5.0-os.html) is planned for a future version.## Usage
Add `mqttrs = "0.4"` and `bytes = "1.0"` to your `Cargo.toml`.
```rust
use mqttrs::*;
use bytes::BytesMut;// Allocate write buffer.
let mut buf = BytesMut::with_capacity(1024);// Encode an MQTT Connect packet.
let pkt = Packet::Connect(Connect { protocol: Protocol::MQTT311,
keep_alive: 30,
client_id: "doc_client".into(),
clean_session: true,
last_will: None,
username: None,
password: None });
assert!(encode(&pkt, &mut buf).is_ok());
assert_eq!(&buf[14..], "doc_client".as_bytes());
let mut encoded = buf.clone();// Decode one packet. The buffer will advance to the next packet.
assert_eq!(Ok(Some(pkt)), decode(&mut buf));// Example decode failures.
let mut incomplete = encoded.split_to(10);
assert_eq!(Ok(None), decode(&mut incomplete));
let mut garbage = BytesMut::from(&[0u8,0,0,0] as &[u8]);
assert_eq!(Err(Error::InvalidHeader), decode(&mut garbage));
```## Optional [serde](https://serde.rs/) support.
Use `mqttrs = { version = "0.4", features = [ "derive" ] }` in your `Cargo.toml`.
Enabling this features adds `#[derive(Deserialize, Serialize)]` to some `mqttrs` types. This
simplifies storing those structs in a database or file, typically to implement session support (qos,
subscriptions...).This doesn't add mqtt as a serde data format; you still need to use the `mqttrs::{decode,encode}`
functions.## Optional `#[no_std]` support.
Use `mqttrs = { version = "0.4", default-features = false }` in your `Cargo.toml` to remove the
default `std` feature.Disabling this feature comes with the cost of not implementing the `std::error::Error` trait,
as well as not supporting `std::io` read and write. This allows usage in embedded devices
where the standard library is not available.