Pandatech.ResponseCrafter
3.0.0
See the version list below for details.
dotnet add package Pandatech.ResponseCrafter --version 3.0.0
NuGet\Install-Package Pandatech.ResponseCrafter -Version 3.0.0
<PackageReference Include="Pandatech.ResponseCrafter" Version="3.0.0" />
paket add Pandatech.ResponseCrafter --version 3.0.0
#r "nuget: Pandatech.ResponseCrafter, 3.0.0"
// Install Pandatech.ResponseCrafter as a Cake Addin #addin nuget:?package=Pandatech.ResponseCrafter&version=3.0.0 // Install Pandatech.ResponseCrafter as a Cake Tool #tool nuget:?package=Pandatech.ResponseCrafter&version=3.0.0
Pandatech.ResponseCrafter
Introduction
Pandatech.ResponseCrafter is a comprehensive NuGet package for .NET 8+, specifically designed to enhance exception handling and logging in ASP.NET Core applications. This package simplifies managing standard and custom exceptions by crafting detailed error responses suitable for both development and production environments.
Features
- Custom Exception Handling: Streamlines the process of managing both standard HTTP exceptions and custom exceptions.
- Detailed Error Responses: Generates verbose error messages, including stack traces for in-depth debugging in development environments.
- Environment-Sensitive Logging: Provides flexible logging and response behavior based on visibility
settings (
Public
orPrivate
):- Private: All exceptions are sent to the client as defined, and 4xx errors are logged as warnings while 5xx errors are logged as errors.
- Public: 4xx exceptions are sent to the client as defined, while 5xx errors are concealed with a generic
message. Logging remains the same as in
Private
.
- Frontend-Friendly Error Messages: Supports converting error messages to your desired case convention, facilitating easier integration with frontend localization systems.
- Standardized Error Responses: Provides a standardized error response format, making it easier for frontend applications to parse and display error messages. The error response format is shown below:
{
"TraceId": "0HMVFE0A284AM:00000001",
"Instance": "POST - 164.54.144.23:443/users/register",
"StatusCode": 400,
"Type": "BadRequestException",
"Errors": {
"email": "email_address_is_not_in_a_valid_format",
"password": "password_must_be_at_least_8_characters_long"
},
"Message": "the_request_was_invalid_or_cannot_be_otherwise_served."
}
Installation
Install the package via NuGet Package Manager or use the following command:
Install-Package ResponseCrafter
Usage
1. Setup Exception Handlers:
Add AddResponseCrafter
in program.cs
bby providing an optional naming convention, and
configure ResponseCrafterVisibility
in your settings.
var builder = WebApplication.CreateBuilder(args);
// Basic setup
builder.AddResponseCrafter();
// Setup with a specific naming convention
builder.AddResponseCrafter(NamingConvention.ToSnakeCase);
var app = builder.Build();
app.UseResponseCrafter();
app.Run();
Configure visibility in your appsettings.json
:
{
"ResponseCrafterVisibility": "Public"
}
Supported naming conventions:
public enum NamingConvention
{
Default = 0,
ToSnakeCase = 1,
ToPascalCase = 2,
ToCamelCase = 3,
ToKebabCase = 4,
ToTitleCase = 5,
ToHumanCase = 6
}
2. Define Custom Exceptions:
Create custom exception classes that inherit from ApiException
or use the predefined ones. Use ErrorDetails
records
for
specific error messages related to API requests.
3. Configure Middleware:
- Implement the exception handling middleware in your application's pipeline.
app.UseResponseCrafter();
4. Logging and Error Responses:
The package automatically logs warnings or errors and provides crafted responses based on the exception type.
Custom HTTP Exception Already Created
BadRequestException
UnauthorizedException
PaymentRequiredException
ForbiddenException
NotFoundException
ConflictException
TooManyRequestsException
InternalServerErrorException
ServiceUnavailableException
Custom Exception Helper Methods
Using exception helpers:
decimal? price = -10.5m;
//For 400 Bad Request
BadRequestException.ThrowIfNullOrNegative(price, "Price is negative");
//For 500 Internal Server Error
InternalServerErrorException.ThrowIfNullOrNegative(price, "Price is negative");
string? username = " ";
//For 400 Bad Request
BadRequestException.ThrowIfNullOrWhiteSpace(username, "Please provide username");
//For 404 Not Found
NotFoundException.ThrowIfNullOrWhiteSpace(username);
//For 500 Internal Server Error
InternalServerErrorException.ThrowIfNullOrWhiteSpace(username, "Price is negative");
List<int> tags = [];
//For 400 Bad Request
BadRequestException.ThrowIfNullOrEmpty(tags, "Please provide tags");
//For 404 Not Found
NotFoundException.ThrowIfNullOrEmpty(tags);
//For 500 Internal Server Error
InternalServerErrorException.ThrowIfNullOrEmpty(tags, "Please provide tags");
object? user = null;
//For 400 Bad Request
BadRequestException.ThrowIfNull(user, "Please provide user");
//For 404 Not Found
NotFoundException.ThrowIfNull(user, "Please provide user");
//For 500 Internal Server Error
InternalServerErrorException.ThrowIfNull(user, "Please provide user");
bool userUnauthorized = false;
//For 401 Unauthorized
UnauthorizedException.ThrowIf(userUnauthorized, "User is unauthorized");
//For 500 Internal Server Error
InternalServerErrorException.ThrowIf(userUnauthorized, "User is unauthorized");
These examples show how to use the ThrowIfNullOrNegative
, ThrowIfNullOrWhiteSpace
, ThrowIfNullOrEmpty
and ThrowIfNull
helper methods
from BadRequestException
, InternalServerErrorException
and NotFoundException
. Adjust the object names and values according to your specific
application needs.
Recommendations
- Error Message Formatting: It's recommended to use snake_case for error messages to aid frontend applications in implementing localization.
Limitations
- This package is specifically tailored for .NET 8 and above.
License
Pandatech.ResponseCrafter is licensed under the MIT License.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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. |
-
net8.0
- Humanizer (>= 2.14.1)
- Microsoft.AspNetCore.OpenApi (>= 8.0.7)
- PandaTech.FluentImporter (>= 2.0.12)
- Pandatech.GridifyExtensions (>= 1.5.1)
- PandaTech.ServiceResponse (>= 1.2.12)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Pandatech.ResponseCrafter:
Package | Downloads |
---|---|
Pandatech.SharedKernel
Pandatech.SharedKernel provides centralized configurations, utilities, and extensions for ASP.NET Core projects. For more information refere to readme.md document. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
5.1.3 | 100 | 12/18/2024 |
5.1.2 | 87 | 12/17/2024 |
5.1.1 | 114 | 12/13/2024 |
5.1.0 | 87 | 12/11/2024 |
5.0.3 | 105 | 11/28/2024 |
5.0.2 | 122 | 11/23/2024 |
5.0.1 | 121 | 11/21/2024 |
5.0.0 | 91 | 11/21/2024 |
4.0.1 | 119 | 11/11/2024 |
4.0.0 | 108 | 10/4/2024 |
3.0.1 | 143 | 9/11/2024 |
3.0.0 | 122 | 7/18/2024 |
2.2.2 | 123 | 6/29/2024 |
2.2.1 | 124 | 6/29/2024 |
2.2.0 | 125 | 6/27/2024 |
2.1.4 | 125 | 6/27/2024 |
2.1.3 | 155 | 6/22/2024 |
2.1.2 | 102 | 6/22/2024 |
2.1.1 | 110 | 6/22/2024 |
2.1.0 | 108 | 6/22/2024 |
2.0.0 | 118 | 6/13/2024 |
1.7.0 | 105 | 6/13/2024 |
1.6.3 | 111 | 6/9/2024 |
1.6.2 | 115 | 6/6/2024 |
1.6.1 | 135 | 6/2/2024 |
1.5.1 | 123 | 5/28/2024 |
1.5.0 | 124 | 5/26/2024 |
1.4.14 | 128 | 5/24/2024 |
1.4.13 | 110 | 5/24/2024 |
1.4.12 | 119 | 5/17/2024 |
1.4.10 | 135 | 5/8/2024 |
1.4.9 | 142 | 5/7/2024 |
1.4.8 | 119 | 5/6/2024 |
1.4.7 | 131 | 5/5/2024 |
1.4.6 | 90 | 5/3/2024 |
1.4.5 | 127 | 4/24/2024 |
1.4.4 | 122 | 4/24/2024 |
1.4.3 | 120 | 4/24/2024 |
1.4.2 | 118 | 4/23/2024 |
1.4.1 | 139 | 4/16/2024 |
1.4.0 | 128 | 4/16/2024 |
1.3.0 | 117 | 4/16/2024 |
1.2.1 | 149 | 4/3/2024 |
1.2.0 | 153 | 4/2/2024 |
1.1.0 | 182 | 3/22/2024 |
1.0.4 | 407 | 12/14/2023 |
1.0.3 | 164 | 11/29/2023 |
1.0.2 | 152 | 11/29/2023 |
1.0.1 | 142 | 11/28/2023 |
1.0.0 | 163 | 11/28/2023 |
Removed base36 support and added new extension methods on errors