Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/denganjia/openapi-schema

Rust structure mapped to Swagger
https://github.com/denganjia/openapi-schema

oas openapi rust swagger

Last synced: 3 months ago
JSON representation

Rust structure mapped to Swagger

Awesome Lists containing this project

README

        

# OpenApi-Schema

Rust structure mapped to openapi

You can use this package will openapi document into rust structure
# Use
```bash
cargo add openapi-schema
```
```rust
use openapi_schema::{from_path, Doc};

fn main() {
let filepath = "./index.json";
let json = from_path(filepath);
match json {
Ok(some_doc) => match some_doc {
Doc::V2(swagger) => {
println!("swagger version:{}", swagger.swagger)
}
Doc::V3(openapi) => {
println!("openapi version:{}", openapi.openapi)
}
},
Err(e) => {
println!("{:?}", e)
}
}
}
```

# Notice

Because some words are reserved words in rust, so will the json structure mapped to rust after structure, rust in the field name is different from some of json
|Rust|Json|
| --- | --- |
| r#type | type |
| r#enum | enum |
| r#in | in |
| reference | $ref |

>For using camelCase in json representation of the field, use snake_case in rust