Update to iron 0.5

* `Url::into_generic_url` was deprecated in 0.4.1. The `Into` trait is
    used instead.
  * iron/logger removed support for ANSI terminal colors in 0.2.0, which
    makes logging work in the Command Prompt on Windows.

Fixes #21
This commit is contained in:
Michael Macias 2017-01-24 23:43:39 -06:00
parent 708b99be62
commit b2e75bf4f6
3 changed files with 12 additions and 21 deletions

View file

@ -23,13 +23,13 @@ expose-test-schema = []
[dependencies] [dependencies]
rustc-serialize = { version = "^0.3.19", optional = true } rustc-serialize = { version = "^0.3.19", optional = true }
iron = { version = "^0.4.0", optional = true } iron = { version = "^0.5.1", optional = true }
serde = { version = "^0.9.1", optional = true } serde = { version = "^0.9.1", optional = true }
[dev-dependencies] [dev-dependencies]
iron = "^0.4.0" iron = "^0.5.1"
router = "^0.2.0" router = "^0.5.0"
mount = "^0.2.1" mount = "^0.3.0"
logger = "^0.1.0" logger = "^0.3.0"
iron-test = "^0.4.0" iron-test = "^0.5.0"
bencher = "^0.1.2" bencher = "^0.1.2"

View file

@ -30,23 +30,13 @@ fn main() {
mount.mount("/", graphiql_endpoint); mount.mount("/", graphiql_endpoint);
mount.mount("/graphql", graphql_endpoint); mount.mount("/graphql", graphql_endpoint);
let mut chain = Chain::new(mount); let (logger_before, logger_after) = Logger::new(None);
setup_logger(&mut chain); let mut chain = Chain::new(mount);
chain.link_before(logger_before);
chain.link_after(logger_after);
let host = env::var("LISTEN").unwrap_or("0.0.0.0:8080".to_owned()); let host = env::var("LISTEN").unwrap_or("0.0.0.0:8080".to_owned());
println!("GraphQL server started on {}", host); println!("GraphQL server started on {}", host);
Iron::new(chain).http(host.as_str()).unwrap(); Iron::new(chain).http(host.as_str()).unwrap();
} }
// Temporary fix - Iron's logger middleware does not work on Windows
#[cfg(not(windows))]
fn setup_logger(chain: &mut Chain) {
let (logger_before, logger_after) = Logger::new(None);
chain.link_before(logger_before);
chain.link_after(logger_after);
}
#[cfg(windows)]
fn setup_logger(_: &mut Chain) {
}

View file

@ -5,6 +5,7 @@ use iron::middleware::Handler;
use iron::mime::Mime; use iron::mime::Mime;
use iron::status; use iron::status;
use iron::method; use iron::method;
use iron::url::Url;
use std::collections::BTreeMap; use std::collections::BTreeMap;
@ -59,7 +60,7 @@ impl<'a, CtxFactory, Query, Mutation, CtxT>
fn handle_get(&self, req: &mut Request) -> IronResult<Response> { fn handle_get(&self, req: &mut Request) -> IronResult<Response> {
let url = req.url.clone().into_generic_url(); let url: Url = req.url.clone().into();
let mut query = None; let mut query = None;
let variables = Variables::new(); let variables = Variables::new();