using NSwag.Generation.Processors;
using NSwag.Generation.Processors.Contexts;
using System.Collections.Generic;
namespace Timeline.Swagger
{
///
/// Swagger operation processor that adds default description to response.
///
public class DefaultDescriptionOperationProcessor : IOperationProcessor
{
private readonly Dictionary defaultDescriptionMap = new Dictionary
{
["200"] = "Succeeded to perform the operation.",
["304"] = "Item does not change.",
["400"] = "See code and message for error info.",
["401"] = "You need to log in to perform this operation.",
["403"] = "You have no permission to perform the operation.",
["404"] = "Item does not exist. See code and message for error info."
};
///
public bool Process(OperationProcessorContext context)
{
var responses = context.OperationDescription.Operation.Responses;
foreach (var (httpStatusCode, res) in responses)
{
if (!string.IsNullOrEmpty(res.Description)) continue;
if (defaultDescriptionMap.ContainsKey(httpStatusCode))
{
res.Description = defaultDescriptionMap[httpStatusCode];
}
}
return true;
}
}
}