diff --git a/src/Makefile.am b/src/Makefile.am index b926fa8c9e..492097361b 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -166,7 +166,6 @@ DEFI_CORE_H = \ masternodes/mn_checks.h \ masternodes/mn_rpc.h \ masternodes/res.h \ - masternodes/rewardhistoryold.h \ masternodes/tokens.h \ masternodes/poolpairs.h \ masternodes/undo.h \ diff --git a/src/flushablestorage.h b/src/flushablestorage.h index 631de1065f..86aac31155 100644 --- a/src/flushablestorage.h +++ b/src/flushablestorage.h @@ -146,6 +146,9 @@ class CStorageLevelDB : public CStorageKV { std::unique_ptr NewIterator() override { return MakeUnique(std::unique_ptr(db.NewIterator())); } + bool IsEmpty() { + return db.IsEmpty(); + } private: CDBWrapper db; diff --git a/src/init.cpp b/src/init.cpp index bb26a4981d..be41cafcf8 100644 --- a/src/init.cpp +++ b/src/init.cpp @@ -1587,13 +1587,16 @@ bool AppInitMain(InitInterfaces& interfaces) pcustomcsDB = MakeUnique(GetDataDir() / "enhancedcs", nDefaultDbCache << 20, false, fReset || fReindexChainState); pcustomcsview.reset(); pcustomcsview = MakeUnique(*pcustomcsDB.get()); - if (!fReset && gArgs.GetBoolArg("-acindex", DEFAULT_ACINDEX)) { - if (shouldMigrateOldRewardHistory(*pcustomcsview)) { - strLoadError = _("Account history needs rebuild").translated; + if (!fReset && !fReindexChainState) { + if (!pcustomcsDB->IsEmpty() && pcustomcsview->GetDbVersion() != CCustomCSView::DbVersion) { + strLoadError = _("Account database is unsuitable").translated; break; } } + // Ensure we are on latest DB version + pcustomcsview->SetDbVersion(CCustomCSView::DbVersion); + panchorauths.reset(); panchorauths = MakeUnique(); panchorAwaitingConfirms.reset(); diff --git a/src/masternodes/accountshistory.cpp b/src/masternodes/accountshistory.cpp index 59a8de23c1..3880f2e44c 100644 --- a/src/masternodes/accountshistory.cpp +++ b/src/masternodes/accountshistory.cpp @@ -5,7 +5,6 @@ #include #include #include -#include #include #include @@ -23,27 +22,3 @@ Res CAccountsHistoryView::SetAccountHistory(const AccountHistoryKey& key, const WriteBy(key, value); return Res::Ok(); } - -bool shouldMigrateOldRewardHistory(CCustomCSView & view) -{ - auto it = view.GetRaw().NewIterator(); - try { - auto prefix = oldRewardHistoryPrefix; - auto oldKey = std::make_pair(prefix, oldRewardHistoryKey{}); - it->Seek(DbTypeToBytes(oldKey)); - if (it->Valid() && BytesToDbType(it->Key(), oldKey) && oldKey.first == prefix) { - return true; - } - bool hasOldAccountHistory = false; - view.ForEachAccountHistory([&](AccountHistoryKey const & key, CLazySerialize) { - if (key.txn == std::numeric_limits::max()) { - hasOldAccountHistory = true; - return false; - } - return true; - }, { {}, 0, std::numeric_limits::max() }); - return hasOldAccountHistory; - } catch(...) { - return true; - } -} diff --git a/src/masternodes/accountshistory.h b/src/masternodes/accountshistory.h index ab40475da3..13005cb7c4 100644 --- a/src/masternodes/accountshistory.h +++ b/src/masternodes/accountshistory.h @@ -64,7 +64,4 @@ class CAccountsHistoryView : public virtual CStorageView static constexpr bool DEFAULT_ACINDEX = true; -class CCustomCSView; -bool shouldMigrateOldRewardHistory(CCustomCSView & view); - #endif //DEFI_MASTERNODES_ACCOUNTSHISTORY_H diff --git a/src/masternodes/masternodes.cpp b/src/masternodes/masternodes.cpp index 250df66c21..55aede0cf8 100644 --- a/src/masternodes/masternodes.cpp +++ b/src/masternodes/masternodes.cpp @@ -27,6 +27,7 @@ const unsigned char DB_MN_OPERATORS = 'o'; // masternodes' operators index const unsigned char DB_MN_OWNERS = 'w'; // masternodes' owners index const unsigned char DB_MN_STAKER = 'X'; // masternodes' last staked block time const unsigned char DB_MN_HEIGHT = 'H'; // single record with last processed chain height +const unsigned char DB_MN_VERSION = 'D'; const unsigned char DB_MN_ANCHOR_REWARD = 'r'; const unsigned char DB_MN_ANCHOR_CONFIRM = 'x'; const unsigned char DB_MN_CURRENT_TEAM = 't'; @@ -604,6 +605,19 @@ std::vector CAnchorConfirmsView::GetAnchorConfirmData() /* * CCustomCSView */ +int CCustomCSView::GetDbVersion() const +{ + int version; + if (Read(DB_MN_VERSION, version)) + return version; + return 0; +} + +void CCustomCSView::SetDbVersion(int version) +{ + Write(DB_MN_VERSION, version); +} + CTeamView::CTeam CCustomCSView::CalcNextTeam(const uint256 & stakeModifier) { if (stakeModifier == uint256()) diff --git a/src/masternodes/masternodes.h b/src/masternodes/masternodes.h index 9d0c93b04c..daddf85839 100644 --- a/src/masternodes/masternodes.h +++ b/src/masternodes/masternodes.h @@ -225,6 +225,9 @@ class CCustomCSView , public CAnchorConfirmsView { public: + // Increase version when underlaying tables are changed + static constexpr const int DbVersion = 1; + CCustomCSView() = default; CCustomCSView(CStorageKV & st) @@ -251,6 +254,10 @@ class CCustomCSView bool CalculateOwnerRewards(CScript const & owner, uint32_t height); + void SetDbVersion(int version); + + int GetDbVersion() const; + CStorageKV& GetRaw() { return DB(); } diff --git a/src/masternodes/rewardhistoryold.h b/src/masternodes/rewardhistoryold.h deleted file mode 100644 index 42dfe5461c..0000000000 --- a/src/masternodes/rewardhistoryold.h +++ /dev/null @@ -1,38 +0,0 @@ -// Copyright (c) DeFi Blockchain Developers -// Distributed under the MIT software license, see the accompanying -// file LICENSE or http://www.opensource.org/licenses/mit-license.php. - -#ifndef DEFI_MASTERNODES_REWARDHISTORYOLD_H -#define DEFI_MASTERNODES_REWARDHISTORYOLD_H - -#include -#include -#include