28 releases

0.6.0 Nov 7, 2017
0.5.1 Jan 23, 2017
0.4.0 Sep 4, 2016
0.2.0 Jul 26, 2016
0.0.4 Dec 28, 2014

#11 in HTTP server

Download history 1430/week @ 2019-07-03 1519/week @ 2019-07-10 1766/week @ 2019-07-17 1517/week @ 2019-07-24 1239/week @ 2019-07-31 1127/week @ 2019-08-07 1125/week @ 2019-08-14 1566/week @ 2019-08-21 1144/week @ 2019-08-28 1439/week @ 2019-09-04 1328/week @ 2019-09-11 1505/week @ 2019-09-18 1631/week @ 2019-09-25 1154/week @ 2019-10-02 1010/week @ 2019-10-09

6,416 downloads per month
Used in 58 crates (53 directly)

MIT license

22KB
356 lines

Router Build Status Crates.io Status

Routing handler for the Iron web framework.

Router is a fast, convenient, and flexible routing middleware for Iron. It allows complex glob patterns and named url parameters and also allows handlers to be any Handler, including all Chains.

Example

extern crate iron;
extern crate router;

use iron::prelude::*;
use iron::status;
use router::Router;

fn main() {
    let mut router = Router::new();           // Alternative syntax:
    router.get("/", handler, "index");        // let router = router!(index: get "/" => handler,
    router.get("/:query", handler, "query");  //                      query: get "/:query" => handler);

    Iron::new(router).http("localhost:3000").unwrap();

    fn handler(req: &mut Request) -> IronResult<Response> {
        let ref query = req.extensions.get::<Router>().unwrap().find("query").unwrap_or("/");
        Ok(Response::with((status::Ok, *query)))
    }
}

Overview

Router is a part of Iron's core bundle.

  • Route client requests based on their paths
  • Parse parameters and provide them to other middleware/handlers

Installation

If you're using cargo, just add router to your Cargo.toml.

[dependencies]

router = "*"

Otherwise, cargo build, and the rlib will be in your target directory.

Documentation

Along with the online documentation, you can build a local copy with make doc.

Examples

Get Help

One of us is usually on #iron on the mozilla irc. Come say hi and ask any questions you might have. We are also usually on #rust and #rust-webdev.

Dependencies

~3MB
~74K SLoC