Utilbox.Response
2.1.0
dotnet add package Utilbox.Response --version 2.1.0
NuGet\Install-Package Utilbox.Response -Version 2.1.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Utilbox.Response" Version="2.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Utilbox.Response" Version="2.1.0" />
<PackageReference Include="Utilbox.Response" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Utilbox.Response --version 2.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Utilbox.Response, 2.1.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Utilbox.Response@2.1.0
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Utilbox.Response&version=2.1.0
#tool nuget:?package=Utilbox.Response&version=2.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Utilbox.Response
A standardized response library for building consistent RESTful APIs in .NET applications, providing a unified way to handle API responses, validation errors, and pagination metadata.
Features
ApiResponse<T>
- Standardized response structure with:
- Success/failure status
- HTTP status code
- Generic data payload
- Error message
- Validation errors
- Custom metadata
- Timestamp
- Request ID
- Factory methods for common scenarios:
- Success responses
- Error responses
- Validation error responses
- Metadata management:
- Add custom metadata
- Add pagination metadata
- JSON serialization support
OperationValidationError
- Field-level validation error representation
- Error message and code support
- Multiple validation errors handling
- Custom validation error types
PaginationMetadata
- Total items count
- Page size configuration
- Current page tracking
- Total pages calculation
- Previous/next page indicators
Installation
Package Manager Console
Install-Package Utilbox.Response
.NET CLI
dotnet add package Utilbox.Response
Usage Examples
Basic API Response
// Success response
var successResponse = ApiResponse<User>.CreateSuccess(
data: user,
statusCode: HttpStatusCode.OK,
requestId: "req-123"
);
// Error response
var errorResponse = ApiResponse<User>.CreateError(
errorMessage: "User not found",
statusCode: HttpStatusCode.NotFound,
requestId: "req-123"
);
// Validation error response
var validationErrors = new List<OperationValidationError>
{
new("Email", "Invalid email format", "INVALID_EMAIL"),
new("Password", "Password too short", "PASSWORD_TOO_SHORT")
};
var validationResponse = ApiResponse<User>.CreateValidationError(
validationErrors: validationErrors,
errorMessage: "Validation failed",
statusCode: HttpStatusCode.BadRequest,
requestId: "req-123"
);
Adding Metadata
// Add custom metadata
var response = ApiResponse<User>.CreateSuccess(user)
.AddMetadata("ProcessingTime", 150)
.AddMetadata("ServerName", "API-01");
// Add pagination metadata
var response = ApiResponse<List<User>>.CreateSuccess(users)
.AddPaginationMetadata(
totalItems: 100,
pageSize: 10,
currentPage: 1,
totalPages: 10
);
Using PaginationMetadata
var metadata = new PaginationMetadata
{
TotalItems = 100,
PageSize = 10,
CurrentPage = 1,
TotalPages = 10
};
// Check navigation
bool hasNext = metadata.HasNext; // true
bool hasPrevious = metadata.HasPrevious; // false
Requirements
- .NET Standard 2.0 or higher
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- System.ComponentModel.Annotations (>= 5.0.0)
- System.Runtime (>= 4.3.1)
- System.Text.Json (>= 9.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.