/
AnnotationsSwaggerGenOptionsExtensions.cs
123 lines (104 loc) · 4.45 KB
/
AnnotationsSwaggerGenOptionsExtensions.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
using System;
using System.Collections.Generic;
using System.Linq;
using Swashbuckle.AspNetCore.SwaggerGen;
using Swashbuckle.AspNetCore.Annotations;
namespace Microsoft.Extensions.DependencyInjection
{
public static class AnnotationsSwaggerGenOptionsExtensions
{
/// <summary>
/// Enables Swagger annotations (SwaggerOperationAttribute, SwaggerParameterAttribute etc.)
/// </summary>
/// <param name="options"></param>
/// <param name="enableAnnotationsForInheritance">Enables SwaggerSubType attribute for inheritance</param>
/// <param name="enableAnnotationsForPolymorphism">Enables SwaggerSubType and SwaggerDiscriminator attributes for polymorphism</param>
public static void EnableAnnotations(
this SwaggerGenOptions options,
bool enableAnnotationsForInheritance,
bool enableAnnotationsForPolymorphism)
{
options.SchemaFilter<AnnotationsSchemaFilter>();
options.ParameterFilter<AnnotationsParameterFilter>();
options.RequestBodyFilter<AnnotationsRequestBodyFilter>();
options.OperationFilter<AnnotationsOperationFilter>();
options.DocumentFilter<AnnotationsDocumentFilter>();
if (enableAnnotationsForInheritance || enableAnnotationsForPolymorphism)
{
options.SelectSubTypesUsing(AnnotationsSubTypesSelector);
options.SelectDiscriminatorNameUsing(AnnotationsDiscriminatorNameSelector);
options.SelectDiscriminatorValueUsing(AnnotationsDiscriminatorValueSelector);
if (enableAnnotationsForInheritance)
{
options.UseAllOfForInheritance();
}
if (enableAnnotationsForPolymorphism)
{
options.UseOneOfForPolymorphism();
}
}
}
/// <summary>
/// Enables Swagger annotations (SwaggerOperationAttribute, SwaggerParameterAttribute etc.)
/// </summary>
/// <param name="options"></param>
public static void EnableAnnotations(this SwaggerGenOptions options)
{
options.EnableAnnotations(
enableAnnotationsForPolymorphism: false,
enableAnnotationsForInheritance: false);
}
private static IEnumerable<Type> AnnotationsSubTypesSelector(Type type)
{
var subTypeAttributes = type.GetCustomAttributes(false)
.OfType<SwaggerSubTypeAttribute>();
if (subTypeAttributes.Any())
{
return subTypeAttributes.Select(attr => attr.SubType);
}
#pragma warning disable CS0618 // Type or member is obsolete
var obsoleteAttribute = type.GetCustomAttributes(false)
.OfType<SwaggerSubTypesAttribute>()
.FirstOrDefault();
#pragma warning restore CS0618 // Type or member is obsolete
if (obsoleteAttribute != null)
{
return obsoleteAttribute.SubTypes;
}
return Enumerable.Empty<Type>();
}
private static string AnnotationsDiscriminatorNameSelector(Type baseType)
{
var discriminatorAttribute = baseType.GetCustomAttributes(false)
.OfType<SwaggerDiscriminatorAttribute>()
.FirstOrDefault();
if (discriminatorAttribute != null)
{
return discriminatorAttribute.PropertyName;
}
#pragma warning disable CS0618 // Type or member is obsolete
var obsoleteAttribute = baseType.GetCustomAttributes(false)
.OfType<SwaggerSubTypesAttribute>()
.FirstOrDefault();
#pragma warning restore CS0618 // Type or member is obsolete
if (obsoleteAttribute != null)
{
return obsoleteAttribute.Discriminator;
}
return null;
}
private static string AnnotationsDiscriminatorValueSelector(Type subType)
{
if (subType.BaseType == null)
return null;
var subTypeAttribute = subType.BaseType.GetCustomAttributes(false)
.OfType<SwaggerSubTypeAttribute>()
.FirstOrDefault(attr => attr.SubType == subType);
if (subTypeAttribute != null)
{
return subTypeAttribute.DiscriminatorValue;
}
return null;
}
}
}