Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.

## [Unreleased]
### Added
- Add `SafeHeaders` to work around Hyper 0.11 panic handling differently type headers with the same name - e.g. Authorization
- Fix warnings present on Rust 1.39

### Changed

Expand Down
2 changes: 1 addition & 1 deletion src/base64_format.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ impl<'de> Deserialize<'de> for ByteArray {
where
D: Deserializer<'de>,
{
let s = try!(String::deserialize(deserializer));
let s = String::deserialize(deserializer)?;
match decode(&s) {
Ok(bin) => Ok(ByteArray(bin)),
_ => Err(D::Error::custom("invalid base64")),
Expand Down
8 changes: 4 additions & 4 deletions src/composites.rs
Original file line number Diff line number Diff line change
Expand Up @@ -41,10 +41,10 @@ impl NotFound for Response {
}
}

type BoxedFuture<V, W> = Box<Future<Item = V, Error = W>>;
type CompositeNewServiceVec<U, V, W> = Vec<(&'static str, Box<BoxedNewService<U, V, W>>)>;
type BoxedFuture<V, W> = Box<dyn Future<Item = V, Error = W>>;
type CompositeNewServiceVec<U, V, W> = Vec<(&'static str, Box<dyn BoxedNewService<U, V, W>>)>;
type BoxedService<U, V, W> =
Box<Service<Request = U, Response = V, Error = W, Future = BoxedFuture<V, W>>>;
Box<dyn Service<Request = U, Response = V, Error = W, Future = BoxedFuture<V, W>>>;

/// Trait for wrapping hyper `NewService`s to make the return type of `new_service` uniform.
/// This is necessary in order for the `NewService`s with different `Instance` types to
Expand Down Expand Up @@ -185,7 +185,7 @@ where
type Request = U;
type Response = V;
type Error = W;
type Future = Box<Future<Item = V, Error = W>>;
type Future = Box<dyn Future<Item = V, Error = W>>;

fn call(&self, req: Self::Request) -> Self::Future {
let mut result = None;
Expand Down
10 changes: 5 additions & 5 deletions src/connector.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ use hyper;

/// Returns a function which creates an http-connector. Used for instantiating
/// clients with custom connectors
pub fn http_connector() -> Box<Fn(&Handle) -> hyper::client::HttpConnector + Send + Sync> {
pub fn http_connector() -> Box<dyn Fn(&Handle) -> hyper::client::HttpConnector + Send + Sync> {
Box::new(move |handle: &Handle| hyper::client::HttpConnector::new(4, handle))
}

Expand All @@ -25,7 +25,7 @@ pub fn http_connector() -> Box<Fn(&Handle) -> hyper::client::HttpConnector + Sen
#[cfg(not(any(target_os = "macos", target_os = "windows", target_os = "ios")))]
pub fn https_connector<CA>(
ca_certificate: CA,
) -> Box<Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
) -> Box<dyn Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
where
CA: AsRef<Path>,
{
Expand Down Expand Up @@ -53,7 +53,7 @@ where
#[cfg(any(target_os = "macos", target_os = "windows", target_os = "ios"))]
pub fn https_connector<CA>(
_ca_certificate: CA,
) -> Box<Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
) -> Box<dyn Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
where
CA: AsRef<Path>,
{
Expand All @@ -71,7 +71,7 @@ pub fn https_mutual_connector<CA, K, C>(
ca_certificate: CA,
client_key: K,
client_certificate: C,
) -> Box<Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
) -> Box<dyn Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
where
CA: AsRef<Path>,
K: AsRef<Path>,
Expand Down Expand Up @@ -112,7 +112,7 @@ pub fn https_mutual_connector<CA, K, C>(
_ca_certificate: CA,
_client_key: K,
_client_certificate: C,
) -> Box<Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
) -> Box<dyn Fn(&Handle) -> hyper_tls::HttpsConnector<hyper::client::HttpConnector> + Send + Sync>
where
CA: AsRef<Path>,
K: AsRef<Path>,
Expand Down
8 changes: 4 additions & 4 deletions src/context.rs
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ use std::marker::Sized;
/// type Request = (hyper::Request, C);
/// type Response = hyper::Response;
/// type Error = hyper::Error;
/// type Future = Box<Future<Item=Self::Response, Error=Self::Error>>;
/// type Future = Box<dyn Future<Item=Self::Response, Error=Self::Error>>;
/// fn call(&self, (req, context) : Self::Request) -> Self::Future {
/// do_something_with_my_item(Has::<MyItem>::get(&context));
/// Box::new(ok(hyper::Response::new()))
Expand Down Expand Up @@ -546,7 +546,7 @@ pub trait SwaggerService<C>:
Request = (hyper::server::Request, C),
Response = hyper::server::Response,
Error = hyper::Error,
Future = Box<Future<Item = hyper::server::Response, Error = hyper::Error>>,
Future = Box<dyn Future<Item = hyper::server::Response, Error = hyper::Error>>,
>
where
C: Has<Option<AuthData>> + Has<Option<Authorization>> + Has<XSpanIdString> + Clone + 'static,
Expand All @@ -560,7 +560,7 @@ where
Request = (hyper::server::Request, C),
Response = hyper::server::Response,
Error = hyper::Error,
Future = Box<Future<Item = hyper::server::Response, Error = hyper::Error>>,
Future = Box<dyn Future<Item = hyper::server::Response, Error = hyper::Error>>,
>,
C: Has<Option<AuthData>> + Has<Option<Authorization>> + Has<XSpanIdString> + Clone + 'static,
{
Expand Down Expand Up @@ -603,7 +603,7 @@ mod context_tests {
type Request = (Request, C);
type Response = Response;
type Error = Error;
type Future = Box<Future<Item = Response, Error = Error>>;
type Future = Box<dyn Future<Item = Response, Error = Error>>;
fn call(&self, (_, context): Self::Request) -> Self::Future {
use_item_2(Has::<ContextItem2>::get(&context));

Expand Down
39 changes: 39 additions & 0 deletions src/headers.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
//! Support library for handling headers in a safe manner

use hyper::header::{Header, Headers};

/// Trait to add a mechanism to safely retrieve a header.
///
/// In Hyper 0.11, if you add an Authorization<Basic> header,
/// and then attempt get an Authorization<Bearer> header, the code
/// will panic, as the type ID doesn't match.
pub trait SafeHeaders {
/// Safely get a header from a hyper::header::Headers
fn safe_get<H: Header>(&self) -> Option<H>;
}

impl SafeHeaders for Headers {
fn safe_get<H: Header>(&self) -> Option<H> {
self.get_raw(H::header_name())
.map(H::parse_header)
.map(Result::ok)
.unwrap_or(None)
}
}

#[cfg(test)]
mod tests {
use super::*;
use hyper::header::{Authorization, Basic, Bearer};

#[test]
fn test() {
let mut headers = Headers::default();
let basic = Basic {
username: "richard".to_string(),
password: None,
};
headers.set::<Authorization<Basic>>(Authorization(basic));
println!("Auth: {:?}", headers.safe_get::<Authorization<Bearer>>());
}
}
4 changes: 3 additions & 1 deletion src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,8 @@ pub use drop_context::DropContext;
pub mod request_parser;
pub use request_parser::RequestParser;

pub mod headers;

header! {
/// `X-Span-ID` header, used to track a request through a chain of microservices.
(XSpanId, "X-Span-ID") => [String]
Expand Down Expand Up @@ -91,7 +93,7 @@ pub struct ApiError(pub String);

impl fmt::Display for ApiError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
let debug: &fmt::Debug = self;
let debug: &dyn fmt::Debug = self;
debug.fmt(f)
}
}
Expand Down