Мы пишем swagger документацию, используя /// комментарии следующим образом:
/// <summary>
/// Create a new widget
/// </summary>
/// <param name="widget"></param>
[HttpPost("/create")]
[ProducesResponseType(typeof(IPayment), 200)]
[ProducesResponseType(typeof(ErrorResult), 400)]
[ProducesResponseType(typeof(ErrorResult), 404)]
public Task<IActionResult> CreateWidget([FromBody] Widget widget)
{
Теперь Widget является реализацией IWidget, и пользователь документации должен подробно знать, что каждый член данных Widget/ IWidget означает, что является обязательным, что является необязательным, и допустимые значения.
Мы обнаружили, что единственное место, где можно добавить это описание, это
/// <param name="widget">very big multi line description</param>
Хотя это работает для конечного пользователя, этоесть лучший способ?Мы спрашиваем об этом, потому что это гораздо более легко поддерживать, если описания предоставляются в виде определения класса / интерфейса.