2019-01-07 11:33:07 +01:00
|
|
|
// Copyright 2015-2019 Parity Technologies (UK) Ltd.
|
|
|
|
// This file is part of Parity Ethereum.
|
2016-09-06 15:31:13 +02:00
|
|
|
|
2019-01-07 11:33:07 +01:00
|
|
|
// Parity Ethereum is free software: you can redistribute it and/or modify
|
2016-09-06 15:31:13 +02:00
|
|
|
// 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.
|
|
|
|
|
2019-01-07 11:33:07 +01:00
|
|
|
// Parity Ethereum is distributed in the hope that it will be useful,
|
2016-09-06 15:31:13 +02:00
|
|
|
// 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
|
2019-01-07 11:33:07 +01:00
|
|
|
// along with Parity Ethereum. If not, see <http://www.gnu.org/licenses/>.
|
2016-09-06 15:31:13 +02:00
|
|
|
|
|
|
|
//! Snapshot manifest type definition
|
|
|
|
|
2018-01-10 13:35:18 +01:00
|
|
|
use ethereum_types::H256;
|
2018-04-16 15:52:12 +02:00
|
|
|
use rlp::{Rlp, RlpStream, DecoderError};
|
2017-09-06 20:47:45 +02:00
|
|
|
use bytes::Bytes;
|
2016-09-06 15:31:13 +02:00
|
|
|
|
|
|
|
/// Manifest data.
|
2016-12-21 15:09:35 +01:00
|
|
|
#[derive(Debug, Clone, PartialEq, Eq)]
|
2016-09-06 15:31:13 +02:00
|
|
|
pub struct ManifestData {
|
2017-03-24 14:02:04 +01:00
|
|
|
/// Snapshot format version.
|
|
|
|
pub version: u64,
|
2016-09-06 15:31:13 +02:00
|
|
|
/// List of state chunk hashes.
|
|
|
|
pub state_hashes: Vec<H256>,
|
|
|
|
/// List of block chunk hashes.
|
|
|
|
pub block_hashes: Vec<H256>,
|
|
|
|
/// The final, expected state root.
|
|
|
|
pub state_root: H256,
|
|
|
|
/// Block number this snapshot was taken at.
|
|
|
|
pub block_number: u64,
|
|
|
|
/// Block hash this snapshot was taken at.
|
|
|
|
pub block_hash: H256,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl ManifestData {
|
|
|
|
/// Encode the manifest data to rlp.
|
|
|
|
pub fn into_rlp(self) -> Bytes {
|
2017-03-24 14:02:04 +01:00
|
|
|
let mut stream = RlpStream::new_list(6);
|
|
|
|
stream.append(&self.version);
|
2017-03-20 19:14:29 +01:00
|
|
|
stream.append_list(&self.state_hashes);
|
|
|
|
stream.append_list(&self.block_hashes);
|
2016-09-06 15:31:13 +02:00
|
|
|
stream.append(&self.state_root);
|
|
|
|
stream.append(&self.block_number);
|
|
|
|
stream.append(&self.block_hash);
|
|
|
|
|
|
|
|
stream.out()
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Try to restore manifest data from raw bytes, interpreted as RLP.
|
|
|
|
pub fn from_rlp(raw: &[u8]) -> Result<Self, DecoderError> {
|
2018-04-16 15:52:12 +02:00
|
|
|
let decoder = Rlp::new(raw);
|
2017-03-24 14:02:04 +01:00
|
|
|
let (start, version) = if decoder.item_count()? == 5 {
|
|
|
|
(0, 1)
|
|
|
|
} else {
|
|
|
|
(1, decoder.val_at(0)?)
|
|
|
|
};
|
2016-09-06 15:31:13 +02:00
|
|
|
|
2017-03-24 14:02:04 +01:00
|
|
|
let state_hashes: Vec<H256> = decoder.list_at(start + 0)?;
|
|
|
|
let block_hashes: Vec<H256> = decoder.list_at(start + 1)?;
|
|
|
|
let state_root: H256 = decoder.val_at(start + 2)?;
|
|
|
|
let block_number: u64 = decoder.val_at(start + 3)?;
|
|
|
|
let block_hash: H256 = decoder.val_at(start + 4)?;
|
2016-09-06 15:31:13 +02:00
|
|
|
|
|
|
|
Ok(ManifestData {
|
2017-03-24 14:02:04 +01:00
|
|
|
version: version,
|
2016-09-06 15:31:13 +02:00
|
|
|
state_hashes: state_hashes,
|
|
|
|
block_hashes: block_hashes,
|
|
|
|
state_root: state_root,
|
|
|
|
block_number: block_number,
|
|
|
|
block_hash: block_hash,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|