-
-
Notifications
You must be signed in to change notification settings - Fork 165
Expand file tree
/
Copy pathIApplicationBuilderExtensions.cs
More file actions
66 lines (56 loc) · 2.27 KB
/
Copy pathIApplicationBuilderExtensions.cs
File metadata and controls
66 lines (56 loc) · 2.27 KB
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
using JsonApiDotNetCore.Builders;
using JsonApiDotNetCore.Configuration;
using JsonApiDotNetCore.Internal;
using JsonApiDotNetCore.Internal.Contracts;
using JsonApiDotNetCore.Middleware;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.AspNetCore.Internal;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
namespace JsonApiDotNetCore.Extensions
{
// ReSharper disable once InconsistentNaming
public static class IApplicationBuilderExtensions
{
public static IApplicationBuilder UseJsonApi(this IApplicationBuilder app, bool useMvc = true)
{
DisableDetailedErrorsIfProduction(app);
LogResourceGraphValidations(app);
app.UseEndpointRouting();
app.UseMiddleware<CurrentRequestMiddleware>();
if (useMvc)
app.UseMvc();
using (var scope = app.ApplicationServices.CreateScope())
{
var inverseRelationshipResolver = scope.ServiceProvider.GetService<IInverseRelationships>();
inverseRelationshipResolver?.Resolve();
}
return app;
}
private static void DisableDetailedErrorsIfProduction(IApplicationBuilder app)
{
var environment = (IHostingEnvironment)app.ApplicationServices.GetService(typeof(IHostingEnvironment));
if (environment.IsProduction())
{
JsonApiOptions.DisableErrorStackTraces = true;
JsonApiOptions.DisableErrorSource = true;
}
}
private static void LogResourceGraphValidations(IApplicationBuilder app)
{
var logger = app.ApplicationServices.GetService(typeof(ILogger<ResourceGraphBuilder>)) as ILogger;
var resourceGraph = app.ApplicationServices.GetService(typeof(IResourceGraph)) as ResourceGraph;
if (logger != null && resourceGraph != null)
{
resourceGraph.ValidationResults.ForEach((v) =>
logger.Log(
v.LogLevel,
new EventId(),
v.Message,
exception: null,
formatter: (m, e) => m));
}
}
}
}