#messagepack

axum-msgpack

serialize/derserialize msgpack for axum

5 releases (3 breaking)

0.4.0 Dec 31, 2023
0.3.0 Nov 28, 2022
0.2.2 Apr 16, 2022
0.2.1 Jan 21, 2022
0.1.0 Aug 28, 2021

#8 in #message-pack

Download history 30/week @ 2024-07-22 94/week @ 2024-07-29 16/week @ 2024-08-05 10/week @ 2024-08-12 20/week @ 2024-08-19 23/week @ 2024-08-26 7/week @ 2024-09-02 9/week @ 2024-09-09 14/week @ 2024-09-16 60/week @ 2024-09-23 53/week @ 2024-09-30 9/week @ 2024-10-07 17/week @ 2024-10-14 23/week @ 2024-10-21 17/week @ 2024-10-28 28/week @ 2024-11-04

85 downloads per month
Used in 4 crates

MIT license

22KB
430 lines

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

  • Serialize, Deserialize MessagePack from request/response

Usage example

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

#[derive(Debug, Serialize, Deserialize)]
struct User {
    pub name: String,
    #[serde(with = "serde_bytes")]
    pub data: Vec<u8>
}

// axum handler | MsgPack
async fn get_handler() -> MsgPack<User> {
    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 | MsgPack
async fn post_handler(MsgPack(user): MsgPack<User>) -> Html<String> {
    let string = format!("<h1>{:?}</h1>", user.name);
    Html(string)
}

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

// axum handler | MsgPackRaw
async fn post_handler_raw(MsgPackRaw(user): MsgPackRaw<User>) -> Html<String> {
    let string = format!("<h1>{:?}</h1>", user.name);
    Html(string)
}

Dependencies for serializing/deserializing MsgPack

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.

Dependencies

~6–13MB
~146K SLoC