1 unstable release
0.1.0 | Jan 8, 2025 |
---|
#1333 in Web programming
125 downloads per month
18KB
280 lines
Problem Details Mapper
The Problem Details Mapper is a library designed to simplify error handling and response generation in Rust-based RESTful API applications. It allows you to map errors to Problem Details as defined by the RFC 7807 specification, enabling consistent and standardized error responses across your API.
Features
- Error Mapping: Easily map Rust errors to Problem Details objects, providing detailed information about encountered errors.
- RFC 7807 Compliance: Ensures that error responses adhere to the RFC 7807 standard, promoting interoperability and consistency in API responses. Provided by the ProblemDetails crate.
- Customizable: Customize the Problem Details response format and content to suit the requirements of your application.
- Extensible: Extend functionality with custom error types and mappings tailored to your application's needs.
Getting Started
To integrate the Rust Problem Details Mapper into your project, add the following line to your Cargo.toml file:
[dependencies]
problem-details-mapper = "0.1.0"
Then, import the library into your Rust code:
use problem_details_mapper::{
IntoProblemDetails,
ProblemDetails,
ProblemDetailsBuilder,
ProblemDetailsMapper
};
Usage
Here's a simple example demonstrating how to use the Problem Details Mapper:
use problem_details_mapper::{
IntoProblemDetails,
ProblemDetails,
ProblemDetailsBuilder,
ProblemDetailsMapper
};
#[derive(Debug)]
struct TestError;
impl TestError {
pub fn new() -> Self {
Self
}
}
impl std::fmt::Display for TestError {
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
write!(f, "")
}
}
impl std::error::Error for TestError {}
impl IntoProblemDetails for TestError {
fn into_problemdetails(&self) -> ProblemDetails {
ProblemDetailsBuilder::build_bad_request(
Some("test"),
None::<String>)
}
}
fn main() {
// Setup the mapper settings
ProblemDetailsMapper::setup(|options| {
// will map every error given to a http status code 500.
options.map_std_err();
// will register the test error its own mapping
// provided by IntoProblemDetails.
options.map::<TestError>();
});
// Map an error to a Problem Details response
let error = TestError::new();
let problem_details = ProblemDetailsMapper::map(Box::new(error));
// Output the Problem Details response
println!("{:?}", problem_details);
}
Examples
Examples demonstrating how to use the Problem Details Mapper library can be found in the examples
folder of the repository. Below are some examples showcasing various usage scenarios:
- Basic Usage: Demonstrates the basic usage of the library, mapping a standard Rust error to a Problem Details response.
- Custom Error Types: Illustrates how to define and map custom error types to Problem Details responses.
Feel free to explore these examples for a better understanding of how to integrate and utilize the Rust Problem Details Mapper in your projects.
Contributing
Contributions to the Problem Details Mapper are welcome! If you encounter any issues, have ideas for improvements, or would like to contribute new features, please feel free to open an issue or submit a pull request on the repository.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Inspired by Hellang.Middleware.ProblemDetails nuget package for C# for Problem Details Mapping in ASP.net HTTP APIs.
Dependencies
~0.9–1.6MB
~32K SLoC