use crate::config::TransportConfig;
use libp2p::{PeerId, Multiaddr};
use std::{borrow::Cow, fmt};
pub type Result<T> = std::result::Result<T, Error>;
#[derive(derive_more::Display, derive_more::From)]
pub enum Error {
Io(std::io::Error),
Client(Box<sp_blockchain::Error>),
#[display(
fmt = "The same bootnode (`{}`) is registered with two different peer ids: `{}` and `{}`",
address,
first_id,
second_id,
)]
DuplicateBootnode {
address: Multiaddr,
first_id: PeerId,
second_id: PeerId,
},
Prometheus(prometheus_endpoint::PrometheusError),
#[display(
fmt = "The following addresses are invalid because they don't match the transport: {:?}",
addresses,
)]
AddressesForAnotherTransport {
transport: TransportConfig,
addresses: Vec<Multiaddr>,
},
#[display(fmt = "Request-response protocol registered multiple times: {}", protocol)]
DuplicateRequestResponseProtocol {
protocol: Cow<'static, str>,
},
}
impl fmt::Debug for Error {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
fmt::Display::fmt(self, f)
}
}
impl std::error::Error for Error {
fn source(&self) -> Option<&(dyn std::error::Error + 'static)> {
match self {
Error::Io(ref err) => Some(err),
Error::Client(ref err) => Some(err),
Error::DuplicateBootnode { .. } => None,
Error::Prometheus(ref err) => Some(err),
Error::AddressesForAnotherTransport { .. } => None,
Error::DuplicateRequestResponseProtocol { .. } => None,
}
}
}