-
Notifications
You must be signed in to change notification settings - Fork 241
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
Add OpenAPI 3.1 Support #795
Comments
I'm particularly interested in the new |
@darrelmiller do you have an ETA on this? Do you need help? |
It is currently planned as a stretch goal for CY2022H2. |
I believe dictionary support is missing from the list microsoft/kiota#62 |
@KeithMAtFis I have good news for you! Previously, But since OpenAPI 3.1 uses JSON Schema 2020-12, this restriction is lifted, and now sibling keywords are respected. Your use case should work as long as the package does something with the |
@gregsdennis that is great. I should have provided some background, I am using Minimal API and DOTNet 6, C#10 and it seems that that does not support OpenAPI 3.1.0 yet in its current form. Out of the box there is Swagger support but it seems to only support 3.0.1 and backwards support to v2. I have not found a way to allow output to 3.1.0 standards. The Nugets that I am using are Swashbuckle.AspNetCore, Swashbuckle.AspNetCore.Swagger and Swashbuckle.Core all at version 6.4.0 (latest). Would you know if there is another NuGet that I should be using or certain configuration i should use? Btw, I really appreciate you taking the time to respond. (here is the GITHUB link to support 3.1.0 in Swashbuckle domaindrivendev/Swashbuckle.AspNetCore#2349) |
I don't know of any others, no. It looks like Swashbuckle is dependent upon this lib, so the goal is to get this one going first. |
There's a new project https://github.com/sourcemeta/alterschema that aims to convert between schema versions. I think they plan to handle OpenAPI versions as well eventually. This might take care of "Enable upcasting from V2/V3 to 3.1". |
What are the timeline on these changes? It looks like a lot of project depends on this project to move forward with OpenAPI 3.1 With regards, |
Hello all! I'm taking a sab at implementing the 9th item - "Map nullable to null type." I have broken up this effort into two seperate PRs. I want to make sure I am not stepping on anyones toes before raising a PR. The first modifies the parser to map the OpenAPI represetntation of null within a type array to the existing Does this sound good to everyone? |
Hey @funkeyfreak, |
@funkeyfreak we're considering taking a dependency on an external JSON schema library so maybe just hold off on creating a PR. |
Hi @msolujic, we've finished working on this issue but we're currently working on other breaking changes that need to go out with the v2.0 release. ETA for the preview release is within a month or less. |
Do we have support for OAS 3.1 now? |
I'm confused by the lack of communication here, especially given that so many projects are dependent on this library (and that the 3.1 spec was released >3 years ago). 2.0 is past due by about 1 month. What's the current ETA? Will you release a preview? |
joining questions from @JWMB hi @MaggieKimani1 @zijianhuang @baywet do we have any ETA when support for 3.1 will be released? |
Great, thanks. Please consider keeping us updated on the progress - I suggest keeping the the milestone page updated with the latest info, plus adding a link to it from any issues/comments asking about the release or support for 3.1. |
@njaci1 we've had comments about lack of clear communications multiple times at this point.
This way the community, customers, and dependant teams have a clearer understanding of where things are at. Thanks! |
The commit history (pretty much only lib bumps lately) and the lack of communication gives me the feeling this project is abandonware. and that the real work is being done somewhere else in preparation for the .NET 9 release (which has several OpenAPI initiatives tied to it). Hidden git branches could be another possibility. I can't imagine the Kiota team would be content with having dependencies to this project if vnext is really progressing as slowly as it seems. |
@JWMB ...or let us consider another theory. A big chunk of the dev team has been asked to work on security related issues. The remaining developers are being asked to focus on some specific Copilot related activities because it is a company wide effort that takes the highest priority. The few people who were tasked with working on this library are only able to sneak in a few hours a week, at least while this other work takes priority. Imagine that the target was to actually deliver 3.1 support as part of the .net9 timeline, but that the team had to tell the .net team that they were not able to make that deadline. Why? Because OpenAPI 3.1 is hard to implement properly. Partly because the integration between JSON Schema 2020-12 and OpenAPI 3.1 was sadly underspecified. I can take partial blame for that as I was heavily involved. Many other OpenAPI libraries treat $refs as pre-processing instructions and the in-memory representation has no awareness of use of $ref. That's not how OpenAPI.NET works. OpenAPI.NET attempts to preserve the referencing model whilst still trying to make the referenced information easily accessible. This has been challenging in OpenAPI.NET v2, particularly whilst trying to incorporate the JsonSchema.NET library which comes with its own set of conventions and behavior. |
Fantastic to finally get some honest messaging, I'm sincerely thankful. I think if you look at past comments here, the main issue is the lack of communication; silence breeds speculation. |
@JWMB That is a fair criticism. The lack of communication was definitely not because we don't care. It is just hard to make firm commitments on OSS projects at Microsoft that are not part of a primary effort. |
@darrelmiller I've sadly seen this as a recurring pattern from Microsoft. We all respect and understand that priorities don't always align with the community's priorities, and I believe I can comfortably say that most of us are able to adjust to that reality when it's communicated to us. I really value that Microsoft has moved to doing a lot of it's work out in the open using GitHub, but there's still a lot of internal communication that never gets transmitted back to the community. For example, System.CommandLine was dead for years, stuck in a perpetual state of beta, to which no one responded and was suddenly bought back to life recently. This left most of us in the state of uncertainty wondering if it was a priority issue or if it was abandonware. A small sign of life is often all that's needed for us to adjust our expectations. |
@jscarle, I share the same view, however, I guess the embarrassing situation is probably partly due to the reshuffle of MS, says, the recent massive layoff, so dedicated veteran programmers in MS might have to resolve some issues due to some temp vacuum. 3.1 had been release in early 2021, and many there have been many on .NET solution around for years. I am pretty sure veteran programmers in MS well understand what the communities along with business customers of MS stacks really want and need, and wishfully they may have more says in the priority. |
The current ChatGPT Plugin only supports OAS 3.1 |
hi @darrelmiller @MaggieKimani1 |
Somewhere in the ASP.NET Community Standup: OpenAPI Updates in .NET 9 video it was mentioned that .NET 9 will not contain OpenAPI 3.1 support because OpenAPI.NET will not be ready in time. So don't expect a release before mid November. |
@cremor yes i checked the video and this is the moment they say it. https://www.youtube.com/live/XoMese9g8WQ?feature=shared&t=3780 That's sad. This discussion started in 2022 and and two years after we don't have it. |
@MaggieKimani1 is there an ETA to add 3.1.0 support? Also, why is the issue marked as Closed if it is not supported yet? |
@darrelmiller @baywet I see the milestone due date has been changed to 2024-10-31 - is this the current assessment? |
@darrelmiller @baywet @MaggieKimani1 |
Hi @JWMB, the preview release is currently underway. I'll let you know as soon as the preview is available on NuGET. |
Everyone! We have a preview version out please go try it out and give us feedback! |
Includes:
The text was updated successfully, but these errors were encountered: