Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support for multiple examples in OpenAPI #492

Closed
vengroff opened this issue Jan 5, 2025 · 8 comments
Closed

Support for multiple examples in OpenAPI #492

vengroff opened this issue Jan 5, 2025 · 8 comments
Labels
feature New feature or request

Comments

@vengroff
Copy link

vengroff commented Jan 5, 2025

This is a feature request originally posted in #57 (comment).

I have an OpenAPI spec that has a post endpoint with an examples section contained within the content section of the requestBody. When I look at the doc generated from this with the default zudoku.config.ts there is a box on the right where I can see sample calls in curl or a variety of languages. But all of them just pass empty lists or dictionaries to the various components of the request. All fields empty is not a valid input for this API, so it is frustrating to users that they don't see a working example.

What I would like to do is have a drop-down listing each of the examples the API spec provides with text for each choice coming from the summary field of one of the examples. When I pick one I would like to have it fill in the values in the example code from the value component of the chosen example and also render the description from the description field so the user can read it. This gives the user a known working input that they can then copy and paste or modify as they see fit. The standard docs generated by FastAPI do this for the API spec in question.

Copy link

linear bot commented Jan 5, 2025

@vengroff
Copy link
Author

vengroff commented Jan 6, 2025

Looking forward to this. Is there a way to get some additional visibility on priority and timing? I'm guessing that's what the linear bot link above is about, but it isn't visible to me.

@ntotten ntotten added the feature New feature or request label Jan 7, 2025
@mosch
Copy link
Contributor

mosch commented Jan 15, 2025

hey @vengroff, looking at the current behavior I agree I think is broken.
We've been discussing the right thing to do here a couple of times.

From my testing it looks like the defined example doesn't make it into the documentation at all. Do you experience the same?

@mosch
Copy link
Contributor

mosch commented Jan 15, 2025

We have a fix for showing the exmaples, should be available in a new version soon: #533

Update: It doesn't support choosing the examples yet, we still need to handle this feature request.

@mosch mosch changed the title Support examples from the OpenAPI Spec Support for multiple examples in OpenAPI Jan 15, 2025
@vengroff
Copy link
Author

Thank you. Supporting example at the argument level is great. examples is what I was most looking for. So that way if there are specific combinations of arguments that illustrate certain use cases we can put them all in the examples section and have them available from a drop-down with their descriptions.

The extension of this is to take the metadata in examples for whichever entry the user has selected from the drop down and generate sample calls across a variety of client languages, which the user also picks from another drop down.

@mosch
Copy link
Contributor

mosch commented Jan 15, 2025

Makes sense, we discussed the implementation of this today and we plan to add this feature soon. Thank you for asking about this again.

@mosch
Copy link
Contributor

mosch commented Jan 20, 2025

@vengroff do you want to check if it works for you in 0.25.1?

@dan-lee
Copy link
Contributor

dan-lee commented Jan 22, 2025

We think this should be resolved now! Please let us know if it doesn't work for you @vengroff. thanks!

@dan-lee dan-lee closed this as completed Jan 22, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature New feature or request
Development

No branches or pull requests

4 participants