mirror of
https://github.com/dashpay/dash.git
synced 2024-12-26 04:22:55 +01:00
Merge #17579: [refactor] Merge getreceivedby tally into GetReceived function
a1d5b12ec07d2f7aa9fa955a6dd99e8a2be5cb25 Merge getreceivedby tally into GetReceived function (Andrew Toth)
Pull request description:
This PR merges the tally code of `getreceivedbyaddress` and `getreceivedbylabel` into a single function `GetReceived`. This reduces repeated code and makes it similar to `listreceivedbyaddress` and `listreceivedbylabel`, which use the function `ListReceived`. It will also make the change in #14707 simpler and easier to review.
ACKs for top commit:
theStack:
re-ACK a1d5b12ec0
meshcollider:
utACK a1d5b12ec07d2f7aa9fa955a6dd99e8a2be5cb25
Tree-SHA512: 43d9cd92f7c2c6a8b9c7509aa85a9b9233a6cfec1c43a9062e3bdfb83515413d1feafa8938c828351278ba22bd31c47e62ab5341e4bddc2493103b094d73b047
This commit is contained in:
parent
f9e0773a9d
commit
b12b323e60
@ -641,6 +641,54 @@ static UniValue signmessage(const JSONRPCRequest& request)
|
|||||||
return signature;
|
return signature;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static CAmount GetReceived(const CWallet& wallet, const UniValue& params, bool by_label) EXCLUSIVE_LOCKS_REQUIRED(wallet.cs_wallet)
|
||||||
|
{
|
||||||
|
std::set<CTxDestination> address_set;
|
||||||
|
|
||||||
|
if (by_label) {
|
||||||
|
// Get the set of addresses assigned to label
|
||||||
|
std::string label = LabelFromValue(params[0]);
|
||||||
|
address_set = wallet.GetLabelAddresses(label);
|
||||||
|
} else {
|
||||||
|
// Get the address
|
||||||
|
CTxDestination dest = DecodeDestination(params[0].get_str());
|
||||||
|
if (!IsValidDestination(dest)) {
|
||||||
|
throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Invalid Dash address");
|
||||||
|
}
|
||||||
|
CScript script_pub_key = GetScriptForDestination(dest);
|
||||||
|
if (!wallet.IsMine(script_pub_key)) {
|
||||||
|
throw JSONRPCError(RPC_WALLET_ERROR, "Address not found in wallet");
|
||||||
|
}
|
||||||
|
address_set.insert(dest);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Minimum confirmations
|
||||||
|
int min_depth = 1;
|
||||||
|
if (!params[1].isNull())
|
||||||
|
min_depth = params[1].get_int();
|
||||||
|
|
||||||
|
bool fAddLocked = (!params[2].isNull() && params[2].get_bool());
|
||||||
|
// Tally
|
||||||
|
CAmount amount = 0;
|
||||||
|
for (const std::pair<const uint256, CWalletTx>& wtx_pair : wallet.mapWallet) {
|
||||||
|
const CWalletTx& wtx = wtx_pair.second;
|
||||||
|
if (wtx.IsCoinBase() || !wallet.chain().checkFinalTx(*wtx.tx)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (wtx.GetDepthInMainChain() < min_depth && !(fAddLocked && wtx.IsLockedByInstantSend())) continue;
|
||||||
|
|
||||||
|
for (const CTxOut& txout : wtx.tx->vout) {
|
||||||
|
CTxDestination address;
|
||||||
|
if (ExtractDestination(txout.scriptPubKey, address) && wallet.IsMine(address) && address_set.count(address)) {
|
||||||
|
amount += txout.nValue;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return amount;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static UniValue getreceivedbyaddress(const JSONRPCRequest& request)
|
static UniValue getreceivedbyaddress(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
RPCHelpMan{"getreceivedbyaddress",
|
RPCHelpMan{"getreceivedbyaddress",
|
||||||
@ -675,37 +723,7 @@ static UniValue getreceivedbyaddress(const JSONRPCRequest& request)
|
|||||||
|
|
||||||
LOCK(pwallet->cs_wallet);
|
LOCK(pwallet->cs_wallet);
|
||||||
|
|
||||||
// Dash address
|
return ValueFromAmount(GetReceived(*pwallet, request.params, /* by_label */ false));
|
||||||
CTxDestination dest = DecodeDestination(request.params[0].get_str());
|
|
||||||
if (!IsValidDestination(dest)) {
|
|
||||||
throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Invalid Dash address");
|
|
||||||
}
|
|
||||||
CScript scriptPubKey = GetScriptForDestination(dest);
|
|
||||||
if (!pwallet->IsMine(scriptPubKey)) {
|
|
||||||
throw JSONRPCError(RPC_WALLET_ERROR, "Address not found in wallet");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Minimum confirmations
|
|
||||||
int nMinDepth = 1;
|
|
||||||
if (!request.params[1].isNull())
|
|
||||||
nMinDepth = request.params[1].get_int();
|
|
||||||
bool fAddLocked = (!request.params[2].isNull() && request.params[2].get_bool());
|
|
||||||
|
|
||||||
// Tally
|
|
||||||
CAmount nAmount = 0;
|
|
||||||
for (const std::pair<const uint256, CWalletTx>& pairWtx : pwallet->mapWallet) {
|
|
||||||
const CWalletTx& wtx = pairWtx.second;
|
|
||||||
if (wtx.IsCoinBase() || !pwallet->chain().checkFinalTx(*wtx.tx)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (const CTxOut& txout : wtx.tx->vout)
|
|
||||||
if (txout.scriptPubKey == scriptPubKey)
|
|
||||||
if ((wtx.GetDepthInMainChain() >= nMinDepth) || (fAddLocked && wtx.IsLockedByInstantSend()))
|
|
||||||
nAmount += txout.nValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ValueFromAmount(nAmount);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -743,34 +761,7 @@ static UniValue getreceivedbylabel(const JSONRPCRequest& request)
|
|||||||
|
|
||||||
LOCK(pwallet->cs_wallet);
|
LOCK(pwallet->cs_wallet);
|
||||||
|
|
||||||
// Minimum confirmations
|
return ValueFromAmount(GetReceived(*pwallet, request.params, /* by_label */ true));
|
||||||
int nMinDepth = 1;
|
|
||||||
if (!request.params[1].isNull())
|
|
||||||
nMinDepth = request.params[1].get_int();
|
|
||||||
bool fAddLocked = (!request.params[2].isNull() && request.params[2].get_bool());
|
|
||||||
|
|
||||||
// Get the set of pub keys assigned to label
|
|
||||||
std::string label = LabelFromValue(request.params[0]);
|
|
||||||
std::set<CTxDestination> setAddress = pwallet->GetLabelAddresses(label);
|
|
||||||
|
|
||||||
// Tally
|
|
||||||
CAmount nAmount = 0;
|
|
||||||
for (const std::pair<const uint256, CWalletTx>& pairWtx : pwallet->mapWallet) {
|
|
||||||
const CWalletTx& wtx = pairWtx.second;
|
|
||||||
if (wtx.IsCoinBase() || !pwallet->chain().checkFinalTx(*wtx.tx))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
for (const CTxOut& txout : wtx.tx->vout)
|
|
||||||
{
|
|
||||||
CTxDestination address;
|
|
||||||
if (ExtractDestination(txout.scriptPubKey, address) && pwallet->IsMine(address) && setAddress.count(address)) {
|
|
||||||
if ((wtx.GetDepthInMainChain() >= nMinDepth) || (fAddLocked && wtx.IsLockedByInstantSend()))
|
|
||||||
nAmount += txout.nValue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return ValueFromAmount(nAmount);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user