DrUalcman.Exceptions.Extensions
1.0.5
See the version list below for details.
dotnet add package DrUalcman.Exceptions.Extensions --version 1.0.5
NuGet\Install-Package DrUalcman.Exceptions.Extensions -Version 1.0.5
<PackageReference Include="DrUalcman.Exceptions.Extensions" Version="1.0.5" />
paket add DrUalcman.Exceptions.Extensions --version 1.0.5
#r "nuget: DrUalcman.Exceptions.Extensions, 1.0.5"
// Install DrUalcman.Exceptions.Extensions as a Cake Addin #addin nuget:?package=DrUalcman.Exceptions.Extensions&version=1.0.5 // Install DrUalcman.Exceptions.Extensions as a Cake Tool #tool nuget:?package=DrUalcman.Exceptions.Extensions&version=1.0.5
DrUalcman.Exceptions
Manage 3 most common exceptions with a default handler using clean architecture. Can be used in any kind of project. Always return a ProblemDetails following the standart rfc7807.
NuGet installation
PM> Install-Package DrUalcman.Exceptions
How to use
PM> IExceptionHandler<ExceptionType>
Implement interface in the handlers for the exception. Then inject in the ServiceContainer
services.AddSingleton<IExceptionPresenter, ExceptionPresenter>();
Extensions
PM> Install-Package DrUalcman.Exceptions.Extensions
Also can add DrUalcman.Exception.Extension. This DLL only have a dependecy containder extension method to simplify the injection.
services.AddExceptionsHandlerPresenter()
or services.AddExceptionsHandlerPresenter([Assembly])
HttpResponseMessage
We have now a estension method for HttpResponseMessage, return a ProblemDetailsException
to ensure have this exception fromated returned.
using HttpResponseMessage response = HttpCliente.GetAsync("endpoint");
response.EnsureSuccessCode();
return response;
This return a ProblemDetailException
if the transaction is not Success. If the conent response is formated with a ProblemDetail
parse correctly all the data.
MiddleWare
PM> Install-Package DrUalcman.Exceptions.MiddleWare
Also can add DrUalcman.Exceptions.MiddleWare. This DLL have the methods to add like a MiddleWare.
/// when build
builder.Services.AddExceptionsHandlerPresenter(ExceptionHandlersAssemblyHelper.Assembly);
/// before run
app.UseExceptionHandler(builder =>
builder.UseExceptionHandlerPresenter(
app.Environment,
app.Services.GetService<IExceptionPresenter>()));
ExceptionView for Blazor
PM> Install-Package DrUalcman.Exceptions.BlazorWebAssembly.View
Basic
<ExceptionView>
@Body
</ExceptionView>
Personalize text button
<ExceptionView ButtonText="<span class='oi oi-home'></span> OK">
@Body
</ExceptionView>
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- DrUalcman.Exceptions (>= 1.0.3)
- Microsoft.Extensions.DependencyInjection (>= 6.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on DrUalcman.Exceptions.Extensions:
Package | Downloads |
---|---|
DrUalcman.Exceptions.MiddleWare
Add easy a middleware to DrUalcman.Exceptions |
GitHub repositories
This package is not used by any popular GitHub repositories.
Fix a bug when the exception is not from DrUalcman.Exceptions.ProblemsDetailsException because is from ApiController ValidationException (for example) then don't show the correct invalidParamDetails. Add method EnsureSuccessCodeAsync() if want to use async actions