#routes #axum #enums #router #resolve #path #customize

macro axum-routes-macros

Create an axum Router from an enum and resolve routes

3 unstable releases

0.2.0 Jan 9, 2025
0.1.1 Oct 16, 2024
0.1.0 Oct 13, 2024

#1821 in Procedural macros

Download history 159/week @ 2024-10-09 187/week @ 2024-10-16 4/week @ 2024-10-23 10/week @ 2024-10-30 13/week @ 2024-11-06 1/week @ 2024-11-13 1/week @ 2024-11-20 1/week @ 2024-12-04 4/week @ 2024-12-11 142/week @ 2025-01-08

142 downloads per month
Used in axum-routes

MIT license

34KB
686 lines

axum-routes

axum-routes is a crate on top of axum to declare routers through enums, and resolve easily routes, so we don't have to hardcode routes when linking in web apps.

Crates.io Documentation

Features

  • Declare your axum::Router using enums
  • Customize routes/nested routers (layers, with_state, fallback, ...)
  • Resolve links using the enum, removing the need to hardcode

Example

use axum::{extract::Path, Json};
use axum_routes::routes;
use http::StatusCode;
use serde_json::{json, Value};
use tower::ServiceBuilder;
use tower_http::trace::TraceLayer;

#[routes]
enum MyApp {
    #[nest("/api", customize = custom_api)]
    Api(APIRoutes),
    #[get("/", handler = home)]
    Home,
    #[get("/about", handler = about)]
    About,
}

#[routes]
enum APIRoutes {
    #[get("/users/:id", handler = get_users_by_id)]
    GetUsersByID,
    #[post("/users", handler = create_user)]
    CreateUser,
}

// ----------------------------------------------------------------------------
// Handlers

async fn home() -> &'static str {
    "Hello world!"
}
async fn about() {}
async fn get_users_by_id(Path(_user_id): Path<u32>) {}
async fn create_user(Json(_payload): Json<Value>) -> (StatusCode, Json<Value>) {
    (StatusCode::CREATED, Json(json!({"status": "ok"})))
}

// ----------------------------------------------------------------------------

#[tokio::main]
async fn main() {
    let trace_layer = ServiceBuilder::new().layer(TraceLayer::new_for_http());
    let app = axum_routes::router!(MyApp,
        custom_api = #move |route| {
            route.layer(trace_layer.clone())
        },
    );

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

Contributing

See a bug ? An improvement ? A new feature you want ? Feel free to open an issue, or even a PR.

This project is not affiliated with axum at all.

Dependencies

~1.6–2.3MB
~41K SLoC