amiya 0.0.6

experimental middleware-based minimalism async HTTP server framework
Documentation
mod common;

use {
    amiya::{m, middleware::Router},
    common::response,
};

fn main() {
    #[rustfmt::skip]
    let app = amiya::new().uses(Router::new()
        // `at` let you set the handler when exact meets the path,
        // `get` let you limit this path only accept get request and set the handler
        // `done` finish router setting for "/api/v1/hello"
        .at("api/v1/hello").get(m!(ctx => response("Call version 1 hello API\n", ctx).await)).done()
        .at("static")
            // As above, we give request to exact "/static" a clear response message that 
            // we do support list dir content
            .get(m!(ctx => response("We do not allow list dir\n", ctx).await))
            // but we not finish this setting here, a call to `fallback` let you set the
            // handler of all other request just except exact match
            // `get` limit we only support get method for static files
            //
            // the `ctx.path()` here will return path after `/static`, for example:
            // response of request GET "/static/sub/folder/a.png"
            // will be "Get file /sub/folder/a.png"
            .fallback().get(m!(ctx => response(format!("Get file {}\n", ctx.path()), ctx).await))
            // and we finish "/static" router setting
            .done());

    app.listen("[::]:8080").unwrap();

    std::thread::park();
}