| Crates.io | okapi-operation |
| lib.rs | okapi-operation |
| version | 0.3.0 |
| created_at | 2022-07-10 18:21:52.752911+00 |
| updated_at | 2025-06-15 12:52:57.602995+00 |
| description | Procedural macro for generating OpenAPI operation specification (using okapi) |
| homepage | |
| repository | https://github.com/Flowneee/okapi-operation |
| max_upload_size | |
| id | 623246 |
| size | 126,175 |
okapi-operationLibrary which allow to generate OpenAPI's operation definitions (using types from okapi crate) with procedural
macro #[openapi].
use axum::{Json, extract::Query};
use okapi_operation::{axum_integration::*, *};
use serde::Deserialize;
#[derive(Deserialize, JsonSchema)]
struct Request {
/// Echo data
data: String,
}
#[openapi(
summary = "Echo using GET request",
operation_id = "echo_get",
tags = "echo",
parameters(
query(name = "echo-data", required = true, schema = "std::string::String",),
header(name = "x-request-id", schema = "std::string::String",)
)
)]
async fn echo_get(query: Query<Request>) -> Json<String> {
Json(query.0.data)
}
#[openapi(
summary = "Echo using POST request",
operation_id = "echo_post",
tags = "echo"
)]
async fn echo_post(
#[body(description = "Echo data", required = true)] body: Json<Request>,
) -> Json<String> {
Json(body.0.data)
}
fn main() {
let app = Router::new()
.route("/echo/get", get(openapi_handler!(echo_get)))
.route("/echo/post", post(openapi_handler!(echo_post)))
.finish_openapi("/openapi", "Demo", "1.0.0")
.expect("no problem");
let listener = tokio::net::TcpListener::bind("0.0.0.0:3000").await.unwrap();
axum::serve(listener, app.into_make_service())
.await
.unwrap()
}
macro: enables re-import of #[openapi] macro (enabled by default);axum-integration: enables integration with axum(https://github.com/tokio-rs/axum) crate (implement traits for
certain axum types):
axum: since integration heavely rely on axum types, this crate will be compatible only with
few (maybe even one) last versions of axum;axum versions: 0.7.x.yaml: enables ability to serve the spec in yaml format in case of present Accept header with yaml value.
Otherwise, in case of values json|*/* or empty, json's being served (currently affects only axum-integration).JsonSchema macro)