|
|
|
@ -673,38 +673,6 @@ UniValue getreceivedbyaccount(const UniValue& params, bool fHelp)
@@ -673,38 +673,6 @@ UniValue getreceivedbyaccount(const UniValue& params, bool fHelp)
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
CAmount GetAccountBalance(CWalletDB& walletdb, const string& strAccount, int nMinDepth, const isminefilter& filter) |
|
|
|
|
{ |
|
|
|
|
CAmount nBalance = 0; |
|
|
|
|
|
|
|
|
|
// Tally wallet transactions
|
|
|
|
|
for (map<uint256, CWalletTx>::iterator it = pwalletMain->mapWallet.begin(); it != pwalletMain->mapWallet.end(); ++it) |
|
|
|
|
{ |
|
|
|
|
const CWalletTx& wtx = (*it).second; |
|
|
|
|
if (!CheckFinalTx(wtx) || wtx.GetBlocksToMaturity() > 0 || wtx.GetDepthInMainChain() < 0) |
|
|
|
|
continue; |
|
|
|
|
|
|
|
|
|
CAmount nReceived, nSent, nFee; |
|
|
|
|
wtx.GetAccountAmounts(strAccount, nReceived, nSent, nFee, filter); |
|
|
|
|
|
|
|
|
|
if (nReceived != 0 && wtx.GetDepthInMainChain() >= nMinDepth) |
|
|
|
|
nBalance += nReceived; |
|
|
|
|
nBalance -= nSent + nFee; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// Tally internal accounting entries
|
|
|
|
|
nBalance += walletdb.GetAccountCreditDebit(strAccount); |
|
|
|
|
|
|
|
|
|
return nBalance; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
CAmount GetAccountBalance(const string& strAccount, int nMinDepth, const isminefilter& filter) |
|
|
|
|
{ |
|
|
|
|
CWalletDB walletdb(pwalletMain->strWalletFile); |
|
|
|
|
return GetAccountBalance(walletdb, strAccount, nMinDepth, filter); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
UniValue getbalance(const UniValue& params, bool fHelp) |
|
|
|
|
{ |
|
|
|
|
if (!EnsureWalletIsAvailable(fHelp)) |
|
|
|
@ -775,7 +743,7 @@ UniValue getbalance(const UniValue& params, bool fHelp)
@@ -775,7 +743,7 @@ UniValue getbalance(const UniValue& params, bool fHelp)
|
|
|
|
|
|
|
|
|
|
string strAccount = AccountFromValue(params[0]); |
|
|
|
|
|
|
|
|
|
CAmount nBalance = GetAccountBalance(strAccount, nMinDepth, filter); |
|
|
|
|
CAmount nBalance = pwalletMain->GetAccountBalance(strAccount, nMinDepth, filter); |
|
|
|
|
|
|
|
|
|
return ValueFromAmount(nBalance); |
|
|
|
|
} |
|
|
|
@ -923,7 +891,7 @@ UniValue sendfrom(const UniValue& params, bool fHelp)
@@ -923,7 +891,7 @@ UniValue sendfrom(const UniValue& params, bool fHelp)
|
|
|
|
|
EnsureWalletIsUnlocked(); |
|
|
|
|
|
|
|
|
|
// Check funds
|
|
|
|
|
CAmount nBalance = GetAccountBalance(strAccount, nMinDepth, ISMINE_SPENDABLE); |
|
|
|
|
CAmount nBalance = pwalletMain->GetAccountBalance(strAccount, nMinDepth, ISMINE_SPENDABLE); |
|
|
|
|
if (nAmount > nBalance) |
|
|
|
|
throw JSONRPCError(RPC_WALLET_INSUFFICIENT_FUNDS, "Account has insufficient funds"); |
|
|
|
|
|
|
|
|
@ -1026,7 +994,7 @@ UniValue sendmany(const UniValue& params, bool fHelp)
@@ -1026,7 +994,7 @@ UniValue sendmany(const UniValue& params, bool fHelp)
|
|
|
|
|
EnsureWalletIsUnlocked(); |
|
|
|
|
|
|
|
|
|
// Check funds
|
|
|
|
|
CAmount nBalance = GetAccountBalance(strAccount, nMinDepth, ISMINE_SPENDABLE); |
|
|
|
|
CAmount nBalance = pwalletMain->GetAccountBalance(strAccount, nMinDepth, ISMINE_SPENDABLE); |
|
|
|
|
if (totalAmount > nBalance) |
|
|
|
|
throw JSONRPCError(RPC_WALLET_INSUFFICIENT_FUNDS, "Account has insufficient funds"); |
|
|
|
|
|
|
|
|
@ -1836,7 +1804,7 @@ UniValue backupwallet(const UniValue& params, bool fHelp)
@@ -1836,7 +1804,7 @@ UniValue backupwallet(const UniValue& params, bool fHelp)
|
|
|
|
|
LOCK2(cs_main, pwalletMain->cs_wallet); |
|
|
|
|
|
|
|
|
|
string strDest = params[0].get_str(); |
|
|
|
|
if (!BackupWallet(*pwalletMain, strDest)) |
|
|
|
|
if (!pwalletMain->BackupWallet(strDest)) |
|
|
|
|
throw JSONRPCError(RPC_WALLET_ERROR, "Error: Wallet backup failed!"); |
|
|
|
|
|
|
|
|
|
return NullUniValue; |
|
|
|
|