From b6d227d1c65e306c7c1b9ffcd2343fc828fd2e09 Mon Sep 17 00:00:00 2001 From: Jordan Date: Tue, 21 Jul 2020 14:05:48 +1200 Subject: [PATCH] Remove extraneous bytes check on input buffer (#68) * Remove extraneous bytes check on input buffer * Keep test, add note --- src/v0/mod.rs | 33 +++++++++++++++------------------ 1 file changed, 15 insertions(+), 18 deletions(-) diff --git a/src/v0/mod.rs b/src/v0/mod.rs index ee446396..d80f98f2 100644 --- a/src/v0/mod.rs +++ b/src/v0/mod.rs @@ -215,20 +215,16 @@ impl Decode for DoughnutV0 { let mut signature = [0_u8; 64]; input.read(&mut signature)?; - if input.read_byte().is_ok() { - Err(codec::Error::from("Doughnut contains unexpected bytes")) - } else { - Ok(Self { - holder, - issuer, - expiry, - not_before, - signature_version, - payload_version, - domains, - signature: H512::from(signature), - }) - } + Ok(Self { + holder, + issuer, + expiry, + not_before, + signature_version, + payload_version, + domains, + signature: H512::from(signature), + }) } } @@ -587,10 +583,11 @@ mod test { let result = DoughnutV0::decode(&mut &encoded[..]); - assert_eq!( - result, - Err(codec::Error::from("Doughnut contains unexpected bytes")) - ); + // This used to be a decoding error. + // It may be desirable for some use cases to fail when encountering extraneous bytes + // as a security precaution. + // TODO: reconcile with https://github.com/cennznet/doughnut-rs/issues/67 + assert!(result.is_ok()); } #[test]