Crates.io | params |
lib.rs | params |
version | 0.8.0 |
source | src |
created_at | 2015-07-08 21:56:29.456716 |
updated_at | 2017-11-27 01:40:17.8345 |
description | A multi-source request parameters parser for Iron. |
homepage | |
repository | https://github.com/iron/params |
max_upload_size | |
id | 2564 |
size | 56,321 |
A plugin for the Iron web framework that parses parameters from incoming requests from the following sources:
Content-Type: application/json
)Content-Type: application/x-www-form-urlencoded
parametersContent-Type: multipart/form-data
)This plugin combines all request parameters from these sources into a single params::Map
accessible through any Iron request using req.get_ref::<params::Params>()
. Working example:
// Visit `http://127.0.0.1:3000/?user[name]=Marie` to be greeted with a welcome message. Any other
// request will return a 404 error.
extern crate iron;
extern crate params;
use iron::prelude::*;
fn handle_user(req: &mut Request) -> IronResult<Response> {
use params::{Params, Value};
let map = req.get_ref::<Params>().unwrap();
match map.find(&["user", "name"]) {
Some(&Value::String(ref name)) if name == "Marie" => {
Ok(Response::with((iron::status::Ok, "Welcome back, Marie!")))
},
_ => Ok(Response::with(iron::status::NotFound)),
}
}
fn main() {
Iron::new(handle_user).http("127.0.0.1:3000").unwrap();
}
You can perform custom request parameter deserialization by implementing params::FromValue
for any Sized
type. See src/conversion.rs
for inspiration!
This crate is fully documented, and we're working on hosting it at ironframework.io.
See examples/params.rs
for an interactive example.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.