-
Notifications
You must be signed in to change notification settings - Fork 73
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
Swagger submitting incorrect format for Model-based form inputs #566
Comments
I don't know who's wrong, here. I'd assume Swagger UI is right. From the Swagger UI created curl statement, it looks like values lists in forms are sent as comma delimited lists. I'd try to use from webargs.fields import DelimitedList
# Schema
class MyFormData(Schema):
my_values = DelimitedList(fields.String()) You may want to search on the Internet how values list in forms are supposed to be passed (to double-check what SwaggerUI does) and how it should be documented (to ensure flask-smorest / apispec does it right). |
Thanks for the quick response! I gave response = client.post(
"/forms/my-form/",
data={
"my_values": [
"a",
"b",
],
},
)
# Fails, it does not parse out items beyond the first. We get OrderedDict([('my_fields', ['a'])])
assert response['my_values'] == ['a', 'b'] Looking at the form specification from Swagger's OpenAPI guide, it seems to suggest that form data generally uses the exploded (non-comma separated) values: https://swagger.io/docs/specification/serialization/ It seems like the actual behavior of
And
Based on this, Swagger's docs are consistent with this in that form/explode should be default notation for array objects. So it seems to be that there may be something missing (or accidentally overriding) for the inner array data inside this data type as defined in the generated openapi.json spec. That said, it's a pretty complex spec, so I have a hard time seeing how this all fits together enough to make a concrete recommendation of exactly what would need to be adjusted. I imagine it may be as "simple" as adding |
The DelimitedList failure is strange. I don't know when I'll have time and motivation to look into this. What you could do to help is try to override that specific part of the generated openapi spec with combinations of explode/style from the docs until you find one that works well with Swagger UI. Then we could try to fix apispec to render that in the spec. |
Good call! That didn't take too long once I started fiddling. It looks like we're missing an "paths": {
"/forms/my-form": {
"post": {
"requestBody": {
"required": true,
"content": {
"application/x-www-form-urlencoded": {
"schema": {
"$ref": "#/components/schemas/MyFormData"
},
####
"encoding": {
"my_values": {
"explode": true,
"style": "form"
}
}
####
}
}
},
"tags": [
"forms"
]
}
},
...
"MyFormData": {
"type": "object",
"properties": {
"my_values": {
"type": "array",
"items": {
"type": "string"
}
}
}
}, Reference here: https://spec.openapis.org/oas/v3.1.0#encoding-object It saw (but didn't read too closely) there was an open issue for multi-part form support. It looks like this may potentially make headway towards that as well. |
Hi, this is a bit of an edge case I'm running into, but I hope it's solvable with some configuration. It is also possible this is a bug with swagger itself, or I'm just using things in an unintended way.
The Problem
The swagger configuration generated for my form endpoint does not submit list data in a valid way. All other usage works fine, everything passes tests, etc. It is only when trying to use swagger UI's "Try it out" does this fail.
The failure mode is that swagger submits lists of items like
my_values=a,b
, but should be submitting via themy_values=a&my_values=b
, i.e. the way ofexplode=True
,style='form'
in OpenAPI 3.0+. As form data, my backend does not properly parse the comma-separated method.Reproducing
Assume the following schema and endpoint:
POST-ing to this endpoint via swagger with values and the form encoding like this:
yields a curl statement like this:
Which we can confirm by seeing the print output that this is not parsed into two values:
The relevant bits of
openapi.json
looks something like:Related Work
This appears at least tangentially related to marshmallow-code/apispec#500 and the fix marshmallow-code/apispec#778. I wasn't able to parse out if there is anything in there that I can action on though.
Thanks for taking the time to read - any thoughts on a potential workaround for fix would be appreciated.
The text was updated successfully, but these errors were encountered: