#axum #utoipa #bindings

utoipa-axum

Utoipa's axum bindings for seamless integration for the two

9 releases

new 0.2.0 Jan 16, 2025
0.1.4 Jan 5, 2025
0.1.3 Dec 19, 2024
0.1.2 Oct 29, 2024
0.1.0-beta.2 Sep 4, 2024

#1343 in Web programming

Download history 244/week @ 2024-09-27 202/week @ 2024-10-04 610/week @ 2024-10-11 1439/week @ 2024-10-18 1567/week @ 2024-10-25 1536/week @ 2024-11-01 1982/week @ 2024-11-08 2707/week @ 2024-11-15 3293/week @ 2024-11-22 3781/week @ 2024-11-29 3725/week @ 2024-12-06 4838/week @ 2024-12-13 3274/week @ 2024-12-20 2502/week @ 2024-12-27 4941/week @ 2025-01-03 5311/week @ 2025-01-10

16,987 downloads per month
Used in docker_compose_spec

MIT/Apache

410KB
6K SLoC

utoipa-axum - Bindings for Axum and utoipa

Utoipa build crates.io docs.rs rustc

Utoipa axum brings utoipa and axum closer together by the way of providing an ergonomic API that is extending on the axum API. It gives a natural way to register handlers known to axum and also simultaneously generates OpenAPI specification from the handlers.

Crate features

  • debug: Implement debug traits for types.

Install

Add dependency declaration to Cargo.toml.

[dependencies]
utoipa-axum = "0.2"

Examples

Use OpenApiRouter to collect handlers with #[utoipa::path] macro to compose service and form OpenAPI spec.

use utoipa_axum::{routes, PathItemExt, router::OpenApiRouter};

#[derive(utoipa::ToSchema)]
struct User {
    id: i32,
}

#[utoipa::path(get, path = "/user", responses((status = OK, body = User)))]
async fn get_user() -> Json<User> {
    Json(User { id: 1 })
}

let (router, api) = OpenApiRouter::new()
    .routes(routes!(get_user))
    .split_for_parts();

License

Licensed under either of Apache 2.0 or MIT license at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, shall be dual licensed, without any additional terms or conditions.

Dependencies

~3.5–5MB
~99K SLoC