#url-path #path-query #routes #structs #deserialize #query-string #applications

app_route_derive

一个过程宏,允许将URL路径+查询参数自动反序列化为Rust结构体

5个不稳定版本

0.3.0 2019年6月16日
0.2.1 2019年5月8日
0.2.0 2019年5月8日
0.1.1 2019年5月7日
0.1.0 2019年4月26日

#12 in #path-query


app_route 中使用

MIT 许可证

15KB
361

AppRoute

将应用程序路由(URL路径+查询字符串)视为强类型Rust结构体

依赖项

  • cargo
  • rustc

构建

$ cargo build

测试

$ cargo test

基准测试

$ cargo bench

示例代码

src/Cargo.toml

[dependencies]
app_route = "0.1"
serde = { version = "1.0", features = ["derive"] }

main.rs

use app_route::AppRoute;
use serde::{Deserialize, Serialize};

#[derive(Debug, Serialize, Deserialize, PartialEq)]
struct UserListQuery {
    limit: Option<u64>,
    offset: Option<u64>,
    keyword: Option<String>,

    #[serde(default)]
    friends_only: bool,
}

#[derive(AppRoute, Debug, PartialEq)]
#[route("/groups/:group_id/users")]
struct UsersListRoute {
    group_id: u64,

    #[query]
    query: UserListQuery,
}

fn main() {
    let path: UsersListRoute =
        "/groups/4313145/users?offset=10&limit=20&friends_only=false&keyword=some_keyword"
            .parse()
            .unwrap();

    assert_eq!(
        path,
        UsersListRoute {
            group_id: 4313145,
            query: {
                UserListQuery {
                    limit: Some(20),
                    offset: Some(10),
                    keyword: Some("some_keyword".to_string()),
                    friends_only: false,
                }
            }
        }
    );

    println!("Path: {}", path);
    // Output:
    // Path: /groups/4313145/users?limit=20&offset=10&keyword=some_keyword&friends_only=false
}

待办事项

  • URL哈希片段
  • 支持作为路径参数的尾随通配符
  • 尽可能使AppRoute trait 对象安全
  • 在过程宏中正确使用spans,以便错误真正有意义

依赖项

~5MB
~98K SLoC