From 1da52b17314c30f9296acc00838eb2bf030fadb7 Mon Sep 17 00:00:00 2001 From: Graydon Hoare Date: Tue, 17 Oct 2023 19:04:44 -0700 Subject: [PATCH] Make ScVal::Validate recursive --- src/curr/scval_validations.rs | 13 ++++++++++++- src/next/scval_validations.rs | 13 ++++++++++++- 2 files changed, 24 insertions(+), 2 deletions(-) diff --git a/src/curr/scval_validations.rs b/src/curr/scval_validations.rs index c7305591..33a82ce2 100644 --- a/src/curr/scval_validations.rs +++ b/src/curr/scval_validations.rs @@ -27,12 +27,18 @@ impl Validate for ScVal { | ScVal::I256(_) | ScVal::Bytes(_) | ScVal::String(_) - | ScVal::Vec(Some(_)) | ScVal::Address(_) | ScVal::LedgerKeyContractInstance | ScVal::LedgerKeyNonce(_) | ScVal::ContractInstance(_) => Ok(()), + ScVal::Vec(Some(v)) => { + for e in v.iter() { + e.validate()? + } + Ok(()) + } + ScVal::Symbol(s) => { // Symbol is defined as valid per https://github.com/stellar/rs-stellar-contract-env/blob/94c1717516c8fad4ad65caa148183b9fcbc408db/stellar-contract-env-common/src/symbol.rs#L107-L111. if s.iter() @@ -53,6 +59,11 @@ impl Validate for ScMap { type Error = Error; fn validate(&self) -> Result<(), Self::Error> { + // Check every element for validity itself. + for pair in self.iter() { + pair.key.validate()?; + pair.val.validate()?; + } // Check the map is sorted by key, and there are no keys that are // duplicates. if self.windows(2).all(|w| w[0].key < w[1].key) { diff --git a/src/next/scval_validations.rs b/src/next/scval_validations.rs index 1f2ec23c..f94d5ad4 100644 --- a/src/next/scval_validations.rs +++ b/src/next/scval_validations.rs @@ -27,12 +27,18 @@ impl Validate for ScVal { | ScVal::I256(_) | ScVal::Bytes(_) | ScVal::String(_) - | ScVal::Vec(Some(_)) | ScVal::Address(_) | ScVal::LedgerKeyContractInstance | ScVal::LedgerKeyNonce(_) | ScVal::ContractInstance(_) => Ok(()), + ScVal::Vec(Some(v)) => { + for e in v.iter() { + e.validate()? + } + Ok(()) + } + ScVal::Symbol(s) => { // Symbol is defined as valid per https://github.com/stellar/rs-stellar-contract-env/blob/94c1717516c8fad4ad65caa148183b9fcbc408db/stellar-contract-env-common/src/symbol.rs#L107-L111. if s.iter() @@ -53,6 +59,11 @@ impl Validate for ScMap { type Error = Error; fn validate(&self) -> Result<(), Self::Error> { + // Check every element for validity itself. + for pair in self.iter() { + pair.key.validate()?; + pair.val.validate()?; + } // Check the map is sorted by key, and there are no keys that are // duplicates. if self.windows(2).all(|w| w[0].key < w[1].key) {