mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 19:51:02 +00:00
23f5f3cdd6
* limit messages in the batch by weight/count * fixed components compilation * reverted obsolete parts of #469 * implement generated_messages_weights * actually use computed weight in message proof * fmt and clippy * fixed TODO * clippy * Update relays/messages-relay/src/message_race_loop.rs Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com> * add issue reference * add assert message * grumbles * fmt * reexport weight from bp-message-lane Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com> Co-authored-by: Hernando Castano <castano.ha@gmail.com>
78 lines
2.3 KiB
Rust
78 lines
2.3 KiB
Rust
// Copyright 2019-2020 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Bridges Common.
|
|
|
|
// Parity Bridges Common is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity Bridges Common is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Substrate node RPC errors.
|
|
|
|
use jsonrpsee::client::RequestError;
|
|
use jsonrpsee::transport::ws::WsNewDnsError;
|
|
use relay_utils::MaybeConnectionError;
|
|
|
|
/// Result type used by Substrate client.
|
|
pub type Result<T> = std::result::Result<T, Error>;
|
|
|
|
/// Errors that can occur only when interacting with
|
|
/// a Substrate node through RPC.
|
|
#[derive(Debug)]
|
|
pub enum Error {
|
|
/// Web socket connection error.
|
|
WsConnectionError(WsNewDnsError),
|
|
/// An error that can occur when making a request to
|
|
/// an JSON-RPC server.
|
|
Request(RequestError),
|
|
/// The response from the server could not be SCALE decoded.
|
|
ResponseParseFailed(codec::Error),
|
|
/// Account does not exist on the chain.
|
|
AccountDoesNotExist,
|
|
/// Custom logic error.
|
|
Custom(String),
|
|
}
|
|
|
|
impl From<WsNewDnsError> for Error {
|
|
fn from(error: WsNewDnsError) -> Self {
|
|
Error::WsConnectionError(error)
|
|
}
|
|
}
|
|
|
|
impl From<RequestError> for Error {
|
|
fn from(error: RequestError) -> Self {
|
|
Error::Request(error)
|
|
}
|
|
}
|
|
|
|
impl MaybeConnectionError for Error {
|
|
fn is_connection_error(&self) -> bool {
|
|
matches!(*self, Error::Request(RequestError::TransportError(_)))
|
|
}
|
|
}
|
|
|
|
impl From<Error> for String {
|
|
fn from(error: Error) -> String {
|
|
error.to_string()
|
|
}
|
|
}
|
|
|
|
impl ToString for Error {
|
|
fn to_string(&self) -> String {
|
|
match self {
|
|
Self::WsConnectionError(e) => e.to_string(),
|
|
Self::Request(e) => e.to_string(),
|
|
Self::ResponseParseFailed(e) => e.what().to_string(),
|
|
Self::AccountDoesNotExist => "Account does not exist on the chain".into(),
|
|
Self::Custom(e) => e.clone(),
|
|
}
|
|
}
|
|
}
|