-
-
Notifications
You must be signed in to change notification settings - Fork 886
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
Support OpenAPI 3.0 discriminator.mapping
#2003
Comments
Mapping in OpenAPI is defined as The general design approach is to prohibit schema elements that are ignored or can lead to contradictory results. We can make mapping allowed in discriminator by adding discriminator to strict mode, so it will require either strictDiscriminator: false/"log" or strict: {discriminator: false/"log"} in options to ignore/log it, rather than fail. |
Also, your schema is incorrect, discriminator has to be used on the object level, where you have tag property in, so it is supposed to be:
You can also note that the presence of discriminator never affects the validation result, it only results in shorter validation process, but it doesn't change the validity of the data - so you have to check that if removing discriminator changes the meaning of your schema, then it is not a correct schema. Unlike JSON Schema, JTD defines discriminator closer to what you expect it to be. |
These options are not working for me. I'm still seeing "discriminator: mapping is not supported" when doing ajv.compile. I guess what I also don't understand is that my schema compiled with v6.12.6, but is broken now with the latest (migrating to v8). |
Any thoughts on why this is? |
@thetumper I'm guessing they haven't actually added the |
@epoberezkin Let me be more clear. I'm a maintainer on react-jsonschema-form and we are trying to add support for discriminator into our code. Unfortunately, this issue will break most of the schemas that I personally am interested in using because they all have mappings that I'd rather not have to remove. So I would LOVE to see this new feature added so that I can turn it on. Thanks! |
Correct, it's not added. PR is welcome! |
@epoberezkin I wish I had the bandwidth to help on this. How soon might you be able to provide one? |
Lol without this, the ajv seems useless. |
The deprecation for discriminator in OpenAPI was postponed to 4.0, so it seems this feature will be around for a while. The MR above from April should solve most of the practical use cases. It could also be useful to enforce matching an explicit mapping in strict mode when any mappings have been defined for the schema. |
What version of Ajv you are you using?
8.11.0
What problem do you want to solve?
I'd like to validate JSON schema extracted from OpenAPI 3.0 that includes
discriminator.mapping
. Currently having it will make AJV throw a unavoidablediscriminator: mapping is not supported
error. Example code that throws:What do you think is the correct solution to problem?
Either implement
discriminator.mapping
as described here or alternatively gracefully ignore the presence of it so user code can implement this feature itself.Will you be able to implement it?
I could probably make it gracefully ignore the property.
The text was updated successfully, but these errors were encountered: