Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

how to pass multi value query params in swagger

Tags:

ruby

swagger

I have following service in swagger.yml. The service is written so that page_id can be passed multiple times. e.g /pages?page_id[]=123&page_id[]=542

I checked this link https://swagger.io/specification/ but couldnt understand how could i update yml so i could pass id multiple times.

I see that i have to set collectionFormat but dont know how.

I tried updating it like below but no luck https://github.com/OAI/OpenAPI-Specification/blob/master/versions/2.0.md.

it generates url like 'http://localhost:0000/pages?page_id=123%2C%20542`

 '/pages':
    get:
      tags:
        - 
      summary: get the list of pages
      operationId: getPages
      produces:
        - application/json
      parameters:
        - name: page_id
          in: query
          description: some description
          required: false
          type: string
          collectionFormat: multi
        - name: page_detail
          in: query
          description: some description
          required: false
          type: string
      responses:
        '200':
          description: OK
        '401':
          description: Authentication Failed
        '404':
          description: Not Found
        '503':
          description: Service Not Available
like image 960
mike Avatar asked Nov 21 '17 19:11

mike


1 Answers

You are almost there. Name the parameter page_id[], make it type: array and use collectionFormat: multi:

      parameters:
        - name: page_id[]
          in: query
          description: some description
          required: false
          type: array
          items:
            type: string   # or type: integer or whatever the type is 
          collectionFormat: multi

Note that the requests will be sent with the [ and ] characters percent-encoded as %5B and %5D, because they are reserved characters according to RFC 3986.

http://example.com/pages?page_id%5B%5D=123&page_id%5B%5D=456
like image 120
Helen Avatar answered Sep 18 '22 05:09

Helen