[−][src]Trait routerify::ext::RequestExt
A extension trait which extends the hyper::Request
type with some helpful methods.
Required methods
fn params(&self) -> &RouteParams
It returns the route parameters as RouteParams type with the name of the parameter specified in the path as their respective keys.
Examples
use routerify::{Router, RouteParams}; use routerify::ext::RequestExt; use hyper::{Response, Body}; let router = Router::builder() .get("/users/:userName/books/:bookName", |req| async move { let params: &RouteParams = req.params(); let user_name = params.get("userName").unwrap(); let book_name = params.get("bookName").unwrap(); Ok(Response::new(Body::from(format!("Username: {}, Book Name: {}", user_name, book_name)))) }) .build() .unwrap();
fn param<P: Into<String>>(&self, param_name: P) -> Option<&String>
It returns the route parameter value by the name of the parameter specified in the path.
Examples
use routerify::{Router, RouteParams}; use routerify::ext::RequestExt; use hyper::{Response, Body}; let router = Router::builder() .get("/users/:userName/books/:bookName", |req| async move { let user_name = req.param("userName").unwrap(); let book_name = req.param("bookName").unwrap(); Ok(Response::new(Body::from(format!("Username: {}, Book Name: {}", user_name, book_name)))) }) .build() .unwrap();
fn remote_addr(&self) -> SocketAddr
It returns the remote address of the incoming request.
Examples
use routerify::{Router, RouteParams}; use routerify::ext::RequestExt; use hyper::{Response, Body}; let router = Router::builder() .get("/hello", |req| async move { let remote_addr = req.remote_addr(); Ok(Response::new(Body::from(format!("Hello from : {}", remote_addr)))) }) .build() .unwrap();