1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
//! A [`Routerify`](https://github.com/routerify/routerify) middleware which parses the request query string and populates in the `req` object.
//!
//! # Examples
//!
//! ```no_run
//! use hyper::{Body, Request, Response, Server};
//! use routerify::{Router, RouterService};
//! // Import the query_parser function and the RequestQueryExt trait.
//! use routerify_query::{query_parser, RequestQueryExt};
//! use std::{convert::Infallible, net::SocketAddr};
//!
//! // A handler for "/" page. Visit: "/?username=Alice&bookname=HarryPotter" to see query values.
//! async fn home_handler(req: Request<Body>) -> Result<Response<Body>, Infallible> {
//! // Access the query values.
//! let user_name = req.query("username").unwrap();
//! let book_name = req.query("bookname").unwrap();
//!
//! Ok(Response::new(Body::from(format!(
//! "User: {}, Book: {}",
//! user_name, book_name
//! ))))
//! }
//!
//! // Create a router.
//! fn router() -> Router<Body, Infallible> {
//! Router::builder()
//! // Attach the query_parser middleware.
//! .middleware(query_parser())
//! .get("/", home_handler)
//! .build()
//! .unwrap()
//! }
//!
//! #[tokio::main]
//! async fn main() {
//! let router = router();
//!
//! // Create a Service from the router above to handle incoming requests.
//! let service = RouterService::new(router).unwrap();
//!
//! // The address on which the server will be listening.
//! let addr = SocketAddr::from(([127, 0, 0, 1], 3001));
//!
//! // Create a server by passing the created service to `.serve` method.
//! let server = Server::bind(&addr).serve(service);
//!
//! println!("App is running on: {}", addr);
//! if let Err(err) = server.await {
//! eprintln!("Server error: {}", err);
//! }
//! }
//! ```
//!
use ;
use Middleware;
use HashMap;
use form_urlencoded;
pub use RequestQueryExt;
pub ;
/// Parses the request query string and populates in the `req` object.
///
/// # Examples
///
/// ```
/// use hyper::{Body, Request, Response, Server};
/// use routerify::{Router, RouterService};
/// // Import the query_parser function and the RequestQueryExt trait.
/// use routerify_query::{query_parser, RequestQueryExt};
/// use std::{convert::Infallible, net::SocketAddr};
///
/// // A handler for "/" page. Visit: "/?username=Alice&bookname=HarryPotter" to see query values.
/// async fn home_handler(req: Request<Body>) -> Result<Response<Body>, Infallible> {
/// // Access the query values.
/// let user_name = req.query("username").unwrap();
/// let book_name = req.query("bookname").unwrap();
///
/// Ok(Response::new(Body::from(format!(
/// "User: {}, Book: {}",
/// user_name, book_name
/// ))))
/// }
///
///
/// # fn run() -> Router<Body, Infallible> {
/// // Create a router.
/// Router::builder()
/// // Attach the query_parser middleware.
/// .middleware(query_parser())
/// .get("/", home_handler)
/// .build()
/// .unwrap()
/// }
/// # run();
/// ```
async