From 4b4336832573fe8120d69bbef3d2277afaf41a0e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pablo=20Andr=C3=A9s=20Dorado=20Su=C3=A1rez?= Date: Fri, 13 Dec 2024 11:43:42 -0500 Subject: [PATCH] fix(fc-traits-gas-tank): return `DispatchResult` when calling `make_tank` to catch on attribute setting errors --- traits/gas-tank/src/impl_nonfungibles.rs | 10 +++++----- traits/gas-tank/src/lib.rs | 3 ++- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/traits/gas-tank/src/impl_nonfungibles.rs b/traits/gas-tank/src/impl_nonfungibles.rs index 3b7300c..212ff14 100644 --- a/traits/gas-tank/src/impl_nonfungibles.rs +++ b/traits/gas-tank/src/impl_nonfungibles.rs @@ -41,11 +41,11 @@ where F::typed_system_attribute(collection_id, Some(item_id), &ATTR_MEMBERSHIP_GAS) } - fn put(&self, collection_id: &F::CollectionId, item_id: &F::ItemId) -> Option<()> + fn put(&self, collection_id: &F::CollectionId, item_id: &F::ItemId) -> DispatchResult where F: nonfungibles_v2::Inspect + nonfungibles_v2::Mutate, { - F::set_typed_attribute(collection_id, item_id, &ATTR_MEMBERSHIP_GAS, self).ok() + F::set_typed_attribute(collection_id, item_id, &ATTR_MEMBERSHIP_GAS, self) } } @@ -92,7 +92,7 @@ where if block_number.checked_sub(&tank.since)? > period { tank.since = block_number.checked_add(&period)?; tank.used = Weight::zero(); - tank.put::(&collection, &item)?; + tank.put::(&collection, &item).ok()?; }; let remaining = capacity.checked_sub(&tank.used.checked_add(estimated)?)?; @@ -127,7 +127,7 @@ where tank.used = tank.used.checked_add(used)?; } - tank.put::(&collection, &item)?; + tank.put::(&collection, &item).ok()?; let max_weight = tank.capacity_per_period?; Some(max_weight.saturating_sub(tank.used)) @@ -190,7 +190,7 @@ where (collection_id, item_id): &Self::TankId, capacity: Option, periodicity: Option, - ) -> Option<()> { + ) -> DispatchResult { WeightTank::::new(capacity, periodicity).put::(collection_id, item_id) } } diff --git a/traits/gas-tank/src/lib.rs b/traits/gas-tank/src/lib.rs index 1c82307..e0196a4 100644 --- a/traits/gas-tank/src/lib.rs +++ b/traits/gas-tank/src/lib.rs @@ -2,6 +2,7 @@ use frame_support::Parameter; use sp_runtime::traits::BlockNumber; +use sp_runtime::DispatchResult; #[cfg(test)] mod tests; @@ -52,5 +53,5 @@ pub trait MakeTank { id: &Self::TankId, capacity: Option, periodicity: Option, - ) -> Option<()>; + ) -> DispatchResult; }