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

Add support for handling OpenAPI v3.1 definitions #3914

Open
julealgon opened this issue Dec 14, 2023 · 15 comments · May be fixed by #5936
Open

Add support for handling OpenAPI v3.1 definitions #3914

julealgon opened this issue Dec 14, 2023 · 15 comments · May be fixed by #5936
Assignees
Labels
blocked This work can't be done until an external dependent work is done. enhancement New feature or request generator Issues or improvements relater to generation capabilities. WIP
Milestone

Comments

@julealgon
Copy link

We started using Kiota recently for a new integration, but the OpenAPI definition for the API we were to interface with uses the v3.1 OpenAPI spec. When attempting to generate a client for this spec, we get the following error message:

crit: Kiota.Builder.KiotaBuilder[0]
      error generating the client: OpenAPI specification version '3.1.0' is not supported.

This forced us to down-convert the definition from v3.1 to v3.0 to be able to use Kiota to generate a C# client for it.

We'd like for Kiota to be able to handle OpenAPI v3.1 natively, so that we don't have to perform this extra, lossy conversion step. The conversion increases maintenance substantially for us, since now we cannot refer directly to the target API's OpenAPI definition, and instead, forces us to maintain a local converted definition file ourselves. Additionally, whenever the target API definition changes in any way, we are then required to perform the conversion step manually again and update our converted file, to only then be able to run Kiota on it again to generate the updated proxy.

For reference, this is the definition we are currently targeting (from SendGrid):

@github-project-automation github-project-automation bot moved this to Todo in Kiota Dec 14, 2023
@baywet baywet self-assigned this Dec 15, 2023
@baywet baywet added enhancement New feature or request blocked This work can't be done until an external dependent work is done. generator Issues or improvements relater to generation capabilities. labels Dec 15, 2023
@baywet baywet added this to the Kiota v2.0 milestone Dec 15, 2023
@baywet
Copy link
Member

baywet commented Dec 15, 2023

Hi @julealgon,
Thanks for using kiota and for reaching out.
Kiota relies on OpenAPI.net to parse the descriptions, a library which is also owned by my team.
It doesn't support 3.1 yet, but we're making progress towards it
Once the support is finalized, we should be able to add it here as well fairly quickly, which should also unblock a number of scenarios (like dictionaries/maps etc...)
Keeping this issue opened for now

@JamieMagee
Copy link
Member

@baywet Once OpenAPI 3.1 support is finalized, is support for generation of webhooks planned? I currently maintain https://github.com/octokit/webhooks.net manually, but am eager to switch over to automatic generation if possible.

@baywet
Copy link
Member

baywet commented Jan 8, 2024

@JamieMagee if by generation of webhooks you mean generating the models for the incoming requests, sure we could add that.
If you mean something else, can you clarify please?

@JamieMagee
Copy link
Member

@baywet yes, that's exactly what I am talking about. A top level webhooks property was added as part of the OpenAPI 3.1 spec1:

Major Changes in OpenAPI Specification 3.1.0
...

  • New top-level element for describing Webhooks that are registered and managed out of band

As of release v2.1.02 of the GitHub REST API description webhook schemas are included.

Footnotes

  1. https://www.openapis.org/blog/2021/02/18/openapi-specification-3-1-released

  2. https://github.com/github/rest-api-description/releases/tag/v2.1.0

@baywet
Copy link
Member

baywet commented Jan 8, 2024

Thanks for clarifying!

@mrBen
Copy link

mrBen commented Apr 1, 2024

Hello,
In the OpenAPI.NET repo, the issue about 3.1 support is closed.
Should we expect Kiota to support v3.1 soon?

@sebastienlevert
Copy link
Contributor

Yes! It's absolutely something we'll start working on soon as there is a lot of demand for it!

We have some other priorities right now but this should be in the next bucket of improvements!

@ricardoboss
Copy link
Contributor

Have the priorities changed by now? 😄
Any timeline for 3.1 support?

@harritaylor
Copy link

harritaylor commented Jul 31, 2024

adding a +1 for demand here - all our APIs are using OAI3.1 so having to down-convert to 3.0 is a little cumbersome. (also happy to help with contributing!)

@baywet
Copy link
Member

baywet commented Jul 31, 2024

No updated timeline to share at this point.
You can track the progress in the dependency with this milestone
Whenever a preview of the new version is available, we'll be able to start work in kiota.

@jhancock-taxa
Copy link

Please make sure that when this is implemented it fully supports proper enums with number/string representation in all languages that generate real enums with real numerical values attached like this:

public enum Example {
  E1 = 1,
  E2 = 2,
  E3 = 4,
  ...etc.
}

The value should always be defined, never left to some automatic guess work based on the starting value too.

See #5165 for examples of what should be correctly outputted as your test case. In the case where the key is a string, languages should use a const static class to represent those if they don't support string/string (i.e. c#)

I've defined an example in #5165 as well of what the OpenAPI 3.1 version looks like.

@LockTar
Copy link

LockTar commented Nov 27, 2024

@baywet is there some preview version that we can try? I have a 3.1 spec that I want to use.
I've installed 1.21.0-preview.202411210001 but still getting the error error generating the client: OpenAPI specification version '3.1.0' is not supported.

Hopefully you get v3.1 support working soon. Great work on this tool already!

@baywet
Copy link
Member

baywet commented Nov 27, 2024

Hey everyone,
I want to share an update on the progress, and our intended results here.

OpenAPI.net has released a preview of v2, which adds support for OpenAPI 3.1 🎉🎉🎉

We're using kiota (and other internal tools) to dog food this new version, so we can collect and address feedback on this new version before releasing a new major release (non-preview).

This has already allowed us to collect a lot of issues with one that's currently blocking kiota and is being worked on.

I have not opened a PR yet to reduce noise (but let me know if it would help you track progress), but my branch (feat/OAI-3-1) has ~150 failing unit tests, the vast majority caused by the bug mentioned above. Once this is fixed, we can think about previewing things in kiota (we don't need for all the feedback to be addressed as we can take a dependency on a preview release, and iterate on that).

Now, when we refer to "OpenAPI 3.1 support" it's usually helpful to break it down into:

  • simply being able to parse an OAS 3.1 document, which will unblock a lot of you.
  • implementing new features (new type array, webhooks, etc...) that are additive (non-breaking). We'll most likely rely on the feedback once a preview is out to drive priorities.
  • implementing new features that are source breaking. We're already having internal conversations about a potential kiota v2, and what the scope would be. Input is always appreciated.

If during the testing phase we realize the basic parsing of OAS3.1 brings some breaking changes, we'll have to review the sequencing here.

I hope this update is positive news to most of you, I do not have any timelines to share, but I'll be happy to answer questions :)

@baywet baywet moved this from Todo 📃 to Blocked 🔒 in Kiota Nov 27, 2024
@baywet baywet modified the milestones: Kiota v1.21, Kiota v1.22 Dec 5, 2024
@baywet baywet linked a pull request Dec 23, 2024 that will close this issue
@baywet
Copy link
Member

baywet commented Dec 23, 2024

Hi everyone,
I wanted to share an additional update on this topic.

The incubation of the preview version resulted in lots of feedback, which is gradually being addressed.
The main point of contention for kiota, being able to automatically detect the description format, has been addressed and released, which has allowed us to make additional progress in the migration of kiota itself.

I've started a draft PR at #5936

You'll see we're down to ~15 unit tests failing at this point. They are all caused by two dependencies: Microsoft.Plugins.Manifest and Microsoft.OpenApi.ApiManifest which depend on Microsoft.OpenAPI 1.X, causing assemblies loading confusion. I'll be working with the library owners to get them to upgrade to Microsoft.OpenAPI 2.X as well to unblock us.

Once that part is done, we might have additional adjustments to make since Microsoft.OpenAPI will have addressed additional feedback. And after that, we'll see what results we get from integration tests.

Hopefully this is good news for all of you! Happy end of the year celebrations!

@andrueastman andrueastman modified the milestones: Kiota v1.22, Kiota v1.23 Jan 9, 2025
@gturri
Copy link

gturri commented Jan 15, 2025

Thanks for this work @baywet ! 🙏

Just to clarify: does it mean that once this is released it will be possible generate enum with ad hoc number representation (as requested by that comment from @jhancock-taxa #3914 (comment) )?

(and if it's the case, what kind of Open API specification will it expect to do so?)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
blocked This work can't be done until an external dependent work is done. enhancement New feature or request generator Issues or improvements relater to generation capabilities. WIP
Projects
Status: Blocked 🔒
Development

Successfully merging a pull request may close this issue.