From 095ac50ba72f89c70896205e37ca3810cba30fb3 Mon Sep 17 00:00:00 2001 From: Luke Parker Date: Tue, 5 Dec 2023 10:34:20 -0500 Subject: [PATCH] Correct div by 0 I introduced --- substrate/dex/pallet/src/lib.rs | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/substrate/dex/pallet/src/lib.rs b/substrate/dex/pallet/src/lib.rs index ebbc2b05..099a9985 100644 --- a/substrate/dex/pallet/src/lib.rs +++ b/substrate/dex/pallet/src/lib.rs @@ -360,10 +360,10 @@ pub mod pallet { for coin in Pools::::iter_keys() { // insert the new price to our oracle window // The spot price for 1 coin, in atomic units, to SRI is used - let pool_id = Self::get_pool_id(coin, Coin::native()).ok().unwrap(); - let pool_account = Self::get_pool_account(pool_id); - let sri_balance = Self::get_balance(&pool_account, Coin::native()); - let coin_balance = Self::get_balance(&pool_account, coin); + let Ok((sri_balance, coin_balance)) = Self::get_reserves(&Coin::native(), &coin) else { + continue; + }; + // We use 1 coin to handle rounding errors which may occur with atomic units // If we used atomic units, any coin whose atomic unit is worth less than SRI's atomic unit // would cause a 'price' of 0 @@ -754,7 +754,7 @@ pub mod pallet { /// Swap coins along a `path`, depositing in `send_to`. pub(crate) fn do_swap( sender: T::AccountId, - amounts: &Vec, + amounts: &[SubstrateAmount], path: BoundedVec, send_to: T::AccountId, ) -> Result<(), DispatchError> {