GREsau/okapi

Issue annotating HTTP status codes for responses

dlahmad opened this issue · 2 comments

Is there a way to annotate a rocket handler method with the HTTP status codes it (possibly) returns a response?

I tried to find the functionality, but it seems not to be there.

I'm not sure what you mean. But I think you mean something like this:

fn create_user(req_body: Json<String>) -> Result<Json<User>, (Status, Json<ErrorMessage>)> {

This way you can directly change the HTTP status.

If you instead want to use a Result and get a list of all the possible HTTP code in you openApi docs use:

fn create_message(message: crate::DataResult<'_, Message>) -> Result<Json<Message>, error::Error>>

Where the Error is your own custom error.

You can then add the openApi errors to it like this: https://github.com/GREsau/okapi/blob/master/examples/custom_schema/src/error.rs

But to know what HTTP status codes an endpoint can return, you have to figure that out yourself. This is because this is depended on the logic of the code and could even be runtime determined so, no way to know at compile time.

ralpha commented

Added a new FAQ question to add some more info for others that might have similar questions.
https://github.com/GREsau/okapi#q-how-do-i-document-my-endpoints