Comments (7)
Basic usage would then involve 2 lines of code instead of 1.
public void ConfigureServices(IServiceCollection services)
{
services.AddProblemDetails();
}
public void Configure(IApplicationBuilder app)
{
services.UseProblemDetails();
}
Although it might be possible to detect when no call to AddProblemDetails
was made and fallback to the old behavior with Options.Create(0.
from middleware.
Yeah, I've gone back and forth on this. I thought about doing it, but I don't see any big advantage over the current solution. It's just more code (an extra call to services.AddProblemDetails()
) to write, and the middleware doesn't really need to add any services. Want to convince me otherwise? 👼
from middleware.
Although it might be possible to detect when no call to
AddProblemDetails
was made and fallback to the old behavior with Options.Create(0.
I do this with the SpaFallback middleware;
Middleware/src/SpaFallback/SpaFallbackExtensions.cs
Lines 49 to 50 in d38a176
Middleware/src/SpaFallback/SpaFallbackExtensions.cs
Lines 65 to 76 in d38a176
But it seems like it's a lot of hassle for no benefit, because the middleware really doesn't need any services injected (I don't view options as a "service").
from middleware.
My issue started with the desire to have my problem configuration in a separate file.
First I created a static class for it.
public static class ProblemConfigurer
{
public static void Configure(ProblemDetailsOptions options)
{
...
}
}
// usage
public void Configure(IApplicationBuilder app)
{
services.UseProblemDetails(ProblemConfigurer.Configure);
}
Then I quickly realized that I need my own dependencies inside ProblemConfigurer. It's impossible to do that via DI since it's a static class. There is a workaround, but the code is not very pleasant.
// DI workaround
public void Configure(IApplicationBuilder app, IService1 dep1, IService2 dep2)
{
services.UseProblemDetails(options => ProblemConfigurer.Configure(options, dep1, dep2));
}
Ultimately I'd like to convert my ProblemConfigurer to non-static and register it with DI so I can just have seamless dependency injection.
The benefit for me is being able to have a separate class that implements IConfigureOptions<ProblemDetailsOptions>
and have the DI framework inject dependencies without having to write additional code.
from middleware.
Hmm. I guess I could find a way to support both, without breaking people. I.e. you won't have to call AddProblemDetails
, but you could if you want to use DI for configuration.
from middleware.
Pushed v2.1.1. Allowed myself to make a tiny breaking change by obsoleting the old UseProblemDetails
method since literally no one has downloaded the 2.0.0 package yet 😝
from middleware.
Works great, thanks!
from middleware.
Related Issues (20)
- Disable ProblemDetailsResultFilter with condition like UseWhen (middleware) to support backwards compatibility HOT 1
- Does not work in .net 6 HOT 8
- How to show (AddProblemDetails) multiple validation error against single property using Fluent Validation & MediatR Pipeline Behaviour HOT 3
- `MapStatusCode` not respected for MVC validation errors HOT 1
- How can I use UseMemberCasing to serialize my data
- Ambiguous invocation in .Net 7 HOT 3
- Customize Exception Logging
- How to disable developer exception page middleware? HOT 3
- Issue with Serilog's RequestLogging and Rethrow HOT 8
- Changes in ASP.NET Core v7 HOT 3
- Master Branch not building in VS 2022 HOT 8
- ProblemDetailsMiddleware and DiagnosticListener.Write for handled exceptions
- [Feature request] ProblemDetails middleware allow send Detail property out of the box in Production HOT 2
- How to customise the ProblemDetails object when capturing FluentValidation exceptions? HOT 5
- Why are headers cleared at all by the middleware?
- ProblemDetails "Instance" property is not being set HOT 13
- How can I avoid returning internal class information in error?
- AddNewtonsoftJson and ProblemDetails using NET 6 HOT 1
- Add .NET 8 support for Authentication.JwtBearer.Google HOT 1
- [Feature request] Use custom mappers inside ProblemDetailsResultFilter
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from middleware.