// Copyright 2021 Parity Technologies (UK) Ltd. // This file is part of Polkadot. // Polkadot 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. // Polkadot 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 Polkadot. If not, see . // //! Error handling related code and Error/Result definitions. use polkadot_node_primitives::UncheckedSignedFullStatement; use polkadot_subsystem::SubsystemError; use thiserror::Error; use polkadot_node_subsystem_util::{Fault, runtime, unwrap_non_fatal}; use crate::LOG_TARGET; /// General result. pub type Result = std::result::Result; /// Result for fatal only failures. pub type FatalResult = std::result::Result; /// Errors for statement distribution. #[derive(Debug, Error)] #[error(transparent)] pub struct Error(pub Fault); impl From for Error { fn from(e: NonFatal) -> Self { Self(Fault::from_non_fatal(e)) } } impl From for Error { fn from(f: Fatal) -> Self { Self(Fault::from_fatal(f)) } } impl From for Error { fn from(o: runtime::Error) -> Self { Self(Fault::from_other(o)) } } /// Fatal runtime errors. #[derive(Debug, Error)] pub enum Fatal { /// Receiving subsystem message from overseer failed. #[error("Receiving message from overseer failed")] SubsystemReceive(#[source] SubsystemError), /// Errors coming from runtime::Runtime. #[error("Error while accessing runtime information")] Runtime(#[from] #[source] runtime::Fatal), } /// Errors for fetching of runtime information. #[derive(Debug, Error)] pub enum NonFatal { /// Signature was invalid on received statement. #[error("CollationSeconded contained statement with invalid signature.")] InvalidStatementSignature(UncheckedSignedFullStatement), /// Errors coming from runtime::Runtime. #[error("Error while accessing runtime information")] Runtime(#[from] #[source] runtime::NonFatal), } /// Utility for eating top level errors and log them. /// /// We basically always want to try and continue on error. This utility function is meant to /// consume top-level errors by simply logging them. pub fn log_error(result: Result<()>, ctx: &'static str) -> FatalResult<()> { if let Some(error) = unwrap_non_fatal(result.map_err(|e| e.0))? { tracing::warn!(target: LOG_TARGET, error = ?error, ctx) } Ok(()) }