Skip to content

Commit

Permalink
Update rewards manager
Browse files Browse the repository at this point in the history
Modified by: wagerr-builder <[email protected]>

- Fix database functions for stake split threshold and auto combine dust functions
- Rename autocombinerewards to autocombinedust
- Remove change output from autocombinedust
- Cleanup scheduling and initialization
  • Loading branch information
celbalrai authored and watto-engineer committed Dec 30, 2022
1 parent dc60283 commit 4cb673a
Show file tree
Hide file tree
Showing 11 changed files with 77 additions and 37 deletions.
5 changes: 1 addition & 4 deletions src/init.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,6 @@
#include <policy/policy.h>
#include <policy/settings.h>
#include <pos/staking-manager.h>
#include <reward-manager.h>
#include <rpc/blockchain.h>
#include <rpc/register.h>
#include <rpc/server.h>
Expand Down Expand Up @@ -359,7 +358,6 @@ void PrepareShutdown(NodeContext& node)
evoDb.reset();
zerocoinDB.reset();
pTokenDB.reset();
rewardManager.reset();
tokenGroupManager.reset();
}
for (const auto& client : node.chain_clients) {
Expand Down Expand Up @@ -2062,8 +2060,6 @@ bool AppInitMain(const util::Ref& context, NodeContext& node, interfaces::BlockA
pTokenDB.reset(new CTokenDB(0, false, fReset || fReindexChainState));
tokenGroupManager.reset();
tokenGroupManager.reset(new CTokenGroupManager());
rewardManager.reset();
rewardManager.reset(new CRewardManager());
llmq::quorumSnapshotManager.reset();
llmq::quorumSnapshotManager.reset(new llmq::CQuorumSnapshotManager(*evoDb));

Expand Down Expand Up @@ -2382,6 +2378,7 @@ bool AppInitMain(const util::Ref& context, NodeContext& node, interfaces::BlockA
// ********************************************************* Step 10b: setup Staking

g_wallet_init_interface.InitStaking();
g_wallet_init_interface.InitRewardsManagement();

// ********************************************************* Step 10c: Load cache data

Expand Down
37 changes: 26 additions & 11 deletions src/reward-manager.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
std::shared_ptr<CRewardManager> rewardManager;

CRewardManager::CRewardManager() :
fEnableRewardManager(false), fEnableAutoCombineRewards(false), nAutoCombineAmountThreshold(0), nAutoCombineNThreshold(10) {
fEnableRewardManager(false), nAutoCombineNThreshold(10) {
}

bool CRewardManager::IsReady() {
Expand All @@ -36,15 +36,25 @@ bool CRewardManager::IsReady() {
return true;
}

bool CRewardManager::IsCombining()
bool CRewardManager::IsAutoCombineEnabled()
{
return IsReady() && IsAutoCombineEnabled();
bool fEnable;
CAmount nAutoCombineAmountThreshold;
pwallet->GetAutoCombineSettings(fEnable, nAutoCombineAmountThreshold);
return fEnable;
}

void CRewardManager::AutoCombineSettings(bool fEnable, CAmount nAutoCombineAmountThresholdIn) {
LOCK(cs);
fEnableAutoCombineRewards = fEnable;
nAutoCombineAmountThreshold = nAutoCombineAmountThresholdIn;
CAmount CRewardManager::GetAutoCombineThresholdAmount()
{
bool fEnable;
CAmount nAutoCombineAmountThreshold;
pwallet->GetAutoCombineSettings(fEnable, nAutoCombineAmountThreshold);
return nAutoCombineAmountThreshold;
}

bool CRewardManager::IsCombining()
{
return IsReady() && IsAutoCombineEnabled();
}

// TODO: replace with pwallet->FilterCoins()
Expand All @@ -67,7 +77,12 @@ std::map<CTxDestination, std::vector<COutput> > CRewardManager::AvailableCoinsBy
return mapCoins;
}

void CRewardManager::AutoCombineRewards() {
void CRewardManager::AutocombineDust() {
bool fEnable;
CAmount nAutoCombineAmountThreshold;
pwallet->GetAutoCombineSettings(fEnable, nAutoCombineAmountThreshold);
if (!fEnable) return;

std::map<CTxDestination, std::vector<COutput> > mapCoinsByAddress = AvailableCoinsByAddress(true, nAutoCombineAmountThreshold * COIN);

//coins are sectioned by address. This combination code only wants to combine inputs that belong to the same address
Expand Down Expand Up @@ -123,8 +138,8 @@ void CRewardManager::AutoCombineRewards() {
std::vector<CRecipient> vecSend;
int nChangePosRet = -1;
CScript scriptPubKey = GetScriptForDestination(it->first);
// 10% safety margin to avoid "Insufficient funds" errors
CRecipient recipient = {scriptPubKey, nTotalRewardsValue - (nTotalRewardsValue / 10), false};
// Subtract fee from amount
CRecipient recipient = {scriptPubKey, nTotalRewardsValue, true};
vecSend.push_back(recipient);

//Send change to same address
Expand Down Expand Up @@ -169,7 +184,7 @@ void CRewardManager::DoMaintenance(CConnman& connman) {
}

if (IsAutoCombineEnabled()) {
AutoCombineRewards();
AutocombineDust();
int randsleep = GetRandInt(5 * 60 * 1000);
MilliSleep(randsleep); // Sleep between 3 and 8 minutes
}
Expand Down
10 changes: 3 additions & 7 deletions src/reward-manager.h
Original file line number Diff line number Diff line change
Expand Up @@ -33,20 +33,16 @@ class CRewardManager
}

bool fEnableRewardManager;

bool fEnableAutoCombineRewards;
CAmount nAutoCombineAmountThreshold;
uint32_t nAutoCombineNThreshold;

bool IsReady();
bool IsCombining();

bool IsAutoCombineEnabled() { return fEnableAutoCombineRewards; };
CAmount GetAutoCombineThresholdAmount() { return nAutoCombineAmountThreshold; };
void AutoCombineSettings(bool fEnable, CAmount nAutoCombineAmountThresholdIn = 0);
bool IsAutoCombineEnabled();
CAmount GetAutoCombineThresholdAmount();

std::map<CTxDestination, std::vector<COutput> > AvailableCoinsByAddress(bool fConfirmed, CAmount maxCoinValue);
void AutoCombineRewards();
void AutocombineDust();

void DoMaintenance(CConnman& connman);
};
Expand Down
4 changes: 2 additions & 2 deletions src/rpc/client.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -190,8 +190,8 @@ static const CRPCConvertParam vRPCConvertParams[] =
{ "getspecialtxes", 4, "verbosity" },
{ "disconnectnode", 1, "nodeid" },
{ "setstakesplitthreshold", 0, "value" },
{ "autocombinerewards", 0, "enable" },
{ "autocombinerewards", 1, "threshold" },
{ "autocombinedust", 0, "enable" },
{ "autocombinedust", 1, "threshold" },
{ "createrawtokentransaction", 0, "inputs" },
{ "createrawtokentransaction", 1, "outputs" },
{ "createrawtokentransaction", 2, "token_outputs" },
Expand Down
15 changes: 11 additions & 4 deletions src/wallet/init.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@
#include <univalue.h>

#include <pos/staking-manager.h>
#include <reward-manager.h>
#include <scheduler.h>
#include <tokens/rpctokenwallet.h>
#include <util/check.h>
Expand Down Expand Up @@ -46,6 +45,7 @@ class WalletInit : public WalletInitInterface
void AutoLockMasternodeCollaterals() const override;
void InitCoinJoinSettings() const override;
void InitStaking() const override;
void InitRewardsManagement() const override;
bool InitAutoBackup() const override;
};

Expand Down Expand Up @@ -236,9 +236,6 @@ void WalletInit::InitStaking() const
stakingManager = std::shared_ptr<CStakingManager>(new CStakingManager(wallets[0]));
stakingManager->fEnableStaking = gArgs.GetBoolArg("-staking", true);
stakingManager->fEnableWAGERRStaking = gArgs.GetBoolArg("-staking", true);

rewardManager->BindWallet(wallets[0].get());
rewardManager->fEnableRewardManager = true;
}
if (Params().NetworkIDString() == CBaseChainParams::REGTEST) {
stakingManager->fEnableStaking = false;
Expand All @@ -252,6 +249,16 @@ void WalletInit::InitStaking() const
stakingManager->nReserveBalance = nReserveBalance;
}

void WalletInit::InitRewardsManagement() const
{
rewardManager = std::shared_ptr<CRewardManager>(new CRewardManager());
std::vector<std::shared_ptr<CWallet>> wallets = GetWallets();
if (HasWallets() && wallets.size() >= 1) {
rewardManager->BindWallet(wallets[0].get());
rewardManager->fEnableRewardManager = true;
}
}

bool WalletInit::InitAutoBackup() const
{
return CWallet::InitAutoBackup();
Expand Down
10 changes: 5 additions & 5 deletions src/wallet/rpcwallet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -3470,7 +3470,7 @@ UniValue setstakesplitthreshold(const JSONRPCRequest& request)

return result;
}
UniValue autocombinerewards(const JSONRPCRequest& request)
UniValue autocombinedust(const JSONRPCRequest& request)
{
std::shared_ptr<CWallet> const wallet = GetWalletForJSONRPCRequest(request);
CWallet* const pwallet = wallet.get();
Expand All @@ -3486,16 +3486,16 @@ UniValue autocombinerewards(const JSONRPCRequest& request)

if (request.fHelp || nParamsSize < 1 || (!fEnable && nParamsSize > 1) || nParamsSize > 2)
throw std::runtime_error(
"autocombinerewards enable ( threshold )\n"
"autocombinedust enable ( threshold )\n"
"\nWallet will automatically monitor for any coins with value below the threshold amount, and combine them if they reside with the same Wagerr address\n"
"When autocombinerewards runs it will create a transaction, and therefore will be subject to transaction fees.\n"
"When autocombinedust runs it will create a transaction, and therefore will be subject to transaction fees.\n"

"\nArguments:\n"
"1. enable (boolean, required) Enable auto combine (true) or disable (false)\n"
"2. threshold amount (numeric, optional) Coins with an aggregated value of this amount will be combined (default: 0)\n"

"\nExamples:\n" +
HelpExampleCli("autocombinerewards", "true 500") + HelpExampleRpc("autocombinerewards", "true 500"));
HelpExampleCli("autocombinedust", "true 500") + HelpExampleRpc("autocombinedust", "true 500"));

EnsureWalletIsUnlocked(pwallet);

Expand All @@ -3514,7 +3514,6 @@ UniValue autocombinerewards(const JSONRPCRequest& request)
throw std::runtime_error("Changed settings in wallet but failed to save to database\n");
}

rewardManager->AutoCombineSettings(fEnable, nThresholdAmount);

result.push_back(Pair("threshold", int(rewardManager->GetAutoCombineThresholdAmount())));
result.push_back(Pair("enabled", rewardManager->IsAutoCombineEnabled()));
Expand Down Expand Up @@ -4197,6 +4196,7 @@ static const CRPCCommand commands[] =
{ "wallet", "importelectrumwallet", &importelectrumwallet, {"filename", "index"} },
{ "wallet", "getstakingstatus", &getstakingstatus, {} },
{ "wallet", "setstakesplitthreshold", &setstakesplitthreshold, {"value"} },
{ "wallet", "autocombinedust", &autocombinedust, {"enable", "threshold"} },
{ "wallet", "importmulti", &importmulti, {"requests","options"} },
{ "wallet", "importprivkey", &importprivkey, {"privkey","label","rescan"} },
{ "wallet", "importprunedfunds", &importprunedfunds, {"rawtransaction","txoutproof"} },
Expand Down
22 changes: 20 additions & 2 deletions src/wallet/wallet.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1463,7 +1463,10 @@ CAmount CWallet::GetChange(const CTxOut& txout) const
bool CWallet::SetStakeSplitThreshold(uint64_t newThreshold)
{
WalletBatch batch(*database);
return batch.WriteStakeSplitThreshold(newThreshold);
if (!batch.WriteStakeSplitThreshold(newThreshold))
return false;
LoadStakeSplitThreshold(newThreshold);
return true;
}

void CWallet::LoadStakeSplitThreshold(uint64_t newThreshold)
Expand All @@ -1479,7 +1482,22 @@ uint64_t CWallet::GetStakeSplitThreshold()
bool CWallet::SetAutoCombineSettings(bool fEnable, CAmount nCombineThreshold)
{
WalletBatch batch(*database);
return batch.WriteAutoCombineSettings(fEnable, nCombineThreshold);
if (!batch.WriteAutoCombineSettings(fEnable, nCombineThreshold))
return false;
LoadAutoCombineSettings(fEnable, nCombineThreshold);
return true;
}

void CWallet::LoadAutoCombineSettings(bool fEnableIn, CAmount nCombineThresholdIn)
{
fCombineEnable = fEnableIn;
nCombineThreshold = nCombineThresholdIn;
}

void CWallet::GetAutoCombineSettings(bool& fEnableRet, CAmount& nCombineThresholdRet) const
{
fEnableRet = fCombineEnable;
nCombineThresholdRet = nCombineThreshold;
}

bool CWallet::IsMine(const CTransaction& tx) const
Expand Down
4 changes: 4 additions & 0 deletions src/wallet/wallet.h
Original file line number Diff line number Diff line change
Expand Up @@ -818,6 +818,8 @@ class CWallet final : public WalletStorage, public interfaces::Chain::Notificati

// Staking and POS
uint64_t nStakeSplitThreshold = 2000;
CAmount nCombineThreshold = 500;
bool fCombineEnable = false;

/* Height of last block processed is used by wallet to know depth of transactions
* without relying on Chain interface beyond asynchronous updates. For safety, we
Expand Down Expand Up @@ -1273,6 +1275,8 @@ class CWallet final : public WalletStorage, public interfaces::Chain::Notificati
void LoadStakeSplitThreshold(uint64_t newThreshold);
uint64_t GetStakeSplitThreshold();
bool SetAutoCombineSettings(bool fEnable, CAmount nCombineThreshold);
void LoadAutoCombineSettings(bool fEnableIn, CAmount nCombineThresholdIn);
void GetAutoCombineSettings(bool& fEnableRet, CAmount& nCombineThresholdRet) const;

/**
* HD Wallet Functions
Expand Down
5 changes: 4 additions & 1 deletion src/wallet/walletdb.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -506,7 +506,10 @@ ReadKeyValue(CWallet* pwallet, CDataStream& ssKey, CDataStream& ssValue,
{
std::pair<bool, CAmount> pSettings;
ssValue >> pSettings;
rewardManager->AutoCombineSettings(pSettings.first, pSettings.second);
pwallet->LoadAutoCombineSettings(pSettings.first, pSettings.second);
}
else if (strType != "bestblock" && strType != "bestblock_nomerkle"){
wss.m_unknown_records++;
}
} catch (const std::exception& e) {
if (strErr.empty()) {
Expand Down
1 change: 0 additions & 1 deletion src/wallet/walletdb.h
Original file line number Diff line number Diff line change
Expand Up @@ -197,7 +197,6 @@ class WalletBatch
bool WriteMinVersion(int nVersion);

bool WriteStakeSplitThreshold(uint64_t nStakeSplitThreshold);
bool LoadStakeSplitThreshold(uint64_t nStakeSplitThreshold);
bool WriteAutoCombineSettings(bool fEnable, CAmount nCombineThreshold);

bool ReadCoinJoinSalt(uint256& salt, bool fLegacy = false);
Expand Down
1 change: 1 addition & 0 deletions src/walletinitinterface.h
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ class WalletInitInterface {
// Wagerr Specific WalletInitInterface
virtual void AutoLockMasternodeCollaterals() const = 0;
void InitStaking() const override {}
virtual void InitRewardsManagement() const = 0;
virtual void InitCoinJoinSettings() const = 0;
virtual bool InitAutoBackup() const = 0;

Expand Down

0 comments on commit 4cb673a

Please sign in to comment.