ripress 2.5.1

An Express.js-inspired web framework for Rust
Documentation
/// A macro for convenient construction of middleware vectors (`Middlewares`).
///
/// # Usage
///
/// The `middlewares!` macro simplifies the creation of middleware lists by allowing you to specify
/// route patterns and corresponding middleware closures in a concise and readable way.
///
/// Each element is a tuple in the form: `("/path", |req: HttpRequest, res| { ... })`.
///
/// # Example
///
/// ```rust
/// use ripress::{app::App, types::Middlewares, middlewares, req::HttpRequest};
/// let pre_middlewares: Middlewares = middlewares![
///     ("/", |req: HttpRequest, res, next| Box::pin(async move { return next.call(req, res).await; })),
///     ("/admin", |req: HttpRequest, res, next| Box::pin(async move { return next.call(req, res).await; })),
/// ];
/// ```
///
/// # Output
///
/// Expands into a `Vec<(&'static str, Box<dyn Fn(...) -> ...>)>` ready for
/// use with `App::use_pre_middlewares()` or `App::use_post_middlewares()`.
#[macro_export]
macro_rules! middlewares {
    ( $( ($path:expr, $handler:expr) ),* $(,)? ) => {
        {
            let mut vec: $crate::types::Middlewares = Vec::new();
            $(
                vec.push((
                    $path,
                    Box::new($handler)
                ));
            )*
            vec
        }
    };
}

#[doc(inline)]
pub use ripress_derive::{FromData, FromJson, FromParams, FromQueryParam};