Crate anyhow_http

source ·
Expand description

anyhow-http offers customizable HTTP errors built on anyhow errors.

This crates acts as a superset of anyhow, extending the functionality to define custom HTTP error responses.

§Example with axum

use axum::{
   routing::get,
   response::IntoResponse,
   Router,
};
use anyhow_http::{http_error_ret, response::Result};

#[tokio::main]
async fn main() {
    let app = Router::new()
        .route("/", get(handler));

    let listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
        .await
        .unwrap();
    axum::serve(listener, app).await.unwrap();
}

fn fallible_operation() -> Result<()> {
    http_error_ret!(INTERNAL_SERVER_ERROR, "this is an error")
}

async fn handler() -> Result<impl IntoResponse> {
    fallible_operation()?;
    Ok(())
}

Re-exports§

Modules§

Macros§

  • Construct an ad-hoc HttpError from a status code, optional source error and formatted reason.
  • Shorthand macro to return early with a HttpError.

Structs§

Traits§