Add getmempooldescendants RPC call
This commit is contained in:
parent
8f7b5dc4af
commit
0dfd86956d
2 changed files with 67 additions and 1 deletions
|
@ -302,7 +302,7 @@ UniValue getmempoolancestors(const UniValue& params, bool fHelp)
|
||||||
"1. \"txid\" (string, required) The transaction id (must be in mempool)\n"
|
"1. \"txid\" (string, required) The transaction id (must be in mempool)\n"
|
||||||
"2. verbose (boolean, optional, default=false) true for a json object, false for array of transaction ids\n"
|
"2. verbose (boolean, optional, default=false) true for a json object, false for array of transaction ids\n"
|
||||||
"\nResult (for verbose=false):\n"
|
"\nResult (for verbose=false):\n"
|
||||||
"[ (json array of string)\n"
|
"[ (json array of strings)\n"
|
||||||
" \"transactionid\" (string) The transaction id of an in-mempool ancestor transaction\n"
|
" \"transactionid\" (string) The transaction id of an in-mempool ancestor transaction\n"
|
||||||
" ,...\n"
|
" ,...\n"
|
||||||
"]\n"
|
"]\n"
|
||||||
|
@ -356,6 +356,70 @@ UniValue getmempoolancestors(const UniValue& params, bool fHelp)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
UniValue getmempooldescendants(const UniValue& params, bool fHelp)
|
||||||
|
{
|
||||||
|
if (fHelp || params.size() < 1 || params.size() > 2) {
|
||||||
|
throw runtime_error(
|
||||||
|
"getmempooldescendants txid (verbose)\n"
|
||||||
|
"\nIf txid is in the mempool, returns all in-mempool descendants.\n"
|
||||||
|
"\nArguments:\n"
|
||||||
|
"1. \"txid\" (string, required) The transaction id (must be in mempool)\n"
|
||||||
|
"2. verbose (boolean, optional, default=false) true for a json object, false for array of transaction ids\n"
|
||||||
|
"\nResult (for verbose=false):\n"
|
||||||
|
"[ (json array of strings)\n"
|
||||||
|
" \"transactionid\" (string) The transaction id of an in-mempool descendant transaction\n"
|
||||||
|
" ,...\n"
|
||||||
|
"]\n"
|
||||||
|
"\nResult (for verbose=true):\n"
|
||||||
|
"{ (json object)\n"
|
||||||
|
" \"transactionid\" : { (json object)\n"
|
||||||
|
+ EntryDescriptionString()
|
||||||
|
+ " }, ...\n"
|
||||||
|
"}\n"
|
||||||
|
"\nExamples\n"
|
||||||
|
+ HelpExampleCli("getmempooldescendants", "\"mytxid\"")
|
||||||
|
+ HelpExampleRpc("getmempooldescendants", "\"mytxid\"")
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool fVerbose = false;
|
||||||
|
if (params.size() > 1)
|
||||||
|
fVerbose = params[1].get_bool();
|
||||||
|
|
||||||
|
uint256 hash = ParseHashV(params[0], "parameter 1");
|
||||||
|
|
||||||
|
LOCK(mempool.cs);
|
||||||
|
|
||||||
|
CTxMemPool::txiter it = mempool.mapTx.find(hash);
|
||||||
|
if (it == mempool.mapTx.end()) {
|
||||||
|
throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Transaction not in mempool");
|
||||||
|
}
|
||||||
|
|
||||||
|
CTxMemPool::setEntries setDescendants;
|
||||||
|
mempool.CalculateDescendants(it, setDescendants);
|
||||||
|
// CTxMemPool::CalculateDescendants will include the given tx
|
||||||
|
setDescendants.erase(it);
|
||||||
|
|
||||||
|
if (!fVerbose) {
|
||||||
|
UniValue o(UniValue::VARR);
|
||||||
|
BOOST_FOREACH(CTxMemPool::txiter descendantIt, setDescendants) {
|
||||||
|
o.push_back(descendantIt->GetTx().GetHash().ToString());
|
||||||
|
}
|
||||||
|
|
||||||
|
return o;
|
||||||
|
} else {
|
||||||
|
UniValue o(UniValue::VOBJ);
|
||||||
|
BOOST_FOREACH(CTxMemPool::txiter descendantIt, setDescendants) {
|
||||||
|
const CTxMemPoolEntry &e = *descendantIt;
|
||||||
|
const uint256& hash = e.GetTx().GetHash();
|
||||||
|
UniValue info(UniValue::VOBJ);
|
||||||
|
entryToJSON(info, e);
|
||||||
|
o.push_back(Pair(hash.ToString(), info));
|
||||||
|
}
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
UniValue getblockhash(const UniValue& params, bool fHelp)
|
UniValue getblockhash(const UniValue& params, bool fHelp)
|
||||||
{
|
{
|
||||||
if (fHelp || params.size() != 1)
|
if (fHelp || params.size() != 1)
|
||||||
|
@ -1081,6 +1145,7 @@ static const CRPCCommand commands[] =
|
||||||
{ "blockchain", "getchaintips", &getchaintips, true },
|
{ "blockchain", "getchaintips", &getchaintips, true },
|
||||||
{ "blockchain", "getdifficulty", &getdifficulty, true },
|
{ "blockchain", "getdifficulty", &getdifficulty, true },
|
||||||
{ "blockchain", "getmempoolancestors", &getmempoolancestors, true },
|
{ "blockchain", "getmempoolancestors", &getmempoolancestors, true },
|
||||||
|
{ "blockchain", "getmempooldescendants", &getmempooldescendants, true },
|
||||||
{ "blockchain", "getmempoolinfo", &getmempoolinfo, true },
|
{ "blockchain", "getmempoolinfo", &getmempoolinfo, true },
|
||||||
{ "blockchain", "getrawmempool", &getrawmempool, true },
|
{ "blockchain", "getrawmempool", &getrawmempool, true },
|
||||||
{ "blockchain", "gettxout", &gettxout, true },
|
{ "blockchain", "gettxout", &gettxout, true },
|
||||||
|
|
|
@ -103,6 +103,7 @@ static const CRPCConvertParam vRPCConvertParams[] =
|
||||||
{ "setban", 2 },
|
{ "setban", 2 },
|
||||||
{ "setban", 3 },
|
{ "setban", 3 },
|
||||||
{ "getmempoolancestors", 1 },
|
{ "getmempoolancestors", 1 },
|
||||||
|
{ "getmempooldescendants", 1 },
|
||||||
};
|
};
|
||||||
|
|
||||||
class CRPCConvertTable
|
class CRPCConvertTable
|
||||||
|
|
Loading…
Reference in a new issue