-
Notifications
You must be signed in to change notification settings - Fork 125
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
multipart/form-data request body schemas with additionalProperties are a bit confusing to use, also doesn't compile #596
Comments
Thanks @jakepetroules, let us take a look at this. The combination of multipart and typed additional properties might not be something I've seen before. But I do think your OpenAPI inputs are valid, so we should make this work. |
Multipart has special handling in Swift OpenAPI Generator. The schema is generated differently because it's used as the top level object that describes the possible multipart parts. More on that in the original proposal: https://swiftpackageindex.com/apple/swift-openapi-generator/1.2.1/documentation/swift-openapi-generator/soar-0009#Different-enum-case-types So JobParameters and JobParameters2 will not look the same, and both are generated correctly. The issue I'm now looking into is why the code doesn't compile, that's the only problem I see right now. |
Yes, this is also expected. The top level
|
Yikes, so this has at least one bug: the proposal dictates the additional properties enum case to be called "other", but it's only called that in some cases, but "additionalProperties" in other. That's my oversight, and I'll think about how to fix this without breaking backwards compatibility. That's issue 1. Still digging into issue 2, as reported by Jake. |
Ok issue 2 is a genuine bug in the mapping of So once fixed, the underlying type will go from: @frozen public enum JobParameters: Sendable, Hashable {
case additionalProperties(OpenAPIRuntime.MultipartDynamicallyNamedPart<Swift.String>)
} to @frozen public enum JobParameters: Sendable, Hashable {
case additionalProperties(OpenAPIRuntime.MultipartDynamicallyNamedPart<OpenAPIRuntime.HTTPBody>)
} A reminder that you can easily go from HTTPBody to a String using https://swiftpackageindex.com/apple/swift-openapi-runtime/1.4.0/documentation/openapiruntime/swift/string/init(collecting:upto:) And since this never compiled, I think it should be okay to do this "breaking change"? WDYT, @simonjbeaumont? |
@jakepetroules A fix incoming here: #597 The other issue ( |
Description
OpenAPI allows using the following construct to represent a
[String: String]
dictionary:However, this doesn't work correctly with multipart/form-data
Reproduction
Considering the following code...
Schema request body:
Schema components:
This generated the following Swift code:
Package version(s)
swift-openapi-generator 1.2.1
swift-openapi-runtime 1.4.0
Expected behavior
The inclusion of JobParameters2 is merely for illustration. That's what I would have expected JobParameters to look like.
It was initially quite unclear to me how to pass a
[String: String]
into this construct, as I would have expected something like this at the call site:but you actually need to use this:
However, the final problem is this:
The generated code doesn't compile, as
value
is aString
, but anHTTPBody
is expected there.I was able to work around the compile error by adding to my target:
That seems to work at runtime as well.
Environment
N/A
Additional information
No response
The text was updated successfully, but these errors were encountered: