Проблема проверки Swagger - Неправильное определение параметра -
Я борюсь с проблемой с Swagger и собираюсь сходить с ума... Это в основном работает, за исключением одного параметра. Вот ситуация:
Мой API может принимать некоторые ограничения поиска в URL. Пользователи могут иметь более одного поискового ограничения и отправлять их в виде массива в виде строки запроса (реальный случай здесь).
У меня возникла проблема с этой частью моей спецификации Swagger (и все это ниже)
{
"name": "constraints",
"in": "query",
"description": "Search constraints",
"type": "array",
"items": {
"$ref": "#/definitions/search_constraints"
}
}
Итак, я думаю, у меня есть два вопроса...
1) Я пытаюсь сделать что-то, что не поддерживается Swagger (имея параметр массив объектов в запросе URL)
2) Если нет, то что я делаю не так?
Я тестировал свой JSON в http://editor2.swagger.io/, и, кроме ошибки, он работает, то есть я могу проверить вызов, который выполняет поиск, добавить ограничения и т. Д., Как следует. Но из-за ошибки я не могу использовать readme.io и другие вещи...
Спасибо, парни!
Полный JSON
{
"swagger": "2.0",
"info": {
"title": "example-api",
"version": "1.0.0"
},
"host": "xxx.com",
"basePath": "/api/1.1/meta/swagger.json/api/1.1",
"schemes": [
"https"
],
"consumes": [
"application/json"
],
"paths": {
"/obj/pet": {
"get": {
"description": "Retrieve a list of things of type pet with some optional search constraints. Retreives 100 items at most at once.",
"parameters": [
{
"name": "limit",
"in": "query",
"description": "Number of items to fetch (maximum is 100)",
"type": "integer",
"format": "int32",
"default": 50
},
{
"name": "cursor",
"in": "query",
"description": "Position to start from in the list",
"type": "integer",
"format": "int32",
"default": 0
},
{
"name": "sort_field",
"in": "query",
"description": "Field to sort the list on",
"type": "string"
},
{
"name": "descending",
"in": "query",
"description": "Sorting type: descending or ascending",
"type": "boolean"
},
{
"name": "constraints",
"in": "query",
"description": "Search constraints",
"type": "array",
"items": {
"$ref": "#/definitions/search_constraints"
}
}
],
"responses": {
"200": {
"description": "Retrieved list of pets",
"schema": {
"type": "object",
"properties": {
"results": {
"type": "array",
"items": {
"$ref": "#/definitions/pet"
}
},
"cursor": {
"type": "number",
"format": "float",
"description": "Rank of the first item in the list"
},
"count": {
"type": "number",
"format": "float",
"description": "Number of items in the current response. It is the minimum between the actual length of the list and the sent limit (or 100 if you did not specify a limit)."
},
"remaining": {
"type": "number",
"format": "float",
"description": "Number of remaining items after the current response. Useful to fetch more items."
}
}
}
}
}
}
}
},
"definitions": {
"pet": {
"type": "object",
"properties": {
"Name": {
"type": "string",
"description": "'Name' field of the current Pet"
},
"unique ID": {
"type": "string",
"description": "'unique ID' field of the current Pet"
}
}
},
"search_constraints": {
"type": "object",
"properties": {
"key": {
"type": "string",
"description": "Field to apply the search constraint on. Can be `_all` for a full-text search"
},
"constraint_type": {
"type": "string",
"description": "Type of constraint. Can be anything among `equals`, `not equal`, `is_empty`, `is_not_empty`, `text contains`, `not text contains`, `greater than`, `less than`, `in`, `not in`, `contains`, `not contains`, `empty`, `not empty`, `geographic_search`"
},
"value": {
"type": "string",
"description": "Value to compare to"
}
},
"required": [
"key",
"constraint_type"
]
}
}
}