我有两个应用程序A和B。在A上,我使用swagger来描述API。在A上,我还定义了一些枚举属性的类。我想在B上生成一个客户端API。为此,我使用Autorest。除了一件事外,一切都很好。由于某些原因,枚举没有正确生成,而且属性的类型(最初是enum)是字符串或int的类型(取决于DescribeAllEnumsAsStrings()的使用)。我在下面的示例中使用了它,所以在本例中它是字符串)。
Enum定义通过swagger生成JSON:
"Car": {
"properties": {
"color": {
"enum": [
"Red",
"Blue",
"Green"
],
"type": "string"
}
},
"type": "object"
}Startup.cs中的Swagger注册
// Register the Swagger generator, defining one or more Swagger documents
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "Car API", Version = "v1" });
c.AddSecurityDefinition("Bearer", new ApiKeyScheme { In = "header", Description = "description", Name = "Authorization", Type = "apiKey" });
c.DescribeAllEnumsAsStrings();
});Autorest命令:
autorest --input-file=http://localhost:55448/swagger/v1/swagger.json --csharp --namespace=Online.Integrations.Api.Service.Car --output-folder=. 生成的类(string而不是enum):
public partial class Car
{
/// <summary>
/// Initializes a new instance of the Car class.
/// </summary>
public Car()
{
CustomInit();
}
/// <summary>
/// Initializes a new instance of the Car class.
/// </summary>
/// <param name="application">Possible values include: 'Any', 'Web'
/// ...
/// </param>
public Car(string color = default(string))
{
Color = color;
}
/// <summary>
/// An initialization method that performs custom operations like setting defaults
/// </summary>
partial void CustomInit();
/// <summary>
/// </summary>
[JsonProperty(PropertyName = "color")]
public string Color { get; set; }
}我发现了这个:https://github.com/Azure/autorest/tree/master/docs/extensions#x-ms-enum
有一些x-ms-enum扩展,但我不知道如何使用它。我尝试手动编辑JSON定义(在下面的示例中我所做的),但也没有成功。生成的类包含对象颜色=默认(对象),而不是字符串,如第一个示例所示,而不是枚举。
"color": {
"type": "string",
"enum": [
"Red",
"Blue",
"Green"
],
"x-ms-enum": {
"name": "Color",
"modelAsString": false
},我很乐意提供任何帮助。谢谢!
编辑:1)完全摇摆定义(结果类型: Sting):
昂首阔步。是"type":"string“就在枚举定义之后。
{"swagger":"2.0","info":{"version":"v1","title":"Audit Overseer API"},"basePath":"/","paths":{"/api/Audit":{"get":{"tags":["Audit"],"operationId":"ApiAuditGet","consumes":[],"produces":["text/plain","application/json","text/json"],"parameters":[{"name":"Id","in":"query","required":false,"type":"string"},{"name":"Application","in":"query","required":false,"type":"string","enum":["Any","Alfa","Beta"]},{"name":"DatabaseName","in":"query","required":false,"type":"string"}],"responses":{"200":{"description":"Success","schema":{"type":"array","items":{"$ref":"#/definitions/Transaction"}}}}}}},"definitions":{"Transaction":{"type":"object","properties":{"callId":{"type":"string"},"actionName":{"type":"string"},"application":{"enum":["Any","Alfa","Beta"],"type":"string"},"httpStatusCode":{"type":"string"},"dateTime":{"format":"date-time","type":"string"}}}},"securityDefinitions":{"Bearer":{"name":"Authorization","in":"header","type":"apiKey","description":"Please insert JWT with Bearer into field"}}}自动执行:

结果:

2)完全摇摆定义(结果类型:对象):
装腔作势。我在定义了"x-ms- enum“之后的实验
{"basePath":"/","definitions":{"Transaction":{"properties":{"actionName":{"type":"string"},"application":{"enum":["Any","Alfa","Beta"],"x-ms-enum":{"modelAsString":false,"name":"Application"}},"callId":{"type":"string"},"dateTime":{"format":"date-time","type":"string"},"httpStatusCode":{"type":"string"}},"type":"object"}},"info":{"title":"Audit Overseer API","version":"v1"},"paths":{"/api/Audit":{"get":{"consumes":[],"operationId":"ApiAuditGet","parameters":[{"in":"query","name":"Id","required":false,"type":"string"},{"enum":["Any","Alfa","Beta"],"in":"query","name":"Application","required":false,"type":"string"},{"in":"query","name":"DatabaseName","required":false,"type":"string"}],"produces":["text/plain","application/json","text/json"],"responses":{"200":{"description":"Success","schema":{"items":{"$ref":"#/definitions/Transaction"},"type":"array"}}},"tags":["Audit"]}}},"securityDefinitions":{"Bearer":{"description":"Please insert JWT with Bearer into field","in":"header","name":"Authorization","type":"apiKey"}},"swagger":"2.0"}...or,我可以把它保持为空。结果是一样的
{"basePath":"/","definitions":{"Transaction":{"properties":{"actionName":{"type":"string"},"application":{"enum":["Any","Alfa","Beta"]},"callId":{"type":"string"},"dateTime":{"format":"date-time","type":"string"},"httpStatusCode":{"type":"string"}},"type":"object"}},"info":{"title":"Audit Overseer API","version":"v1"},"paths":{"/api/Audit":{"get":{"consumes":[],"operationId":"ApiAuditGet","parameters":[{"in":"query","name":"Id","required":false,"type":"string"},{"enum":["Any","Alfa","Beta"],"in":"query","name":"Application","required":false,"type":"string"},{"in":"query","name":"DatabaseName","required":false,"type":"string"}],"produces":["text/plain","application/json","text/json"],"responses":{"200":{"description":"Success","schema":{"items":{"$ref":"#/definitions/Transaction"},"type":"array"}}},"tags":["Audit"]}}},"securityDefinitions":{"Bearer":{"description":"Please insert JWT with Bearer into field","in":"header","name":"Authorization","type":"apiKey"}},"swagger":"2.0"}(现在让我们执行与以前相同的自动lets命令)
其结果是:

发布于 2018-03-21 18:02:53
似乎可以让SwaggerGen通过使用SchemaFilter<TFilter>选项方法自动添加x-ms-enum扩展。
Startup.cs中的Swagger注册
// Register the Swagger generator, defining one or more Swagger documents
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "Car API", Version = "v1" });
c.AddSecurityDefinition("Bearer", new ApiKeyScheme { In = "header", Description = "description", Name = "Authorization", Type = "apiKey" });
c.ApplyFiltersToAllSchemas();//ignore deprecation warning
c.SchemaFilter<EnumFilter>();
c.DescribeAllEnumsAsStrings();
});然后用以下代码定义一个EnumFilter类
public class EnumFilter : ISchemaFilter
{
public void Apply(Schema model, SchemaFilterContext context)
{
if (model == null)
throw new ArgumentNullException("model");
if (context == null)
throw new ArgumentNullException("context");
if (context.SystemType.IsEnum)
model.Extensions.Add("x-ms-enum", new
{
name = context.SystemType.Name,
modelAsString = false
});
}
}发布于 2018-10-29 13:35:34
查找了几个小时来为可空枚举找到一个解决方案!
public class EnumFilter : ISchemaFilter
{
public void Apply(Schema model, SchemaRegistry schemaRegistry, Type type)
{
if (model == null)
{
throw new ArgumentNullException("model");
}
if (schemaRegistry == null)
{
throw new ArgumentNullException("schemaRegistry");
}
if (IsEnum(type, out var enumName))
{
model.vendorExtensions.Add("x-ms-enum", new
{
name = enumName ?? type.Name,
modelAsString = false
});
}
}
public static bool IsEnum(Type t, out string enumName)
{
if (t.IsEnum)
{
enumName = t.Name;
return true;
}
Type u = Nullable.GetUnderlyingType(t);
enumName = u?.Name;
return (u != null) && u.IsEnum;
}
}发布于 2019-07-09 05:37:48
未来的打样解决方案,进一步到@richard解决方案,一旦杰出的自动回购中的枚举值问题被修复,下面是EnumFilter:ISchemaFilter的enum部分的值
Startup.cs中的Swagger注册
// Register the Swagger generator, defining one or more Swagger documents
services.AddSwaggerGen(c =>
{
c.SwaggerDoc("v1", new Info { Title = "Car API", Version = "v1" });
c.AddSecurityDefinition("Bearer", new ApiKeyScheme { In = "header", Description = "description", Name = "Authorization", Type = "apiKey" });
c.ApplyFiltersToAllSchemas();//ignore deprecation warning
c.SchemaFilter(() => new EnumTypeSchemaFilter(false));
c.DescribeAllEnumsAsStrings();
});然后用以下代码定义一个EnumFilter类:
using Swashbuckle.Swagger;
using System;
namespace Swashbuckle.AutoRestExtensions
{
public class EnumTypeSchemaFilter : ISchemaFilter
{
public EnumTypeSchemaFilter()
{
}
public EnumTypeSchemaFilter(bool modelAsString)
{
_modelAsString = modelAsString;
}
public void Apply(Schema schema, SchemaRegistry schemaRegistry, Type type)
{
type = Nullable.GetUnderlyingType(type) ?? type;
System.Diagnostics.Debug.WriteLine(type.FullName);
if (type.IsEnum)
{
// Add enum type information once
if (schema.vendorExtensions.ContainsKey("x-ms-enum")) return;
if (_modelAsString)
{
schema.vendorExtensions.Add("x-ms-enum", new
{
name = type.Name,
modelAsString = _modelAsString
});
}
else
{
var valuesList = new System.Collections.Generic.List<object>();
foreach (var fieldInfo in type.GetFields())
{
if (fieldInfo.FieldType.IsEnum)
{
var fName = fieldInfo.Name;
var fValue = (int)fieldInfo.GetRawConstantValue();
valuesList.Add(new { value = fValue, description = fName, name = fName });
}
}
schema.vendorExtensions.Add("x-ms-enum", new
{
name = type.Name,
modelAsString = _modelAsString,
values = valuesList
//Values:
/*
accountType:
type: string
enum:
- Standard_LRS
- Standard_ZRS
- Standard_GRS
- Standard_RAGRS
- Premium_LRS
x-ms-enum:
name: AccountType
modelAsString: false
values:
- value: Standard_LRS
description: Locally redundant storage.
name: StandardLocalRedundancy
- value: Standard_ZRS
description: Zone-redundant storage.
- value: Standard_GRS
name: StandardGeoRedundancy
- value: Standard_RAGRS
- value: Premium_LRS
*/
});
}
}
}
private readonly bool _modelAsString;
}
}https://stackoverflow.com/questions/46237442
复制相似问题