Swagger PHP Object вместо массива
Пример разметки для модели
* @SWG\Model(
* id="UserSubscriptionSearchResultsFilter",
* @SWG\Property(name="total", type="integer"),
* @SWG\Property(name="perPage", type="integer"),
* @SWG\Property(name="query", type="string"),
* @SWG\Property(name="sortColumn", type="string"),
* @SWG\Property(name="sortDirection", type="string"),
* )
*/
/**
* @SWG\Model(
* id="UserSubscriptionSearchResults",
* @SWG\Property(name="results",type="array", items="$ref:UserSubscriptionRepository"),
* @SWG\Property(name="total", type="integer"),
* @SWG\Property(name="filter",type="object", uniqueItems="$ref:UserSubscriptionSearchResultsFilter")
* )
*/
Прямо сейчас схема выглядит так:
"filter": "object"
Вместо этого я хочу увидеть:
"filter": {
"total": 0,
"perPage": 0,
"query": "",
"sortColumn": "",
"sortDirection": ""
}
Прямо сейчас я только смог создать объект массива, который выглядит относительно похожим на это, но это все еще не полная спецификация.
Я читал подобные проблемы здесь: https://github.com/swagger-api/swagger-spec/issues/38 https://github.com/mission-liao/pyswagger/issues/18
Но я не нашел четкого ответа.
1 ответ
Правильная схема в Swagger 2.0 в вашем случае должна выглядеть примерно так:
"definitions": {
"filter": {
"type": "object",
"properties": {
"total": {
"type": "integer"
},
"perPage": {
"type": "integer"
},
"query": {
"type": "string"
},
"sortColumn": {
"type": "string"
},
"sortDirection": {
"type": "string"
}
}
}
}
Я думаю, что вы используете проект swagger-php. Вот цитата из их примера объявления модели отсюда:
<?php
namespace PetstoreIO;
/**
* @SWG\Definition(
* @SWG\Xml(name="Category")
* )
*/
class Category
{
/**
* @SWG\Property(format="int64")
* @var int
*/
public $id;
/**
* @SWG\Property()
* @var string
*/
public $name;
}
Термины изменяются с "модель" на "определение" при обновлении с 1,2 до 2,0.