axum-msgpack

axum-msgpack adds MessagePack features to axum.

Documentation Crates.io

More information about this crate can be found in the crate documentation.

serde msgpack

Features

Usage example

```rust use axum_msgpack::MsgPack; use serde::{Deserialize, Serialize};

[derive(Debug, Serialize, Deserialize)]

struct User { pub name: String, #[serde(with = "serde_bytes")] pub data: Vec }

// axum handler | MsgPack async fn gethandler() -> MsgPack { let user = User { name: "steve".tostring(), data: vec![0,0,0,0,0,0,0,0,0,0,0,0,0,0,0] }; MsgPack(user) }

// axum handler | MsgPack async fn post_handler(MsgPack(user): MsgPack) -> Html { let string = format!("

{:?}

", user.name); Html(string) }

// axum handler | MsgPackRaw async fn gethandlerraw() -> MsgPackRaw { let user = User { name: "steve".to_string(), data: vec![0,0,0,0,0,0,0,0,0,0,0,0,0,0,0] }; MsgPack(user) }

// axum handler | MsgPackRaw async fn posthandlerraw(MsgPackRaw(user): MsgPackRaw) -> Html { let string = format!("

{:?}

", user.name); Html(string) } ```

Dependencies for serializing/deserializing MsgPack toml serde = { version = "1.0", features = ["derive"] } serde_bytes = "0.11"

In order to pack arrays correct remember to add #[serde(with = "serde_bytes")] to the struct member.

Safety

This crate uses #![forbid(unsafe_code)] to ensure everything is implemented in 100% safe Rust.

License

This project is licensed under the MIT license.