From b63cde64297409c5a73663dff322f23e6cddc2bc Mon Sep 17 00:00:00 2001 From: Anthony Fieroni Date: Fri, 18 Mar 2022 08:35:36 +0200 Subject: [PATCH] Calculate collateral ratio when there is actual price update Signed-off-by: Anthony Fieroni --- src/validation.cpp | 36 +++++++++++++++++++++++++++++------- 1 file changed, 29 insertions(+), 7 deletions(-) diff --git a/src/validation.cpp b/src/validation.cpp index 87fbdad52b..6cf84bb5ca 100644 --- a/src/validation.cpp +++ b/src/validation.cpp @@ -3106,11 +3106,17 @@ void CChainState::ProcessLoanEvents(const CBlockIndex* pindex, CCustomCSView& ca viewCache.Flush(); } - if (pindex->nHeight % chainparams.GetConsensus().blocksCollateralizationRatioCalculation() == 0) { + static const auto calculationBlock = chainparams.GetConsensus().blocksCollateralizationRatioCalculation(); + + // non consensus enforced + static bool firstRun = true; + static std::vector liquidatedVaults; + + if (pindex->nHeight % calculationBlock == 0) { bool useNextPrice = false, requireLivePrice = true; LogPrint(BCLog::LOAN,"ProcessLoanEvents()->ForEachVaultCollateral():\n"); /* Continued */ - cache.ForEachVaultCollateral([&](const CVaultId& vaultId, const CBalances& collaterals) { + auto processVault = [&](const CVaultId& vaultId, const CBalances& collaterals) { auto collateral = cache.GetLoanCollaterals(vaultId, collaterals, pindex->nHeight, pindex->nTime, useNextPrice, requireLivePrice); if (!collateral) { return true; @@ -3190,7 +3196,20 @@ void CChainState::ProcessLoanEvents(const CBlockIndex* pindex, CCustomCSView& ca } return true; - }); + }; + + auto lastPriceUpdate = pindex->nHeight - (pindex->nHeight % cache.GetIntervalBlock()); + if (firstRun || lastPriceUpdate > pindex->nHeight - calculationBlock) { + cache.ForEachVaultCollateral(processVault); + } else { + for (const auto& vaultId : liquidatedVaults) { + if (auto collaterals = cache.GetVaultCollaterals(vaultId)) { + processVault(vaultId, *collaterals); + } + } + } + firstRun = false; + liquidatedVaults.clear(); } CHistoryWriters writers{nullptr, pburnHistoryDB.get(), pvaultHistoryDB.get()}; @@ -3269,6 +3288,8 @@ void CChainState::ProcessLoanEvents(const CBlockIndex* pindex, CCustomCSView& ca view.StoreVault(vaultId, *vault); view.EraseAuction(vaultId, pindex->nHeight); + liquidatedVaults.push_back(vaultId); + // Store state in vault DB if (pvaultHistoryDB) { pvaultHistoryDB->WriteVaultState(view, *pindex, vaultId); @@ -3306,20 +3327,21 @@ void CChainState::ProcessOracleEvents(const CBlockIndex* pindex, CCustomCSView& // Furthermore, the time stamp is always indicative of the // last price time. - auto nextPrice = fixedIntervalPrice.priceRecord[1]; + auto& nextPrice = fixedIntervalPrice.priceRecord[1]; if (nextPrice > 0) { - fixedIntervalPrice.priceRecord[0] = fixedIntervalPrice.priceRecord[1]; + auto& currentPrice = fixedIntervalPrice.priceRecord[0]; + currentPrice = nextPrice; } // keep timestamp updated fixedIntervalPrice.timestamp = pindex->nTime; // Use -1 to indicate empty price - fixedIntervalPrice.priceRecord[1] = -1; + nextPrice = -1; auto aggregatePrice = GetAggregatePrice(cache, fixedIntervalPrice.priceFeedId.first, fixedIntervalPrice.priceFeedId.second, pindex->nTime); if (aggregatePrice) { - fixedIntervalPrice.priceRecord[1] = aggregatePrice; + nextPrice = aggregatePrice; } else { LogPrint(BCLog::ORACLE,"ProcessOracleEvents(): No aggregate price available: %s\n", aggregatePrice.msg); }