#openapi #serde-json #deserialize #specification #structures #v3 #deserializable

openapiv3

This crate provides data structures that represent the OpenAPI v3.0.x specification easily deserializable with serde

23 releases (5 stable)

2.0.0 Dec 8, 2023
2.0.0-rc.1 Oct 21, 2023
1.0.4 Dec 13, 2023
1.0.3 Aug 28, 2023
0.1.3 Mar 5, 2019

#40 in Encoding

Download history 21942/week @ 2024-09-19 24790/week @ 2024-09-26 26368/week @ 2024-10-03 25389/week @ 2024-10-10 31981/week @ 2024-10-17 28860/week @ 2024-10-24 28306/week @ 2024-10-31 33001/week @ 2024-11-07 28769/week @ 2024-11-14 27798/week @ 2024-11-21 26297/week @ 2024-11-28 28859/week @ 2024-12-05 27357/week @ 2024-12-12 13388/week @ 2024-12-19 3714/week @ 2024-12-26 11586/week @ 2025-01-02

61,733 downloads per month
Used in 85 crates (44 directly)

MIT/Apache

375KB
2K SLoC

OpenAPI v3 example workflow

This crate provides data structures that represent the OpenAPI v3.0.x specification. Note this does not cover OpenAPI v3.1 which was an incompatible change.

Example

use serde_json;
use openapiv3::OpenAPI;

fn main() {
    let data = include_str!("openapi.json");
    let openapi: OpenAPI = serde_json::from_str(data).expect("Could not deserialize input");
    println!("{:?}", openapi);
}

Goals

  • Provide a deserialization for the specification that maps cleanly to Rust enums etc.

Non Goals

  • Deserialization and subsequent re-serialization are 100% the same.
    • Some defaults show-up when serializing that may not have existed in the input.

Issues

Schemas without a type will end up as any data type as per the specification and can have any parameters of any schema type. Some Open API documents don't include the type parameter it would be nice to try to derive the type but the crate as of right now meets my needs.

Similar Crates

License

This crate is licensed under either of

Apache License, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Dependencies