// Copyright 2019 Parity Technologies (UK) Ltd. // This file is part of Substrate. // // Substrate 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. // // Substrate 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 Substrate. If not, see . //! Block announcement validation. use crate::BlockStatus; use sr_primitives::{generic::BlockId, traits::Block}; use std::{error::Error, sync::Arc}; /// A type which provides access to chain information. pub trait Chain { /// Retrieve the status of the block denoted by the given [`BlockId`]. fn block_status(&self, id: &BlockId) -> Result>; } impl, B: Block> Chain for Arc { fn block_status(&self, id: &BlockId) -> Result> { (&**self).block_status(id) } } /// Result of `BlockAnnounceValidator::validate`. #[derive(Debug, PartialEq, Eq)] pub enum Validation { /// Valid block announcement. Success, /// Invalid block announcement. Failure, } /// Type which checks incoming block announcements. pub trait BlockAnnounceValidator { /// Validate the announced header and its associated data. fn validate(&mut self, header: &B::Header, data: &[u8]) -> Result>; } /// Default implementation of `BlockAnnounceValidator`. #[derive(Debug)] pub struct DefaultBlockAnnounceValidator { chain: C } impl DefaultBlockAnnounceValidator { pub fn new(chain: C) -> Self { Self { chain } } } impl> BlockAnnounceValidator for DefaultBlockAnnounceValidator { fn validate(&mut self, _h: &B::Header, _d: &[u8]) -> Result> { Ok(Validation::Success) } }