Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I denote decimal floating point in swagger specs?

I would like to denote decimal with 2 places and decimal with 1 place in my api documentation. I'm using swagger 2.0, Is there inbuilt defined type or any other 'round' parameter in the specs, or my only option is to use 'x-' extension?

like image 936
runakash Avatar asked Jul 07 '17 10:07

runakash


1 Answers

OpenAPI (fka Swagger) Specification uses a subset of JSON Schema to describe the data types.

If the parameter is passed as a number, you can try using multipleOf as suggested in this Q&A:

type: number
multipleOf: 0.1     # up to 1 decimal place,  e.g. 4.2
# multipleOf: 0.01  # up to 2 decimal places, e.g. 4.25

Hovewer, multipleOf validation against floating-point numbers can be unreliable due to floating-point math specifics.


If your number if passed as a string, you can specify a regex pattern for the desired number format:

type: string
pattern: your_regex


In any case, you can also document any restrictions verbally in the description.

like image 61
Helen Avatar answered Sep 19 '22 13:09

Helen