mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-02-12 11:19:08 -05:00
Merge bitcoin/bitcoin#25171: rpc: wallet: remove -deprecatedrpc=exclude_coinbase
logic
a4703ce9d7
doc: add release notes about removal of the `deprecatedrpc=exclude_coinbase` (Sebastian Falbesoner)ef0aa74836
rpc: wallet: remove `-deprecatedrpc=exclude_coinbase` logic (Sebastian Falbesoner) Pull request description: Including coinbase transactions in `receivedby` RPCs and adding the `-deprecatedrpc=exclude_coinbase` was done in PR #14707 (released in v23.0). For the next release v24.0, this configuration option can be removed. ACKs for top commit: fanquake: ACKa4703ce9d7
Tree-SHA512: 97cd4e78501e64f678c78d2ebb5be5376688c023e34fced71dd24e432d27aa31a74b5483545f49ba0bdf48656d8b8b7bee74e3db26cf6daf112613f1caa4dfa4
This commit is contained in:
commit
a7e3afb221
4 changed files with 9 additions and 49 deletions
|
@ -55,6 +55,13 @@ Updated RPCs
|
||||||
previously deprecated in 23.0. (#23508) Information on soft fork status is
|
previously deprecated in 23.0. (#23508) Information on soft fork status is
|
||||||
now only available via the `getdeploymentinfo` RPC.
|
now only available via the `getdeploymentinfo` RPC.
|
||||||
|
|
||||||
|
- The `deprecatedrpc=exclude_coinbase` configuration option has been removed.
|
||||||
|
The `receivedby` RPCs (`listreceivedbyaddress`, `listreceivedbylabel`,
|
||||||
|
`getreceivedbyaddress` and `getreceivedbylabel`) now always return results
|
||||||
|
accounting for received coins from coinbase outputs, without an option to
|
||||||
|
change that behaviour. Excluding coinbases was previously deprecated in 23.0.
|
||||||
|
(#25171)
|
||||||
|
|
||||||
Changes to wallet related RPCs can be found in the Wallet section below.
|
Changes to wallet related RPCs can be found in the Wallet section below.
|
||||||
|
|
||||||
New RPCs
|
New RPCs
|
||||||
|
|
|
@ -49,14 +49,6 @@ static CAmount GetReceived(const CWallet& wallet, const UniValue& params, bool b
|
||||||
|
|
||||||
const bool include_immature_coinbase{params[2].isNull() ? false : params[2].get_bool()};
|
const bool include_immature_coinbase{params[2].isNull() ? false : params[2].get_bool()};
|
||||||
|
|
||||||
// Excluding coinbase outputs is deprecated
|
|
||||||
// It can be enabled by setting deprecatedrpc=exclude_coinbase
|
|
||||||
const bool include_coinbase{!wallet.chain().rpcEnableDeprecated("exclude_coinbase")};
|
|
||||||
|
|
||||||
if (include_immature_coinbase && !include_coinbase) {
|
|
||||||
throw JSONRPCError(RPC_INVALID_PARAMETER, "include_immature_coinbase is incompatible with deprecated exclude_coinbase");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tally
|
// Tally
|
||||||
CAmount amount = 0;
|
CAmount amount = 0;
|
||||||
for (const std::pair<const uint256, CWalletTx>& wtx_pair : wallet.mapWallet) {
|
for (const std::pair<const uint256, CWalletTx>& wtx_pair : wallet.mapWallet) {
|
||||||
|
@ -64,7 +56,7 @@ static CAmount GetReceived(const CWallet& wallet, const UniValue& params, bool b
|
||||||
int depth{wallet.GetTxDepthInMainChain(wtx)};
|
int depth{wallet.GetTxDepthInMainChain(wtx)};
|
||||||
if (depth < min_depth
|
if (depth < min_depth
|
||||||
// Coinbase with less than 1 confirmation is no longer in the main chain
|
// Coinbase with less than 1 confirmation is no longer in the main chain
|
||||||
|| (wtx.IsCoinBase() && (depth < 1 || !include_coinbase))
|
|| (wtx.IsCoinBase() && (depth < 1))
|
||||||
|| (wallet.IsTxImmatureCoinBase(wtx) && !include_immature_coinbase))
|
|| (wallet.IsTxImmatureCoinBase(wtx) && !include_immature_coinbase))
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -95,14 +95,6 @@ static UniValue ListReceived(const CWallet& wallet, const UniValue& params, cons
|
||||||
has_filtered_address = true;
|
has_filtered_address = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Excluding coinbase outputs is deprecated
|
|
||||||
// It can be enabled by setting deprecatedrpc=exclude_coinbase
|
|
||||||
const bool include_coinbase{!wallet.chain().rpcEnableDeprecated("exclude_coinbase")};
|
|
||||||
|
|
||||||
if (include_immature_coinbase && !include_coinbase) {
|
|
||||||
throw JSONRPCError(RPC_INVALID_PARAMETER, "include_immature_coinbase is incompatible with deprecated exclude_coinbase");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Tally
|
// Tally
|
||||||
std::map<CTxDestination, tallyitem> mapTally;
|
std::map<CTxDestination, tallyitem> mapTally;
|
||||||
for (const std::pair<const uint256, CWalletTx>& pairWtx : wallet.mapWallet) {
|
for (const std::pair<const uint256, CWalletTx>& pairWtx : wallet.mapWallet) {
|
||||||
|
@ -113,7 +105,7 @@ static UniValue ListReceived(const CWallet& wallet, const UniValue& params, cons
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
// Coinbase with less than 1 confirmation is no longer in the main chain
|
// Coinbase with less than 1 confirmation is no longer in the main chain
|
||||||
if ((wtx.IsCoinBase() && (nDepth < 1 || !include_coinbase))
|
if ((wtx.IsCoinBase() && (nDepth < 1))
|
||||||
|| (wallet.IsTxImmatureCoinBase(wtx) && !include_immature_coinbase))
|
|| (wallet.IsTxImmatureCoinBase(wtx) && !include_immature_coinbase))
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -18,8 +18,6 @@ from test_framework.wallet_util import test_address
|
||||||
class ReceivedByTest(BitcoinTestFramework):
|
class ReceivedByTest(BitcoinTestFramework):
|
||||||
def set_test_params(self):
|
def set_test_params(self):
|
||||||
self.num_nodes = 2
|
self.num_nodes = 2
|
||||||
# Test deprecated exclude coinbase on second node
|
|
||||||
self.extra_args = [[], ["-deprecatedrpc=exclude_coinbase"]]
|
|
||||||
|
|
||||||
def skip_test_if_missing_module(self):
|
def skip_test_if_missing_module(self):
|
||||||
self.skip_if_no_wallet()
|
self.skip_if_no_wallet()
|
||||||
|
@ -250,35 +248,6 @@ class ReceivedByTest(BitcoinTestFramework):
|
||||||
{"label": label},
|
{"label": label},
|
||||||
{}, True)
|
{}, True)
|
||||||
|
|
||||||
# Test exclude_coinbase
|
|
||||||
address2 = self.nodes[1].getnewaddress(label)
|
|
||||||
self.generatetoaddress(self.nodes[1], COINBASE_MATURITY + 1, address2, sync_fun=self.no_op)
|
|
||||||
|
|
||||||
self.log.info("getreceivedbyaddress returns nothing when excluding coinbase")
|
|
||||||
balance = self.nodes[1].getreceivedbyaddress(address2)
|
|
||||||
assert_equal(balance, 0)
|
|
||||||
|
|
||||||
self.log.info("getreceivedbylabel returns nothing when excluding coinbase")
|
|
||||||
balance = self.nodes[1].getreceivedbylabel("label")
|
|
||||||
assert_equal(balance, 0)
|
|
||||||
|
|
||||||
self.log.info("listreceivedbyaddress does not include address when excluding coinbase")
|
|
||||||
assert_array_result(self.nodes[1].listreceivedbyaddress(),
|
|
||||||
{"address": address2},
|
|
||||||
{}, True)
|
|
||||||
|
|
||||||
self.log.info("listreceivedbylabel does not include label when excluding coinbase")
|
|
||||||
assert_array_result(self.nodes[1].listreceivedbylabel(),
|
|
||||||
{"label": label},
|
|
||||||
{}, True)
|
|
||||||
|
|
||||||
self.log.info("getreceivedbyaddress throws when setting include_immature_coinbase with deprecated exclude_coinbase")
|
|
||||||
assert_raises_rpc_error(-8, 'include_immature_coinbase is incompatible with deprecated exclude_coinbase', self.nodes[1].getreceivedbyaddress, address2, 1, True)
|
|
||||||
|
|
||||||
|
|
||||||
self.log.info("listreceivedbyaddress throws when setting include_immature_coinbase with deprecated exclude_coinbase")
|
|
||||||
assert_raises_rpc_error(-8, 'include_immature_coinbase is incompatible with deprecated exclude_coinbase', self.nodes[1].listreceivedbyaddress, 1, False, False, "", True)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
ReceivedByTest().main()
|
ReceivedByTest().main()
|
||||||
|
|
Loading…
Add table
Reference in a new issue