Проблема проверки 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"
            ]
        }
    }
}

0 ответов

Другие вопросы по тегам