-
Notifications
You must be signed in to change notification settings - Fork 364
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
Upgrade version of oapi-codegen
#7493
Conversation
To get the latest features and bug fixes, we should bump to the latest version of the library.
Hi @jamietanna , |
Still doesn't compile.
This looks really neat and a good idea! @jamietanna : did you manage to run Perhaps we're generating the files incorrectly? Or some further template updates are missing? |
The new code has stricter typing for enums, which is cool! I fixed the relevant compilation breakage in 4d335e3, but now this func is broken. This version bump is turning into a somewhat larger fix than I expected. I'd of course be happily grateful for your time to advise us on doing it -- but will you have time for us? Again: thanks! |
Thanks for your changes to help with this too - I think these latest changes should pass - I'm just running through the tests locally now |
Oh hmm I see #7532 |
OK, so my confusion with getting the changes appears to be because we've got a mix of files that are and aren't committed - think I've managed to get there now (with many more build errors!) |
#7533 will be a prerequisite, then it'll be easier to see the difference when doing the upgrade 👍 |
Currently we use |
The current compilation failures look like this. I'll try to fix them. |
I kept on going over on my fork of your fork :-/ . But I hit a wall. I would appreciate your help getting 92e7e0e to compile. The generated code has this method stub in the interface: // Abort a presign multipart upload
// (DELETE /repositories/{repository}/branches/{branch}/staging/pmpu/{uploadId})
AbortPresignMultipartUpload(w http.ResponseWriter, r *http.Request, repository string, branch string, uploadId string, params AbortPresignMultipartUploadParams) This is the OpenAPI spec: delete:
tags:
- experimental
operationId: abortPresignMultipartUpload
summary: Abort a presign multipart upload
description: Aborts a presign multipart upload.
requestBody:
content:
application/json:
schema:
$ref: "#/components/schemas/AbortPresignMultipartUpload"
responses:
204:
description: Presign multipart upload aborted
400:
$ref: "#/components/responses/BadRequest"
401:
$ref: "#/components/responses/Unauthorized"
404:
$ref: "#/components/responses/NotFound"
420:
description: too many requests
default:
$ref: "#/components/responses/ServerError" As you may see, it takes a requestBody of type AbortPresignMultipartUpload. I don't understand: how does the generated server code deliver this body? If it helps, here's the generated lakefs.gen.go.gz. |
In fact I found this comment on a related OpenAPI issue. It seems that the OpenAPI 3.1 spec may have pulled the rug from beneath our feet. This is a very real concern! We have a stable 1.0 API. Obviously we cannot change it to remove a DELETE method without bumping a new major version. Frankly it will not be worth the product effort to do this. A possible mitigation is that this is an experimental API, which explicitly means we are allowed to change it. Opened #7538 to do something about this. But I would VERY MUCH like to keep going on this PR. @jamietanna , can you help us convince the codegen to relax this enforcement? I want to resolve this issue before the API leaves experimental, I want this PR, but I don't want this PR to be blocked by that issue. Realistically, we know that we have users who use this API. So while I can change this API at will, it will take at least 2 releases with a fairly long period to allow users to adapt between them. |
This PR is now marked as stale after 30 days of inactivity, and will be closed soon. To keep it, mark it with the "no stale" label. |
Thanks for the heads-up and help, @jamietanna! I'm continuing this on #7532. It's now compiling and everything. |
This PR is now marked as stale after 30 days of inactivity, and will be closed soon. To keep it, mark it with the "no stale" label. |
Closing this PR because it has been stale for 7 days with no activity. |
To get the latest features and bug fixes, we should bump to the latest
version of the library.
Thanks for using oapi-codegen!
Note that I've not updated
lakeFS/pkg/api/serve.go
Line 100 in 16cf769
May also be worth reviewing the upstream templates vs our versions here, in case there's anything else useful to bring in changes wise