2018-11-15 17:41:11 +01:00
|
|
|
// Copyright 2018 Parity Technologies (UK) Ltd.
|
2018-05-14 15:55:16 +02:00
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a
|
|
|
|
// copy of this software and associated documentation files (the "Software"),
|
|
|
|
// to deal in the Software without restriction, including without limitation
|
|
|
|
// the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
|
|
// and/or sell copies of the Software, and to permit persons to whom the
|
|
|
|
// Software is furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
|
|
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
|
|
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
// DEALINGS IN THE SOFTWARE.
|
|
|
|
|
2019-09-16 11:08:44 +02:00
|
|
|
use crate::Negotiated;
|
2018-11-15 17:41:11 +01:00
|
|
|
use crate::upgrade::{InboundUpgrade, OutboundUpgrade, UpgradeInfo};
|
2019-09-16 11:08:44 +02:00
|
|
|
use futures::prelude::*;
|
|
|
|
use std::{pin::Pin, task::Context, task::Poll};
|
2018-05-14 15:55:16 +02:00
|
|
|
|
2018-11-16 12:11:44 +01:00
|
|
|
/// Wraps around an upgrade and applies a closure to the output.
|
2018-11-15 17:41:11 +01:00
|
|
|
#[derive(Debug, Clone)]
|
2018-11-19 10:58:45 +01:00
|
|
|
pub struct MapInboundUpgrade<U, F> { upgrade: U, fun: F }
|
2018-05-14 15:55:16 +02:00
|
|
|
|
2018-11-19 10:58:45 +01:00
|
|
|
impl<U, F> MapInboundUpgrade<U, F> {
|
2018-11-15 17:41:11 +01:00
|
|
|
pub fn new(upgrade: U, fun: F) -> Self {
|
2018-11-19 10:58:45 +01:00
|
|
|
MapInboundUpgrade { upgrade, fun }
|
2018-11-15 17:41:11 +01:00
|
|
|
}
|
2018-05-14 15:55:16 +02:00
|
|
|
}
|
|
|
|
|
2018-11-19 10:58:45 +01:00
|
|
|
impl<U, F> UpgradeInfo for MapInboundUpgrade<U, F>
|
2018-05-14 15:55:16 +02:00
|
|
|
where
|
2018-11-15 17:41:11 +01:00
|
|
|
U: UpgradeInfo
|
2018-05-14 15:55:16 +02:00
|
|
|
{
|
2018-12-11 15:13:10 +01:00
|
|
|
type Info = U::Info;
|
|
|
|
type InfoIter = U::InfoIter;
|
2018-05-14 15:55:16 +02:00
|
|
|
|
2018-12-11 15:13:10 +01:00
|
|
|
fn protocol_info(&self) -> Self::InfoIter {
|
|
|
|
self.upgrade.protocol_info()
|
2018-05-14 15:55:16 +02:00
|
|
|
}
|
2018-11-15 17:41:11 +01:00
|
|
|
}
|
|
|
|
|
2018-11-19 10:58:45 +01:00
|
|
|
impl<C, U, F, T> InboundUpgrade<C> for MapInboundUpgrade<U, F>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
|
|
|
U: InboundUpgrade<C>,
|
2019-09-16 11:08:44 +02:00
|
|
|
U::Future: Unpin,
|
2018-11-15 17:41:11 +01:00
|
|
|
F: FnOnce(U::Output) -> T
|
|
|
|
{
|
|
|
|
type Output = T;
|
|
|
|
type Error = U::Error;
|
|
|
|
type Future = MapFuture<U::Future, F>;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_inbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-11-15 17:41:11 +01:00
|
|
|
MapFuture {
|
2018-12-11 15:13:10 +01:00
|
|
|
inner: self.upgrade.upgrade_inbound(sock, info),
|
2018-11-15 17:41:11 +01:00
|
|
|
map: Some(self.fun)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-05-14 15:55:16 +02:00
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<C, U, F> OutboundUpgrade<C> for MapInboundUpgrade<U, F>
|
2018-11-19 10:58:45 +01:00
|
|
|
where
|
2019-09-16 11:08:44 +02:00
|
|
|
U: OutboundUpgrade<C>,
|
|
|
|
U::Future: Unpin,
|
2018-11-19 10:58:45 +01:00
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = U::Error;
|
|
|
|
type Future = U::Future;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_outbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-12-11 15:13:10 +01:00
|
|
|
self.upgrade.upgrade_outbound(sock, info)
|
2018-11-19 10:58:45 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Wraps around an upgrade and applies a closure to the output.
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct MapOutboundUpgrade<U, F> { upgrade: U, fun: F }
|
|
|
|
|
|
|
|
impl<U, F> MapOutboundUpgrade<U, F> {
|
|
|
|
pub fn new(upgrade: U, fun: F) -> Self {
|
|
|
|
MapOutboundUpgrade { upgrade, fun }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<U, F> UpgradeInfo for MapOutboundUpgrade<U, F>
|
|
|
|
where
|
|
|
|
U: UpgradeInfo
|
|
|
|
{
|
2018-12-11 15:13:10 +01:00
|
|
|
type Info = U::Info;
|
|
|
|
type InfoIter = U::InfoIter;
|
2018-11-19 10:58:45 +01:00
|
|
|
|
2018-12-11 15:13:10 +01:00
|
|
|
fn protocol_info(&self) -> Self::InfoIter {
|
|
|
|
self.upgrade.protocol_info()
|
2018-11-19 10:58:45 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<C, U, F> InboundUpgrade<C> for MapOutboundUpgrade<U, F>
|
2018-11-19 10:58:45 +01:00
|
|
|
where
|
2019-09-16 11:08:44 +02:00
|
|
|
U: InboundUpgrade<C>,
|
|
|
|
U::Future: Unpin,
|
2018-11-19 10:58:45 +01:00
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = U::Error;
|
|
|
|
type Future = U::Future;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_inbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-12-11 15:13:10 +01:00
|
|
|
self.upgrade.upgrade_inbound(sock, info)
|
2018-11-19 10:58:45 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<C, U, F, T> OutboundUpgrade<C> for MapOutboundUpgrade<U, F>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
|
|
|
U: OutboundUpgrade<C>,
|
2019-09-16 11:08:44 +02:00
|
|
|
U::Future: Unpin,
|
2018-11-15 17:41:11 +01:00
|
|
|
F: FnOnce(U::Output) -> T
|
|
|
|
{
|
|
|
|
type Output = T;
|
|
|
|
type Error = U::Error;
|
2018-11-12 17:12:47 +01:00
|
|
|
type Future = MapFuture<U::Future, F>;
|
2018-05-14 15:55:16 +02:00
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_outbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-11-12 17:12:47 +01:00
|
|
|
MapFuture {
|
2018-12-11 15:13:10 +01:00
|
|
|
inner: self.upgrade.upgrade_outbound(sock, info),
|
2018-11-15 17:41:11 +01:00
|
|
|
map: Some(self.fun)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-16 12:11:44 +01:00
|
|
|
/// Wraps around an upgrade and applies a closure to the error.
|
2018-11-15 17:41:11 +01:00
|
|
|
#[derive(Debug, Clone)]
|
2018-11-19 16:08:00 +01:00
|
|
|
pub struct MapInboundUpgradeErr<U, F> { upgrade: U, fun: F }
|
2018-11-15 17:41:11 +01:00
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<U, F> MapInboundUpgradeErr<U, F> {
|
2018-11-15 17:41:11 +01:00
|
|
|
pub fn new(upgrade: U, fun: F) -> Self {
|
2018-11-19 16:08:00 +01:00
|
|
|
MapInboundUpgradeErr { upgrade, fun }
|
2018-11-15 17:41:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<U, F> UpgradeInfo for MapInboundUpgradeErr<U, F>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
|
|
|
U: UpgradeInfo
|
|
|
|
{
|
2018-12-11 15:13:10 +01:00
|
|
|
type Info = U::Info;
|
|
|
|
type InfoIter = U::InfoIter;
|
2018-11-15 17:41:11 +01:00
|
|
|
|
2018-12-11 15:13:10 +01:00
|
|
|
fn protocol_info(&self) -> Self::InfoIter {
|
|
|
|
self.upgrade.protocol_info()
|
2018-11-15 17:41:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<C, U, F, T> InboundUpgrade<C> for MapInboundUpgradeErr<U, F>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
|
|
|
U: InboundUpgrade<C>,
|
2019-09-16 11:08:44 +02:00
|
|
|
U::Future: Unpin,
|
2018-11-15 17:41:11 +01:00
|
|
|
F: FnOnce(U::Error) -> T
|
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = T;
|
|
|
|
type Future = MapErrFuture<U::Future, F>;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_inbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-11-15 17:41:11 +01:00
|
|
|
MapErrFuture {
|
2018-12-11 15:13:10 +01:00
|
|
|
fut: self.upgrade.upgrade_inbound(sock, info),
|
2018-11-15 17:41:11 +01:00
|
|
|
fun: Some(self.fun)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<C, U, F> OutboundUpgrade<C> for MapInboundUpgradeErr<U, F>
|
|
|
|
where
|
2019-09-16 11:08:44 +02:00
|
|
|
U: OutboundUpgrade<C>,
|
|
|
|
U::Future: Unpin,
|
2018-11-19 16:08:00 +01:00
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = U::Error;
|
|
|
|
type Future = U::Future;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_outbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-12-11 15:13:10 +01:00
|
|
|
self.upgrade.upgrade_outbound(sock, info)
|
2018-11-19 16:08:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Wraps around an upgrade and applies a closure to the error.
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct MapOutboundUpgradeErr<U, F> { upgrade: U, fun: F }
|
|
|
|
|
|
|
|
impl<U, F> MapOutboundUpgradeErr<U, F> {
|
|
|
|
pub fn new(upgrade: U, fun: F) -> Self {
|
|
|
|
MapOutboundUpgradeErr { upgrade, fun }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<U, F> UpgradeInfo for MapOutboundUpgradeErr<U, F>
|
|
|
|
where
|
|
|
|
U: UpgradeInfo
|
|
|
|
{
|
2018-12-11 15:13:10 +01:00
|
|
|
type Info = U::Info;
|
|
|
|
type InfoIter = U::InfoIter;
|
2018-11-19 16:08:00 +01:00
|
|
|
|
2018-12-11 15:13:10 +01:00
|
|
|
fn protocol_info(&self) -> Self::InfoIter {
|
|
|
|
self.upgrade.protocol_info()
|
2018-11-19 16:08:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<C, U, F, T> OutboundUpgrade<C> for MapOutboundUpgradeErr<U, F>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
|
|
|
U: OutboundUpgrade<C>,
|
2019-09-16 11:08:44 +02:00
|
|
|
U::Future: Unpin,
|
2018-11-19 16:08:00 +01:00
|
|
|
F: FnOnce(U::Error) -> T
|
2018-11-15 17:41:11 +01:00
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = T;
|
|
|
|
type Future = MapErrFuture<U::Future, F>;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_outbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-11-15 17:41:11 +01:00
|
|
|
MapErrFuture {
|
2018-12-11 15:13:10 +01:00
|
|
|
fut: self.upgrade.upgrade_outbound(sock, info),
|
2018-11-15 17:41:11 +01:00
|
|
|
fun: Some(self.fun)
|
2018-11-12 17:12:47 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-19 16:08:00 +01:00
|
|
|
impl<C, U, F> InboundUpgrade<C> for MapOutboundUpgradeErr<U, F>
|
|
|
|
where
|
|
|
|
U: InboundUpgrade<C>
|
|
|
|
{
|
|
|
|
type Output = U::Output;
|
|
|
|
type Error = U::Error;
|
|
|
|
type Future = U::Future;
|
|
|
|
|
2019-03-19 17:27:30 +01:00
|
|
|
fn upgrade_inbound(self, sock: Negotiated<C>, info: Self::Info) -> Self::Future {
|
2018-12-11 15:13:10 +01:00
|
|
|
self.upgrade.upgrade_inbound(sock, info)
|
2018-11-19 16:08:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-12 17:12:47 +01:00
|
|
|
pub struct MapFuture<TInnerFut, TMap> {
|
|
|
|
inner: TInnerFut,
|
|
|
|
map: Option<TMap>,
|
|
|
|
}
|
|
|
|
|
2019-09-16 11:08:44 +02:00
|
|
|
impl<TInnerFut, TMap> Unpin for MapFuture<TInnerFut, TMap> {
|
|
|
|
}
|
|
|
|
|
2018-11-12 17:12:47 +01:00
|
|
|
impl<TInnerFut, TIn, TMap, TOut> Future for MapFuture<TInnerFut, TMap>
|
2018-11-15 17:41:11 +01:00
|
|
|
where
|
2019-09-16 11:08:44 +02:00
|
|
|
TInnerFut: TryFuture<Ok = TIn> + Unpin,
|
2018-11-15 17:41:11 +01:00
|
|
|
TMap: FnOnce(TIn) -> TOut,
|
2018-11-12 17:12:47 +01:00
|
|
|
{
|
2019-09-16 11:08:44 +02:00
|
|
|
type Output = Result<TOut, TInnerFut::Error>;
|
|
|
|
|
|
|
|
fn poll(mut self: Pin<&mut Self>, cx: &mut Context) -> Poll<Self::Output> {
|
|
|
|
let item = match TryFuture::try_poll(Pin::new(&mut self.inner), cx) {
|
|
|
|
Poll::Ready(Ok(v)) => v,
|
|
|
|
Poll::Ready(Err(err)) => return Poll::Ready(Err(err)),
|
|
|
|
Poll::Pending => return Poll::Pending,
|
|
|
|
};
|
2018-11-12 17:12:47 +01:00
|
|
|
|
|
|
|
let map = self.map.take().expect("Future has already finished");
|
2019-09-16 11:08:44 +02:00
|
|
|
Poll::Ready(Ok(map(item)))
|
2018-05-14 15:55:16 +02:00
|
|
|
}
|
|
|
|
}
|
2018-11-15 17:41:11 +01:00
|
|
|
|
|
|
|
pub struct MapErrFuture<T, F> {
|
|
|
|
fut: T,
|
|
|
|
fun: Option<F>,
|
|
|
|
}
|
|
|
|
|
2019-09-16 11:08:44 +02:00
|
|
|
impl<T, F> Unpin for MapErrFuture<T, F> {
|
|
|
|
}
|
|
|
|
|
2018-11-15 17:41:11 +01:00
|
|
|
impl<T, E, F, A> Future for MapErrFuture<T, F>
|
|
|
|
where
|
2019-09-16 11:08:44 +02:00
|
|
|
T: TryFuture<Error = E> + Unpin,
|
2018-11-15 17:41:11 +01:00
|
|
|
F: FnOnce(E) -> A,
|
|
|
|
{
|
2019-09-16 11:08:44 +02:00
|
|
|
type Output = Result<T::Ok, A>;
|
|
|
|
|
|
|
|
fn poll(mut self: Pin<&mut Self>, cx: &mut Context) -> Poll<Self::Output> {
|
|
|
|
match TryFuture::try_poll(Pin::new(&mut self.fut), cx) {
|
|
|
|
Poll::Pending => Poll::Pending,
|
|
|
|
Poll::Ready(Ok(x)) => Poll::Ready(Ok(x)),
|
|
|
|
Poll::Ready(Err(e)) => {
|
2018-11-15 17:41:11 +01:00
|
|
|
let f = self.fun.take().expect("Future has not resolved yet");
|
2019-09-16 11:08:44 +02:00
|
|
|
Poll::Ready(Err(f(e)))
|
2018-11-15 17:41:11 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|