diff --git a/src/configurable.rs b/src/configurable.rs
deleted file mode 100644
index 1f673423..00000000
--- a/src/configurable.rs
+++ /dev/null
@@ -1,553 +0,0 @@
-use std::marker;
-
-use futures::{future, future::FutureResult, Async, Future, IntoFuture, Poll};
-use tower_service::Service;
-
-use service::{AndThen, FnService, MapErr};
-
-/// Creates new `Service` values.
-///
-/// Acts as a service factory. This is useful for cases where new `Service`
-/// values must be produced. One case is a TCP servier listener. The listner
-/// accepts new TCP streams, obtains a new `Service` value using the
-/// `NewConfigurableService` trait, and uses that new `Service` value to
-/// process inbound requests on that new TCP stream.
-pub trait NewConfigurableService<C> {
-    /// Requests handled by the service
-    type Request;
-
-    /// Responses given by the service
-    type Response;
-
-    /// Errors produced by the service
-    type Error;
-
-    /// The `Service` value created by this factory
-    type Service: Service<
-        Request = Self::Request,
-        Response = Self::Response,
-        Error = Self::Error,
-    >;
-
-    /// Errors produced while building a service.
-    type InitError;
-
-    /// The future of the `Service` instance.
-    type Future: Future<Item = Self::Service, Error = Self::InitError>;
-
-    /// Create and return a new service value asynchronously.
-    fn new_service(&self, C) -> Self::Future;
-
-    fn and_then<F, B>(self, new_service: F) -> AndThenNewConfigurableService<Self, B, C>
-    where
-        Self: Sized,
-        F: IntoNewConfigurableService<B, C>,
-        B: NewConfigurableService<
-            C,
-            Request = Self::Response,
-            Error = Self::Error,
-            InitError = Self::InitError,
-        >,
-    {
-        AndThenNewConfigurableService::new(self, new_service)
-    }
-
-    fn map_err<F, E>(self, f: F) -> MapErrNewConfigurableService<Self, F, E, C>
-    where
-        Self: Sized,
-        F: Fn(Self::Error) -> E,
-    {
-        MapErrNewConfigurableService::new(self, f)
-    }
-
-    fn map_init_err<F, E>(self, f: F) -> MapInitErr<Self, F, E, C>
-    where
-        Self: Sized,
-        F: Fn(Self::InitError) -> E,
-    {
-        MapInitErr::new(self, f)
-    }
-}
-
-/// Trait for types that can be converted to a Service
-pub trait IntoNewConfigurableService<T, C>
-where
-    T: NewConfigurableService<C>,
-{
-    /// Create service
-    fn into_new_service(self) -> T;
-}
-
-impl<T, C> IntoNewConfigurableService<T, C> for T
-where
-    T: NewConfigurableService<C>,
-{
-    fn into_new_service(self) -> T {
-        self
-    }
-}
-
-pub struct Fn2NewConfigurableService<F, S, Err, Fut, Cfg>
-where
-    S: Service,
-    F: Fn(Cfg) -> Fut,
-    Fut: IntoFuture<Item = S, Error = Err>,
-{
-    f: F,
-    err: marker::PhantomData<Err>,
-    cfg: marker::PhantomData<Cfg>,
-    fut: marker::PhantomData<Fut>,
-    s: marker::PhantomData<S>,
-}
-
-impl<F, S, Err, Fut, Cfg> Fn2NewConfigurableService<F, S, Err, Fut, Cfg>
-where
-    S: Service,
-    F: Fn(Cfg) -> Fut + 'static,
-    Fut: IntoFuture<Item = S, Error = Err>,
-{
-    fn new(f: F) -> Self {
-        Fn2NewConfigurableService {
-            f,
-            err: marker::PhantomData,
-            cfg: marker::PhantomData,
-            fut: marker::PhantomData,
-            s: marker::PhantomData,
-        }
-    }
-}
-
-impl<F, S, Err, Fut, Cfg>
-    IntoNewConfigurableService<Fn2NewConfigurableService<F, S, Err, Fut, Cfg>, Cfg> for F
-where
-    S: Service,
-    F: Fn(Cfg) -> Fut + 'static,
-    Fut: IntoFuture<Item = S, Error = Err>,
-{
-    fn into_new_service(self) -> Fn2NewConfigurableService<F, S, Err, Fut, Cfg> {
-        Fn2NewConfigurableService::new(self)
-    }
-}
-
-impl<F, S, Err, Fut, Cfg> Clone for Fn2NewConfigurableService<F, S, Err, Fut, Cfg>
-where
-    S: Service,
-    F: Fn(Cfg) -> Fut + Clone + 'static,
-    Fut: IntoFuture<Item = S, Error = Err>,
-{
-    fn clone(&self) -> Self {
-        Self::new(self.f.clone())
-    }
-}
-
-impl<F, S, Err, Fut, Cfg> NewConfigurableService<Cfg>
-    for Fn2NewConfigurableService<F, S, Err, Fut, Cfg>
-where
-    S: Service,
-    F: Fn(Cfg) -> Fut,
-    Fut: IntoFuture<Item = S, Error = Err>,
-{
-    type Request = S::Request;
-    type Response = S::Response;
-    type Error = S::Error;
-    type Service = S;
-    type InitError = Err;
-    type Future = Fut::Future;
-
-    fn new_service(&self, cfg: Cfg) -> Self::Future {
-        (self.f)(cfg).into_future()
-    }
-}
-
-pub struct FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg>
-where
-    F: Fn(Req) -> Fut,
-    Fut: IntoFuture<Item = Resp, Error = Err>,
-{
-    f: F,
-    req: marker::PhantomData<Req>,
-    resp: marker::PhantomData<Resp>,
-    err: marker::PhantomData<Err>,
-    ierr: marker::PhantomData<IErr>,
-    cfg: marker::PhantomData<Cfg>,
-}
-
-impl<F, Req, Resp, Err, IErr, Fut, Cfg>
-    FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg>
-where
-    F: Fn(Req) -> Fut + Clone,
-    Fut: IntoFuture<Item = Resp, Error = Err>,
-{
-    fn new(f: F) -> Self {
-        FnNewConfigurableService {
-            f,
-            req: marker::PhantomData,
-            resp: marker::PhantomData,
-            err: marker::PhantomData,
-            ierr: marker::PhantomData,
-            cfg: marker::PhantomData,
-        }
-    }
-}
-
-impl<F, Req, Resp, Err, IErr, Fut, Cfg> NewConfigurableService<Cfg>
-    for FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg>
-where
-    F: Fn(Req) -> Fut + Clone,
-    Fut: IntoFuture<Item = Resp, Error = Err>,
-{
-    type Request = Req;
-    type Response = Resp;
-    type Error = Err;
-    type Service = FnService<F, Req, Resp, Err, Fut>;
-    type InitError = IErr;
-    type Future = FutureResult<Self::Service, Self::InitError>;
-
-    fn new_service(&self, _: Cfg) -> Self::Future {
-        future::ok(FnService::new(self.f.clone()))
-    }
-}
-
-impl<F, Req, Resp, Err, IErr, Fut, Cfg>
-    IntoNewConfigurableService<FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg>, Cfg>
-    for F
-where
-    F: Fn(Req) -> Fut + Clone + 'static,
-    Fut: IntoFuture<Item = Resp, Error = Err>,
-{
-    fn into_new_service(self) -> FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg> {
-        FnNewConfigurableService::new(self)
-    }
-}
-
-impl<F, Req, Resp, Err, IErr, Fut, Cfg> Clone
-    for FnNewConfigurableService<F, Req, Resp, Err, IErr, Fut, Cfg>
-where
-    F: Fn(Req) -> Fut + Clone,
-    Fut: IntoFuture<Item = Resp, Error = Err>,
-{
-    fn clone(&self) -> Self {
-        Self::new(self.f.clone())
-    }
-}
-
-/// `AndThenNewConfigurableService` new service combinator
-pub struct AndThenNewConfigurableService<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<C>,
-{
-    a: A,
-    b: B,
-    c: marker::PhantomData<C>,
-}
-
-impl<A, B, C> AndThenNewConfigurableService<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<C>,
-{
-    /// Create new `AndThen` combinator
-    pub fn new<F: IntoNewConfigurableService<B, C>>(a: A, f: F) -> Self {
-        Self {
-            a,
-            b: f.into_new_service(),
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, B, C> NewConfigurableService<C> for AndThenNewConfigurableService<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<
-        C,
-        Request = A::Response,
-        Error = A::Error,
-        InitError = A::InitError,
-    >,
-    C: Clone,
-{
-    type Request = A::Request;
-    type Response = B::Response;
-    type Error = A::Error;
-    type Service = AndThen<A::Service, B::Service>;
-
-    type InitError = A::InitError;
-    type Future = AndThenNewConfigurableServiceFuture<A, B, C>;
-
-    fn new_service(&self, cfg: C) -> Self::Future {
-        AndThenNewConfigurableServiceFuture::new(
-            self.a.new_service(cfg.clone()),
-            self.b.new_service(cfg),
-        )
-    }
-}
-
-impl<A, B, C> Clone for AndThenNewConfigurableService<A, B, C>
-where
-    A: NewConfigurableService<C> + Clone,
-    B: NewConfigurableService<
-            C,
-            Request = A::Response,
-            Error = A::Error,
-            InitError = A::InitError,
-        > + Clone,
-{
-    fn clone(&self) -> Self {
-        Self {
-            a: self.a.clone(),
-            b: self.b.clone(),
-            c: marker::PhantomData,
-        }
-    }
-}
-
-pub struct AndThenNewConfigurableServiceFuture<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<C>,
-{
-    fut_b: B::Future,
-    fut_a: A::Future,
-    a: Option<A::Service>,
-    b: Option<B::Service>,
-    c: marker::PhantomData<C>,
-}
-
-impl<A, B, C> AndThenNewConfigurableServiceFuture<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<C>,
-{
-    fn new(fut_a: A::Future, fut_b: B::Future) -> Self {
-        AndThenNewConfigurableServiceFuture {
-            fut_a,
-            fut_b,
-            a: None,
-            b: None,
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, B, C> Future for AndThenNewConfigurableServiceFuture<A, B, C>
-where
-    A: NewConfigurableService<C>,
-    B: NewConfigurableService<
-        C,
-        Request = A::Response,
-        Error = A::Error,
-        InitError = A::InitError,
-    >,
-{
-    type Item = AndThen<A::Service, B::Service>;
-    type Error = A::InitError;
-
-    fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
-        if let Async::Ready(service) = self.fut_a.poll()? {
-            self.a = Some(service);
-        }
-
-        if let Async::Ready(service) = self.fut_b.poll()? {
-            self.b = Some(service);
-        }
-
-        if self.a.is_some() && self.b.is_some() {
-            Ok(Async::Ready(AndThen::new(
-                self.a.take().unwrap(),
-                self.b.take().unwrap(),
-            )))
-        } else {
-            Ok(Async::NotReady)
-        }
-    }
-}
-
-/// `MapErrNewService` new service combinator
-pub struct MapErrNewConfigurableService<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-{
-    a: A,
-    f: F,
-    e: marker::PhantomData<E>,
-    c: marker::PhantomData<C>,
-}
-
-impl<A, F, E, C> MapErrNewConfigurableService<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::Error) -> E,
-{
-    /// Create new `MapErr` new service instance
-    pub fn new(a: A, f: F) -> Self {
-        Self {
-            a,
-            f,
-            e: marker::PhantomData,
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, F, E, C> Clone for MapErrNewConfigurableService<A, F, E, C>
-where
-    A: NewConfigurableService<C> + Clone,
-    F: Fn(A::Error) -> E + Clone,
-{
-    fn clone(&self) -> Self {
-        Self {
-            a: self.a.clone(),
-            f: self.f.clone(),
-            e: marker::PhantomData,
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, F, E, C> NewConfigurableService<C> for MapErrNewConfigurableService<A, F, E, C>
-where
-    A: NewConfigurableService<C> + Clone,
-    F: Fn(A::Error) -> E + Clone,
-{
-    type Request = A::Request;
-    type Response = A::Response;
-    type Error = E;
-    type Service = MapErr<A::Service, F, E>;
-
-    type InitError = A::InitError;
-    type Future = MapErrNewConfigurableServiceFuture<A, F, E, C>;
-
-    fn new_service(&self, cfg: C) -> Self::Future {
-        MapErrNewConfigurableServiceFuture::new(self.a.new_service(cfg), self.f.clone())
-    }
-}
-
-pub struct MapErrNewConfigurableServiceFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::Error) -> E,
-{
-    fut: A::Future,
-    f: F,
-}
-
-impl<A, F, E, C> MapErrNewConfigurableServiceFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::Error) -> E,
-{
-    fn new(fut: A::Future, f: F) -> Self {
-        MapErrNewConfigurableServiceFuture { f, fut }
-    }
-}
-
-impl<A, F, E, C> Future for MapErrNewConfigurableServiceFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::Error) -> E + Clone,
-{
-    type Item = MapErr<A::Service, F, E>;
-    type Error = A::InitError;
-
-    fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
-        if let Async::Ready(service) = self.fut.poll()? {
-            Ok(Async::Ready(MapErr::new(service, self.f.clone())))
-        } else {
-            Ok(Async::NotReady)
-        }
-    }
-}
-
-/// `MapInitErr` service combinator
-pub struct MapInitErr<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-{
-    a: A,
-    f: F,
-    e: marker::PhantomData<E>,
-    c: marker::PhantomData<C>,
-}
-
-impl<A, F, E, C> MapInitErr<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::InitError) -> E,
-{
-    /// Create new `MapInitErr` combinator
-    pub fn new(a: A, f: F) -> Self {
-        Self {
-            a,
-            f,
-            e: marker::PhantomData,
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, F, E, C> Clone for MapInitErr<A, F, E, C>
-where
-    A: NewConfigurableService<C> + Clone,
-    F: Fn(A::InitError) -> E + Clone,
-{
-    fn clone(&self) -> Self {
-        Self {
-            a: self.a.clone(),
-            f: self.f.clone(),
-            e: marker::PhantomData,
-            c: marker::PhantomData,
-        }
-    }
-}
-
-impl<A, F, E, C> NewConfigurableService<C> for MapInitErr<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::InitError) -> E + Clone,
-{
-    type Request = A::Request;
-    type Response = A::Response;
-    type Error = A::Error;
-    type Service = A::Service;
-
-    type InitError = E;
-    type Future = MapInitErrFuture<A, F, E, C>;
-
-    fn new_service(&self, cfg: C) -> Self::Future {
-        MapInitErrFuture::new(self.a.new_service(cfg), self.f.clone())
-    }
-}
-
-pub struct MapInitErrFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::InitError) -> E,
-{
-    f: F,
-    fut: A::Future,
-}
-
-impl<A, F, E, C> MapInitErrFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::InitError) -> E,
-{
-    fn new(fut: A::Future, f: F) -> Self {
-        MapInitErrFuture { f, fut }
-    }
-}
-
-impl<A, F, E, C> Future for MapInitErrFuture<A, F, E, C>
-where
-    A: NewConfigurableService<C>,
-    F: Fn(A::InitError) -> E,
-{
-    type Item = A::Service;
-    type Error = E;
-
-    fn poll(&mut self) -> Poll<Self::Item, Self::Error> {
-        self.fut.poll().map_err(&self.f)
-    }
-}
diff --git a/src/lib.rs b/src/lib.rs
index bf95306a..d7c0fed5 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -62,7 +62,6 @@ use actix::Message;
 pub use tower_service::{NewService, Service};
 
 pub(crate) mod accept;
-pub mod configurable;
 pub mod connector;
 pub mod server;
 mod server_service;
@@ -71,7 +70,6 @@ pub mod ssl;
 pub mod stream;
 mod worker;
 
-pub use configurable::{IntoNewConfigurableService, NewConfigurableService};
 pub use server::Server;
 pub use service::{IntoNewService, IntoService, NewServiceExt, ServiceExt};