Skip to content
This repository has been archived by the owner on Nov 8, 2024. It is now read-only.

Polymorphic Type Response #442

Closed
terrancesnyder opened this issue May 1, 2019 · 2 comments
Closed

Polymorphic Type Response #442

terrancesnyder opened this issue May 1, 2019 · 2 comments

Comments

@terrancesnyder
Copy link

Hello, I seem to have an issue getting documentation given a response object.

Assume the following basic example, classic pet shop inheritance..

AnimalTargeting

  • array[AnimalTarget] include
  • array[AnimalTarget] exclude

AnimalTarget (object)
.. definition here...

AnimalCatTarget (AnimalTarget)
.. definition here...

AnimalDogTarget (AnimalTarget)
.. definition here...

AnimalBirdTarget (AnimalTarget)
.. definition here...

Assume I expose a object with:

PetShopCoupon (object)

  • targeting (AnimalTargeting) - The animal targeting you want to use.

Because I have polymorphic types, the generated documentation doesn't really give a detailed list of all available options, so it's becomes close to impossible to not provide alternative documentation for the other polymorphic types.

I was hoping the API generated/documentation would provide "Possible Types to Use..." or a "more types available..." so that a user could explore the options.

Am I missing this feature someplace?

@kylef
Copy link
Member

kylef commented May 8, 2019

MSON allows you to declare "sample" values, these are values that can be used as samples but they do not restrict what may be a permitted value. Sounds like this may be what you are looking for, for example:

# My API

## GET /

+ Response 200 (application/json)
    + Attributes (array[AnimalTarget], fixed-type)
        + Sample
            + (AnimalCatTarget)
            + (AnimalDogTarget)

## Data Structures

### AnimalTarget

+ type (required)

### AnimalCatTarget (AnimalTarget)

+ type: cat (fixed)

### AnimalDogTarget (AnimalTarget)

+ type: dog (fixed)

We've delcared that our response is an array of AnimalTarget, and we've provided two example values.

Unfortunately, there are two bugs which makes this not work as expected, one in the parser (apiaryio/drafter#519) where the generated JSON bodies are not using the samples. We've attempted to fix this in apiaryio/drafter#587 but it's become complex to solve and we're unsure if we'll be able to solve this with a significant breaking change to the compiled form of API Blueprints (API Elements). You could perhaps work around this by providing your own JSON body which is the sample value to be used, for example:

# My API

## GET /

+ Response 200 (application/json)
    + Attributes (array[AnimalTarget], fixed-type)

    + Body
    
            [
                { "type": "cat" },
                { "type": "dog" }
            ]

## Data Structures

### AnimalTarget

+ type (required)

Which will show the following JSON example in mock servers and documentation:

Screenshot 2019-05-08 at 14 08 58

Secondly, the other bug I referred to is apiaryio/attributes-kit#489 which affects Apiary's documentation rendering of the attributes.

@kylef
Copy link
Member

kylef commented May 8, 2019

Perhaps you could achieve what you are looking for by declaring the potential values inside the array, for example:

FORMAT: 1A

# My API

## GET /

+ Response 200 (application/json)
    + Attributes (array)
        + (AnimalCatTarget)
        + (AnimalDogTarget)

## Data Structures

### AnimalCatTarget (AnimalTarget)

+ type: cat (fixed)

### AnimalDogTarget (AnimalTarget)

+ type: dog (fixed)

This can be rendered as:

Screenshot 2019-05-08 at 14 19 55

@kylef kylef closed this as completed Sep 28, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

No branches or pull requests

2 participants