Skip to content

Not generating unions with multiple media types #314

@slinkardbrandon

Description

@slinkardbrandon

There seems to be an issue generating union types when multiple media types exist that alter the requirements for the request body.

Example path with multiple media types (right from the swagger requestBody docs):

Given the following schema:

paths:
  /pets:
    post:
      summary: Add a new pet
      requestBody:
        content:
          "application/json":
            schema:
              $ref: '#/components/schemas/Cat'
          "application/foo.bar+json":
            schema:
              $ref: '#/components/schemas/Dog'

Only one output method will be generated, it seems to either be application/json or index 0, I'm not entirely sure.

Is there any way I can get this to generate a union type rather than always generating from schemas/Cat? It seems like the swagger specification should allow for multiple media types for a single endpoint.

The requestBody is more flexible in that it lets you consume different media types, such as JSON, XML, form data, plain text, and others, and use different schemas for different media types. requestBody consists of the content object, an optional Markdown-formatted description, and an optional required flag (false by default). content lists the media types consumed by the operation (such as application/json) and specifies the schema for each media type

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions