Skip to content

Commit

Permalink
Fix orphan handling, not related to current head. Fixes #412
Browse files Browse the repository at this point in the history
  • Loading branch information
ignopeverell committed Dec 1, 2017
1 parent 06f3c7e commit 87f2e1c
Showing 1 changed file with 9 additions and 7 deletions.
16 changes: 9 additions & 7 deletions chain/src/pipe.rs
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ use core::core::hash::{Hash, Hashed};
use core::core::{Block, BlockHeader};
use core::core::target::Difficulty;
use core::core::transaction;
use grin_store;
use types::*;
use store;
use sumtree;
Expand Down Expand Up @@ -132,9 +133,6 @@ fn check_known(bh: Hash, ctx: &mut BlockContext) -> Result<(), Error> {
/// arranged by order of cost to have as little DoS surface as possible.
/// TODO require only the block header (with length information)
fn validate_header(header: &BlockHeader, ctx: &mut BlockContext) -> Result<(), Error> {
if header.height > ctx.head.height + 1 {
return Err(Error::Orphan);
}

// check version, enforces scheduled hard fork
if !consensus::valid_header_version(header.height, header.version) {
Expand Down Expand Up @@ -164,16 +162,20 @@ fn validate_header(header: &BlockHeader, ctx: &mut BlockContext) -> Result<(), E
}

// first I/O cost, better as late as possible
let prev = try!(ctx.store.get_block_header(&header.previous,).map_err(|e| {
Error::StoreErr(e, format!("previous block header {}", header.previous))
},));
let prev = match ctx.store.get_block_header(&header.previous) {
Ok(prev) => Ok(prev),
Err(grin_store::Error::NotFoundErr) => Err(Error::Orphan),
Err(e) =>{
Err(Error::StoreErr(e, format!("previous header {}", header.previous)))
}
}?;

if header.height != prev.height + 1 {
return Err(Error::InvalidBlockHeight);
}
if header.timestamp <= prev.timestamp && !global::is_automated_testing_mode() {
// prevent time warp attacks and some timestamp manipulations by forcing strict
// time progression (but not in CI mode)
// time progression (but not in CI mode)
return Err(Error::InvalidBlockTime);
}

Expand Down

0 comments on commit 87f2e1c

Please sign in to comment.