swagger-typescript-api icon indicating copy to clipboard operation
swagger-typescript-api copied to clipboard

Not generating unions with multiple media types

Open slinkardbrandon opened this issue 3 years ago • 1 comments

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

slinkardbrandon avatar Nov 05 '21 22:11 slinkardbrandon