Complex data types
Describe APIs with flexible schemas, optional properties, and multiple data formats using oneOf
, anyOf
, and allOf
keywords
When your API accepts multiple data formats, has conditional fields, or uses inheritance patterns, OpenAPI’s schema composition keywords help you document these flexible structures. Using oneOf
, anyOf
, and allOf
, you can describe APIs that handle different input types or combine multiple schemas into comprehensive data models.
oneOf
, anyOf
, allOf
keywords
For complex data types, OpenAPI provides keywords for combining schemas:
allOf
: Combines multiple schemas (like merging objects or extending a base schema). Functions like anand
operator.anyOf
: Accepts data matching any of the provided schemas. Functions like anor
operator.oneOf
: Accepts data matching exactly one of the provided schemas. Functions like anexclusive-or
operator.
oneOf
and anyOf
identically since the practical difference rarely affects using the API.For detailed specifications of these keywords see the OpenAPI documentation.
not
keyword is currently unsupported.Combining schemas with allOf
When you use allOf
, Mintlify performs some preprocessing on your OpenAPI document to display complex combinations in a readable way. For example, when you combine two object schemas with allOf
, Mintlify combines the properties of both into a single object. This becomes especially useful when leveraging OpenAPI’s reusable components
.
Providing options with oneOf
and anyOf
When you use oneOf
or anyOf
, Mintlify displays the options in a tabbed container. Specify a title
field in each subschema to give your options names. For example, here’s how you might display two different types of delivery addresses: