mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-31 01:41:03 +00:00
868814e4b6
* fixed PoA contract deploy (granda_authorities call) * pause if all submitted headers were rejected * give funds to Bertha and Carlos * max 1 active PoA transaction in headers sync :( * display initial header id when deploying PoA contract * cargo fmt + clipy * update PoA contract to accept <= 4 Substrate headers at once * pause submitting headers when contract rejects all new headers + we have active transactions * fix compilation * cargo fmt --all * does_not_select_new_headers_to_submit_when_submit_is_paused * updated bridge contract * Update relays/ethereum/src/sync.rs Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com> * WiP. * Submit first incomplete header. * Finish up test. * cargo fmt --all * Remove redundant clone. * Address review comments. * cargo fmt --all * Fix clippy. Co-authored-by: Hernando Castano <HCastano@users.noreply.github.com> Co-authored-by: Tomasz Drwięga <tomasz@parity.io>
137 lines
4.0 KiB
Rust
137 lines
4.0 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/>.
|
|
|
|
use crate::utils::MaybeConnectionError;
|
|
|
|
use jsonrpsee::client::RequestError;
|
|
|
|
/// Contains common errors that can occur when
|
|
/// interacting with a Substrate or Ethereum node
|
|
/// through RPC.
|
|
#[derive(Debug)]
|
|
pub enum RpcError {
|
|
/// The arguments to the RPC method failed to serialize.
|
|
Serialization(serde_json::Error),
|
|
/// An error occured when interacting with an Ethereum node.
|
|
Ethereum(EthereumNodeError),
|
|
/// An error occured when interacting with a Substrate node.
|
|
Substrate(SubstrateNodeError),
|
|
/// An error that can occur when making an HTTP request to
|
|
/// an JSON-RPC client.
|
|
Request(RequestError),
|
|
}
|
|
|
|
impl From<RpcError> for String {
|
|
fn from(err: RpcError) -> Self {
|
|
match err {
|
|
RpcError::Serialization(e) => e.to_string(),
|
|
RpcError::Ethereum(e) => e.to_string(),
|
|
RpcError::Substrate(e) => e.to_string(),
|
|
RpcError::Request(e) => e.to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl From<serde_json::Error> for RpcError {
|
|
fn from(err: serde_json::Error) -> Self {
|
|
Self::Serialization(err)
|
|
}
|
|
}
|
|
|
|
impl From<EthereumNodeError> for RpcError {
|
|
fn from(err: EthereumNodeError) -> Self {
|
|
Self::Ethereum(err)
|
|
}
|
|
}
|
|
|
|
impl From<SubstrateNodeError> for RpcError {
|
|
fn from(err: SubstrateNodeError) -> Self {
|
|
Self::Substrate(err)
|
|
}
|
|
}
|
|
|
|
impl From<RequestError> for RpcError {
|
|
fn from(err: RequestError) -> Self {
|
|
Self::Request(err)
|
|
}
|
|
}
|
|
|
|
impl From<ethabi::Error> for RpcError {
|
|
fn from(err: ethabi::Error) -> Self {
|
|
Self::Ethereum(EthereumNodeError::ResponseParseFailed(format!("{}", err)))
|
|
}
|
|
}
|
|
|
|
impl MaybeConnectionError for RpcError {
|
|
fn is_connection_error(&self) -> bool {
|
|
matches!(*self, RpcError::Request(RequestError::TransportError(_)))
|
|
}
|
|
}
|
|
|
|
impl From<codec::Error> for RpcError {
|
|
fn from(err: codec::Error) -> Self {
|
|
Self::Substrate(SubstrateNodeError::Decoding(err))
|
|
}
|
|
}
|
|
|
|
/// Errors that can occur only when interacting with
|
|
/// an Ethereum node through RPC.
|
|
#[derive(Debug)]
|
|
pub enum EthereumNodeError {
|
|
/// Failed to parse response.
|
|
ResponseParseFailed(String),
|
|
/// We have received a header with missing fields.
|
|
IncompleteHeader,
|
|
/// We have received a transaction missing a `raw` field.
|
|
IncompleteTransaction,
|
|
/// An invalid Substrate block number was received from
|
|
/// an Ethereum node.
|
|
InvalidSubstrateBlockNumber,
|
|
/// An invalid index has been received from an Ethereum node.
|
|
InvalidIncompleteIndex,
|
|
}
|
|
|
|
impl ToString for EthereumNodeError {
|
|
fn to_string(&self) -> String {
|
|
match self {
|
|
Self::ResponseParseFailed(e) => e.to_string(),
|
|
Self::IncompleteHeader => {
|
|
"Incomplete Ethereum Header Received (missing some of required fields - hash, number, logs_bloom)"
|
|
.to_string()
|
|
}
|
|
Self::IncompleteTransaction => "Incomplete Ethereum Transaction (missing required field - raw)".to_string(),
|
|
Self::InvalidSubstrateBlockNumber => "Received an invalid Substrate block from Ethereum Node".to_string(),
|
|
Self::InvalidIncompleteIndex => "Received an invalid incomplete index from Ethereum Node".to_string(),
|
|
}
|
|
}
|
|
}
|
|
|
|
/// Errors that can occur only when interacting with
|
|
/// a Substrate node through RPC.
|
|
#[derive(Debug)]
|
|
pub enum SubstrateNodeError {
|
|
/// The response from the client could not be SCALE decoded.
|
|
Decoding(codec::Error),
|
|
}
|
|
|
|
impl ToString for SubstrateNodeError {
|
|
fn to_string(&self) -> String {
|
|
match self {
|
|
Self::Decoding(e) => e.what().to_string(),
|
|
}
|
|
}
|
|
}
|