gpt4 book ai didi

Swashbuckle 隐藏未引用的模型

转载 作者:行者123 更新时间:2023-12-01 08:34:16 26 4
gpt4 key购买 nike

我在隐藏调用时遇到 Swashbuckle 问题,链接到调用的模型定义保留在生成的 JSON 中的定义中。

使用文档过滤器,我可以从界面中删除调用。

调用保留在生成的 JSON 中,但在 Swagger UI 中不可见。我们还可以看到链接到这些调用的模型和枚举的定义。

这些是内部调用,需要在 JSON 中对外部眼睛隐藏。

如何隐藏所有调用及其引用?

使用 [ApiExplorerSettings(IgnoreApi = true)] 可以解决我的问题,但我需要使用现有属性进行过滤。

最佳答案

所以我通过努力找到了问题的答案。我把它放在这里是为了让下一个遇到我的问题的人比我过得更好。

public static class SwashbuckleExtensions
{
public static IEnumerable<Operation> EnumerateOperations(this PathItem pathItem)
{
if (pathItem == null)
{
yield break;
}
yield return pathItem.get;
yield return pathItem.post;
yield return pathItem.put;
yield return pathItem.delete;
yield return pathItem.options;
yield return pathItem.head;
}


public static IEnumerable<Schema> EnumerateSchema(this Operation operation)
{
if (operation == null)
{
yield break;
}
foreach (var response in operation.responses ?? new Dictionary<string, Response>())
{
yield return response.Value.schema;
if (response.Value.schema.items != null)
{
yield return response.Value.schema.items;
}
}
foreach (var parameter in operation.parameters ?? new List<Parameter>())
{
yield return parameter.schema;
}
}


public static IEnumerable<Schema> FindAdditionalSchema(this Schema schema, IDictionary<string, Schema> listOfDefinition)
{
if (!string.IsNullOrEmpty(schema.@ref))
{
Schema definition;
if (listOfDefinition.TryGetValue(schema.@ref.Replace("#/definitions/", String.Empty), out definition))
{
foreach (var propertySchema in definition.properties)
{
yield return propertySchema.Value;
}
}
}
if (!string.IsNullOrEmpty( schema?.items?.@ref))
{
Schema definition;
if (listOfDefinition.TryGetValue(schema.items.@ref.Replace("#/definitions/", String.Empty), out definition))
{
foreach (var propertySchema in definition.properties)
{
yield return propertySchema.Value;
}
}
}
}

public static IEnumerable<Schema> EnumerateSchema(this Schema schema,IDictionary<string,Schema> listOfDefinition, int dept = 0)
{
if (schema == null)
{
yield break;
}
if (dept > 10)
{
yield break;
}
if (dept == 0)
{
yield return schema;
}

var ListOfAdditionalSchema = schema.FindAdditionalSchema(listOfDefinition) ?? new List<Schema>();
foreach (var additionalSchema in ListOfAdditionalSchema)
{
yield return additionalSchema;
foreach (var childSchema in additionalSchema.EnumerateSchema(listOfDefinition,dept++) ?? new List<Schema>())
{
yield return childSchema;
}
}
}
}

然后在DocumentFilter中

    public void Apply(SwaggerDocument swaggerDoc, SchemaRegistry schemaRegistry, IApiExplorer apiExplorer)
{


foreach (var value in swaggerDoc.paths.Values)
{
if (value.post != null && value.post.tags.Contains(ToHide))
value.post = null;

if (value.get != null && value.get.tags.Contains(ToHide))
value.get = null;

if (value.put != null && value.put.tags.Contains(ToHide))
value.put = null;

if (value.delete != null && value.delete.tags.Contains(ToHide))
value.delete = null;

if (value.head != null && value.head.tags.Contains(ToHide))
value.head = null;

if (value.options != null && value.options.tags.Contains(ToHide))
value.options = null;
}

var pathToDelete = swaggerDoc.paths.Where(x => !x.Value.EnumerateOperations().Any(y=>y != null) )
.ToList();//Deleting item from source need list
foreach (var item in pathToDelete)
{
swaggerDoc.paths.Remove(item.Key);
}


var listOfSchemaWithReference = swaggerDoc.paths.SelectMany(x => x.Value.EnumerateOperations())//Find operation by path
.SelectMany(x => x.EnumerateSchema()) //Find schema by operation
.SelectMany(x => x.EnumerateSchema(swaggerDoc.definitions))//Find Schema by schema (dependent schema)
.Where(x=> x?.@ref != null || x?.items?.@ref != null)//I only wany the schema that reference a definition.
.Select(x=> ((x?.@ref) ?? (x.items?.@ref) ).Replace("#/definitions/", String.Empty))//remove the path and keep the Model name
.Distinct()//I dont like duplicates
.ToList();//commit to memory

//Not finding a definition in the built list of reference means its unreferenced and can be removed.
var listOfUnreferencedDefinition = swaggerDoc.definitions.Where(x => !listOfSchemaWithReference.Any(y => y == x.Key))
.ToList();//Deleting item from source need list

foreach (var unreferencedDefinition in listOfUnreferencedDefinition)
{
swaggerDoc.definitions.Remove(unreferencedDefinition.Key);
}
}
}

关于Swashbuckle 隐藏未引用的模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46116507/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com