#query-string #routes #applications #path #structs #url #strongly-typed

app_route

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

4个版本 (2个破坏性更新)

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

#17 in #strongly-typed

MIT许可证

7KB
61

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
}

TODO

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

依赖

~9MB
~179K SLoC