Split help and rpc methods
Use constants for field names Signed-off-by: Anthony Fieroni <bvbfan@abv.bg>
This commit is contained in:
parent
9d4ef899a6
commit
5bdbc9e0d6
4 changed files with 448 additions and 445 deletions
|
@ -155,6 +155,7 @@ BITCOIN_CORE_H = \
|
|||
reverse_iterator.h \
|
||||
reverselock.h \
|
||||
rpc/blockchain.h \
|
||||
rpc/claimrpchelp.h \
|
||||
rpc/client.h \
|
||||
rpc/mining.h \
|
||||
rpc/protocol.h \
|
||||
|
|
290
src/rpc/claimrpchelp.h
Normal file
290
src/rpc/claimrpchelp.h
Normal file
|
@ -0,0 +1,290 @@
|
|||
|
||||
#include <string>
|
||||
|
||||
// always keep defines T_ + value in upper case
|
||||
#define T_NORMALIZEDNAME "normalizedName"
|
||||
#define T_BLOCKHASH "blockhash"
|
||||
#define T_CLAIMS "claims"
|
||||
#define T_CLAIMID "claimId"
|
||||
#define T_TXID "txId"
|
||||
#define T_N "n"
|
||||
#define T_AMOUNT "amount"
|
||||
#define T_HEIGHT "height"
|
||||
#define T_VALUE "value"
|
||||
#define T_NAME "name"
|
||||
#define T_VALIDATHEIGHT "validAtHeight"
|
||||
#define T_NAMES "names"
|
||||
#define T_EFFECTIVEAMOUNT "effectiveAmount"
|
||||
#define T_LASTTAKEOVERHEIGHT "lastTakeoverHeight"
|
||||
#define T_SUPPORTS "supports"
|
||||
#define T_SUPPORTSWITHOUTCLAIM "supportsWithoutClaim"
|
||||
#define T_TOTALNAMES "totalNames"
|
||||
#define T_TOTALCLAIMS "totalClaims"
|
||||
#define T_TOTALVALUE "totalValue"
|
||||
#define T_CONTROLLINGONLY "controllingOnly"
|
||||
#define T_CLAIMTYPE "claimType"
|
||||
#define T_DEPTH "depth"
|
||||
#define T_INCLAIMTRIE "inClaimTrie"
|
||||
#define T_ISCONTROLLING "isControlling"
|
||||
#define T_INSUPPORTMAP "inSupportMap"
|
||||
#define T_INQUEUE "inQueue"
|
||||
#define T_BLOCKSTOVALID "blocksToValid"
|
||||
#define T_NODES "nodes"
|
||||
#define T_CHILDREN "children"
|
||||
#define T_CHARACTER "character"
|
||||
#define T_NODEHASH "nodeHash"
|
||||
#define T_VALUEHASH "valueHash"
|
||||
#define T_PAIRS "pairs"
|
||||
#define T_ODD "odd"
|
||||
#define T_HASH "hash"
|
||||
|
||||
enum {
|
||||
GETCLAIMSINTRIE = 0,
|
||||
GETNAMESINTRIE,
|
||||
GETVALUEFORNAME,
|
||||
GETCLAIMSFORNAME,
|
||||
GETCLAIMBYID,
|
||||
GETTOTALCLAIMEDNAMES,
|
||||
GETTOTALCLAIMS,
|
||||
GETTOTALVALUEOFCLAIMS,
|
||||
GETCLAIMSFORTX,
|
||||
GETNAMEPROOF,
|
||||
CHECKNORMALIZATION,
|
||||
};
|
||||
|
||||
static const char* const rpc_help[] = {
|
||||
|
||||
// GETCLAIMSINTRIE
|
||||
R"(getclaimsintrie
|
||||
Return all claims in the name trie. Deprecated
|
||||
Arguments:
|
||||
1. ")" T_BLOCKHASH R"(" (string, optional) get claims in the trie
|
||||
at the block specified
|
||||
by this block hash.
|
||||
If none is given,
|
||||
the latest active
|
||||
block will be used.
|
||||
Result: [
|
||||
")" T_NORMALIZEDNAME R"(" (string) the name of the claim(s) (after normalization)
|
||||
")" T_CLAIMS R"(": [ (array of object) the claims for this name
|
||||
")" T_NAME R"(" (string) the original name of this claim (before normalization)
|
||||
")" T_VALUE R"(" (string) the value of this claim
|
||||
")" T_CLAIMID R"(" (string) the claimId of the claim
|
||||
")" T_TXID R"(" (string) the txid of the claim
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the claim became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the claim
|
||||
]
|
||||
])",
|
||||
|
||||
// GETNAMESINTRIE
|
||||
R"(getnamesintrie
|
||||
Return all claim names in the trie.
|
||||
Arguments:
|
||||
1. ")" T_BLOCKHASH R"(" (string, optional) get claims in the trie
|
||||
at the block specified
|
||||
by this block hash.
|
||||
If none is given,
|
||||
the latest active
|
||||
block will be used.
|
||||
Result: [
|
||||
")" T_NAMES R"(" all names in the trie that have claims
|
||||
])",
|
||||
|
||||
// GETVALUEFORNAME
|
||||
R"(getvalueforname
|
||||
Return the winning or specified by claimId value associated with a name
|
||||
Arguments:
|
||||
1. ")" T_NAME R"(" (string) the name to look up
|
||||
2. ")" T_BLOCKHASH R"(" (string, optional) get the value
|
||||
associated with the name
|
||||
at the block specified
|
||||
by this block hash.
|
||||
If none is given,
|
||||
the latest active
|
||||
block will be used.
|
||||
3. ")" T_CLAIMID R"(" (string, optional) can be partial one
|
||||
Result: [
|
||||
")" T_NORMALIZEDNAME R"(" (string) the name of the claim(s) (after normalization)
|
||||
")" T_NAME R"(" (string) the original name of this claim (before normalization)
|
||||
")" T_VALUE R"(" (string) the value of this claim
|
||||
")" T_CLAIMID R"(" (string) the claimId of the claim
|
||||
")" T_TXID R"(" (string) the txid of the claim
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the claim
|
||||
")" T_EFFECTIVEAMOUNT R"(" (numeric) the amount plus amount from all supports associated with the claim
|
||||
")" T_SUPPORTS R"(": [ (array of object) supports for this claim
|
||||
")" T_VALUE R"(" (string) the metadata of the support if any
|
||||
")" T_TXID R"(" (string) the txid of the support
|
||||
")" T_N R"(" (numeric) the index of the support in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the support
|
||||
]
|
||||
")" T_LASTTAKEOVERHEIGHT R"(" (numeric) the last height at which ownership of the name changed
|
||||
])",
|
||||
|
||||
// GETCLAIMSFORNAME
|
||||
R"(getclaimsforname
|
||||
Return all claims and supports for a name
|
||||
Arguments:
|
||||
1. ")" T_NAME R"(" (string) the name to look up
|
||||
2. ")" T_BLOCKHASH R"(" (string, optional) get claims in the trie
|
||||
at the block specified
|
||||
by this block hash.
|
||||
If none is given,
|
||||
the latest active
|
||||
block will be used.
|
||||
Result: [
|
||||
")" T_NORMALIZEDNAME R"(" (string) the name of the claim(s) (after normalization)
|
||||
")" T_CLAIMS R"(": [ (array of object) the claims for this name
|
||||
")" T_NAME R"(" (string) the original name of this claim (before normalization)
|
||||
")" T_VALUE R"(" (string) the value of this claim
|
||||
")" T_CLAIMID R"(" (string) the claimId of the claim
|
||||
")" T_TXID R"(" (string) the txid of the claim
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the claim became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the claim
|
||||
")" T_EFFECTIVEAMOUNT R"(" (numeric) the amount plus amount from all supports associated with the claim
|
||||
")" T_SUPPORTS R"(": [ (array of object) supports for this claim
|
||||
")" T_VALUE R"(" (string) the metadata of the support if any
|
||||
")" T_TXID R"(" (string) the txid of the support
|
||||
")" T_N R"(" (numeric) the index of the support in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the support
|
||||
]
|
||||
]
|
||||
")" T_LASTTAKEOVERHEIGHT R"(" (numeric) the last height at which ownership of the name changed
|
||||
")" T_SUPPORTSWITHOUTCLAIM R"(": [
|
||||
")" T_TXID R"(" (string) the txid of the support
|
||||
")" T_N R"(" (numeric) the index of the support in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the support
|
||||
]
|
||||
])",
|
||||
|
||||
// GETCLAIMBYID
|
||||
R"(getclaimbyid
|
||||
Get a claim by claim id
|
||||
Arguments:
|
||||
1. ")" T_CLAIMID R"(" (string) the claimId of this claim or patial id (at least 3 chars)
|
||||
Result: [
|
||||
")" T_NORMALIZEDNAME R"(" (string) the name of the claim(s) (after normalization)
|
||||
")" T_NAME R"(" (string) the original name of this claim (before normalization)
|
||||
")" T_VALUE R"(" (string) the value of this claim
|
||||
")" T_CLAIMID R"(" (string) the claimId of the claim
|
||||
")" T_TXID R"(" (string) the txid of the claim
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the claim
|
||||
")" T_EFFECTIVEAMOUNT R"(" (numeric) the amount plus amount from all supports associated with the claim
|
||||
")" T_SUPPORTS R"(": [ (array of object) supports for this claim
|
||||
")" T_VALUE R"(" (string) the metadata of the support if any
|
||||
")" T_TXID R"(" (string) the txid of the support
|
||||
")" T_N R"(" (numeric) the index of the support in the transaction's list of outputs
|
||||
")" T_HEIGHT R"(" (numeric) the height of the block in which this transaction is located
|
||||
")" T_VALIDATHEIGHT R"(" (numeric) the height at which the support became/becomes valid
|
||||
")" T_AMOUNT R"(" (numeric) the amount of the support
|
||||
]
|
||||
")" T_LASTTAKEOVERHEIGHT R"(" (numeric) the last height at which ownership of the name changed
|
||||
])",
|
||||
|
||||
// GETTOTALCLAIMEDNAMES
|
||||
|
||||
R"(gettotalclaimednames
|
||||
Return the total number of names that have been
|
||||
Arguments:
|
||||
Result:
|
||||
")" T_TOTALNAMES R"(" (numeric) the total number of names in the trie
|
||||
)",
|
||||
|
||||
// GETTOTALCLAIMS
|
||||
R"(gettotalclaims
|
||||
Return the total number of active claims in the trie
|
||||
Arguments:
|
||||
Result:
|
||||
")" T_TOTALCLAIMS R"(" (numeric) the total number of active claims
|
||||
)",
|
||||
|
||||
// GETTOTALVALUEOFCLAIMS
|
||||
R"(gettotalvalueofclaims
|
||||
Return the total value of the claims in the trie
|
||||
Arguments:
|
||||
1. ")" T_CONTROLLINGONLY R"(" (boolean) only include the value of controlling claims
|
||||
Result:
|
||||
")" T_TOTALVALUE R"(" (numeric) the total value of the claims in the trie
|
||||
)",
|
||||
|
||||
// GETCLAIMSFORTX
|
||||
R"(getclaimsfortx
|
||||
Return any claims or supports found in a transaction
|
||||
Arguments:
|
||||
1. ")" T_TXID R"(" (string) the txid of the transaction to check for unspent claims
|
||||
Result: [
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_CLAIMTYPE R"(" (string) claim or support
|
||||
")" T_NAME R"(" (string) the name claimed or supported
|
||||
")" T_CLAIMID R"(" (string) if a claim, its ID
|
||||
")" T_VALUE R"(" (string) if a claim, its value
|
||||
")" T_DEPTH R"(" (numeric) the depth of the transaction in the main chain
|
||||
")" T_INCLAIMTRIE R"(" (boolean) if a name claim, whether the claim is active, i.e. has made it into the trie
|
||||
")" T_ISCONTROLLING R"(" (boolean) if a name claim, whether the claim is the current controlling claim for the name
|
||||
")" T_INSUPPORTMAP R"(" (boolean) if a support, whether the support is active, i.e. has made it into the support map
|
||||
")" T_INQUEUE R"(" (boolean) whether the claim is in a queue waiting to be inserted into the trie or support map
|
||||
")" T_BLOCKSTOVALID R"(" (numeric) if in a queue, the number of blocks until it's inserted into the trie or support map
|
||||
])",
|
||||
|
||||
// GETNAMEPROOF
|
||||
R"(getnameproof
|
||||
Return the cryptographic proof that a name maps to a value or doesn't.
|
||||
Arguments:
|
||||
1. ")" T_NAME R"(" (string) the name to look up
|
||||
2. ")" T_BLOCKHASH R"(" (string, optional) get the value
|
||||
associated with the name
|
||||
at the block specified
|
||||
by this block hash.
|
||||
If none is given,
|
||||
the latest active
|
||||
block will be used.
|
||||
3. ")" T_CLAIMID R"(" (string, optional, post-fork) for validating a specific claim
|
||||
can be partial one
|
||||
Result: [
|
||||
")" T_NODES R"(": [ (array of object, pre-fork) full nodes
|
||||
(i.e. those which lead to the requested name)
|
||||
")" T_CHILDREN R"(": [ (array of object) the children of the node
|
||||
")" T_CHARACTER R"(" (string) the character which leads from the parent
|
||||
to this child node
|
||||
")" T_NODEHASH R"(" (string, if exists) the hash of the node if this is a leaf node
|
||||
]
|
||||
")" T_VALUEHASH R"(" (string, if exists) the hash of this node's value, if
|
||||
it has one. If this is the requested name this
|
||||
will not exist whether the node has a value or not
|
||||
]
|
||||
")" T_PAIRS R"(": [ (array of pairs, post-fork) hash can be validated by
|
||||
hashing claim from the bottom up
|
||||
")" T_ODD R"(" (boolean) this value goes on the right of hash
|
||||
")" T_HASH R"(" (string) the hash to be mixed in
|
||||
]
|
||||
")" T_TXID R"(" (string, if exists) the txid of the claim which controls
|
||||
this name, if there is one.
|
||||
")" T_N R"(" (numeric) the index of the claim in the transaction's list of outputs
|
||||
")" T_LASTTAKEOVERHEIGHT R"(" (numeric) the last height at which ownership of the name changed
|
||||
])",
|
||||
|
||||
// CHECKNORMALIZATION
|
||||
R"(checknormalization
|
||||
Given an unnormalized name of a claim, return normalized version of it
|
||||
Arguments:
|
||||
1. ")" T_NAME R"(" (string) the name to normalize
|
||||
Result:
|
||||
")" T_NORMALIZEDNAME R"(" (string) normalized name
|
||||
)",
|
||||
|
||||
};
|
|
@ -3,6 +3,7 @@
|
|||
#include <core_io.h>
|
||||
#include <logging.h>
|
||||
#include <nameclaim.h>
|
||||
#include <rpc/claimrpchelp.h>
|
||||
#include <rpc/server.h>
|
||||
#include <shutdown.h>
|
||||
#include <txdb.h>
|
||||
|
@ -24,6 +25,8 @@ void ParseClaimtrieId(const UniValue& v, std::string& partialId, uint160& claimI
|
|||
strHex = v.get_str();
|
||||
if (!IsHex(strHex))
|
||||
throw JSONRPCError(RPC_INVALID_PARAMETER, strName + " must be a hexadecimal string");
|
||||
if (strHex.length() > claimIdHexLength)
|
||||
throw JSONRPCError(RPC_INVALID_PARAMETER, strName + " must be max 20-character hexadecimal string");
|
||||
if (strHex.length() == claimIdHexLength)
|
||||
claimId.SetHex(strHex);
|
||||
else
|
||||
|
@ -173,18 +176,18 @@ UniValue claimToJSON(const CCoinsViewCache& coinsCache, const CClaimValue& claim
|
|||
|
||||
std::string targetName;
|
||||
if (getClaimById(claim.claimId, targetName))
|
||||
result.pushKV("name", escapeNonUtf8(targetName));
|
||||
result.pushKV(T_NAME, escapeNonUtf8(targetName));
|
||||
|
||||
std::string sValue;
|
||||
if (getValueForOutPoint(coinsCache, claim.outPoint, sValue))
|
||||
result.pushKV("value", sValue);
|
||||
result.pushKV(T_VALUE, sValue);
|
||||
|
||||
result.pushKV("claimId", claim.claimId.GetHex());
|
||||
result.pushKV("txId", claim.outPoint.hash.GetHex());
|
||||
result.pushKV("n", (int)claim.outPoint.n);
|
||||
result.pushKV("height", claim.nHeight);
|
||||
result.pushKV("validAtHeight", claim.nValidAtHeight);
|
||||
result.pushKV("amount", claim.nAmount);
|
||||
result.pushKV(T_CLAIMID, claim.claimId.GetHex());
|
||||
result.pushKV(T_TXID, claim.outPoint.hash.GetHex());
|
||||
result.pushKV(T_N, (int)claim.outPoint.n);
|
||||
result.pushKV(T_HEIGHT, claim.nHeight);
|
||||
result.pushKV(T_VALIDATHEIGHT, claim.nValidAtHeight);
|
||||
result.pushKV(T_AMOUNT, claim.nAmount);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
@ -195,13 +198,13 @@ UniValue supportToJSON(const CCoinsViewCache& coinsCache, const CSupportValue& s
|
|||
|
||||
std::string value;
|
||||
if (getValueForOutPoint(coinsCache, support.outPoint, value))
|
||||
ret.pushKV("value", value);
|
||||
ret.pushKV(T_VALUE, value);
|
||||
|
||||
ret.pushKV("txId", support.outPoint.hash.GetHex());
|
||||
ret.pushKV("n", (int)support.outPoint.n);
|
||||
ret.pushKV("height", support.nHeight);
|
||||
ret.pushKV("validAtHeight", support.nValidAtHeight);
|
||||
ret.pushKV("amount", support.nAmount);
|
||||
ret.pushKV(T_TXID, support.outPoint.hash.GetHex());
|
||||
ret.pushKV(T_N, (int)support.outPoint.n);
|
||||
ret.pushKV(T_HEIGHT, support.nHeight);
|
||||
ret.pushKV(T_VALIDATHEIGHT, support.nValidAtHeight);
|
||||
ret.pushKV(T_AMOUNT, support.nAmount);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
@ -212,17 +215,14 @@ UniValue claimAndSupportsToJSON(const CCoinsViewCache& coinsCache, const CClaimN
|
|||
auto& supports = claimNsupports.supports;
|
||||
|
||||
auto result = claimToJSON(coinsCache, claim);
|
||||
result.pushKV("effectiveAmount", claimNsupports.effectiveAmount);
|
||||
|
||||
if (claim.nEffectiveAmount > claimNsupports.effectiveAmount)
|
||||
result.pushKV("pendingEffectiveAmount", claim.nEffectiveAmount);
|
||||
result.pushKV(T_EFFECTIVEAMOUNT, claimNsupports.effectiveAmount);
|
||||
|
||||
UniValue supportObjs(UniValue::VARR);
|
||||
for (auto& support : supports)
|
||||
supportObjs.push_back(supportToJSON(coinsCache, support));
|
||||
|
||||
if (!supportObjs.empty())
|
||||
result.pushKV("supports", supportObjs);
|
||||
result.pushKV(T_SUPPORTS, supportObjs);
|
||||
|
||||
return result;
|
||||
}
|
||||
|
@ -233,48 +233,25 @@ bool validParams(const UniValue& params, uint8_t required, uint8_t optional)
|
|||
return count >= required && count <= required + optional;
|
||||
}
|
||||
|
||||
void validateRequest(const JSONRPCRequest& request, int findex, uint8_t required, uint8_t optional)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, required, optional))
|
||||
throw std::runtime_error(rpc_help[findex]);
|
||||
}
|
||||
|
||||
static UniValue getclaimsintrie(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || request.params.size() > 1)
|
||||
throw std::runtime_error(
|
||||
"getclaimsintrie\n"
|
||||
"Return all claims in the name trie. Deprecated.\n"
|
||||
"Arguments:\n"
|
||||
"1. \"blockhash\" (string, optional) get claims in the trie\n"
|
||||
" at the block specified\n"
|
||||
" by this block hash.\n"
|
||||
" If none is given,\n"
|
||||
" the latest active\n"
|
||||
" block will be used.\n"
|
||||
"Result: \n"
|
||||
"[\n"
|
||||
" {\n"
|
||||
" \"normalized_name\" (string) the name of these claims (after normalization)\n"
|
||||
" \"claims\": [ (array of object) the claims for this name\n"
|
||||
" {\n"
|
||||
" \"claimId\" (string) the claimId of the claim\n"
|
||||
" \"txid\" (string) the txid of the claim\n"
|
||||
" \"n\" (numeric) the vout value of the claim\n"
|
||||
" \"amount\" (numeric) txout amount\n"
|
||||
" \"height\" (numeric) the height of the block in which this transaction is located\n"
|
||||
" \"value\" (string) the value of this claim\n"
|
||||
" \"name\" (string) the original name of this claim (before normalization)\n"
|
||||
" }\n"
|
||||
" ]\n"
|
||||
" }\n"
|
||||
"]\n");
|
||||
validateRequest(request, GETCLAIMSINTRIE, 0, 1);
|
||||
|
||||
if (!IsDeprecatedRPCEnabled("getclaimsintrie")) {
|
||||
const auto msg = "getclaimsintrie is deprecated and will be removed in v0.18. To use this command, start with -deprecatedrpc=getclaimsintrie";
|
||||
if (request.fHelp) {
|
||||
if (request.fHelp)
|
||||
throw std::runtime_error(msg);
|
||||
}
|
||||
throw JSONRPCError(RPC_METHOD_DEPRECATED, msg);
|
||||
}
|
||||
|
||||
UniValue ret(UniValue::VARR);
|
||||
LOCK(cs_main);
|
||||
|
||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
||||
|
@ -297,8 +274,8 @@ static UniValue getclaimsintrie(const JSONRPCRequest& request)
|
|||
claims.push_back(claimToJSON(coinsCache, claim));
|
||||
|
||||
UniValue nodeObj(UniValue::VOBJ);
|
||||
nodeObj.pushKV("normalized_name", escapeNonUtf8(name));
|
||||
nodeObj.pushKV("claims", claims);
|
||||
nodeObj.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(name));
|
||||
nodeObj.pushKV(T_CLAIMS, claims);
|
||||
ret.push_back(nodeObj);
|
||||
});
|
||||
return ret;
|
||||
|
@ -312,22 +289,9 @@ static UniValue getclaimtrie(const JSONRPCRequest& request)
|
|||
|
||||
static UniValue getnamesintrie(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 0, 1))
|
||||
throw std::runtime_error(
|
||||
"getnamesintrie\n"
|
||||
"Return all claim names in the trie.\n"
|
||||
"Arguments:\n"
|
||||
"1. \"blockhash\" (string, optional) get claims in the trie\n"
|
||||
" at the block specified\n"
|
||||
" by this block hash.\n"
|
||||
" If none is given,\n"
|
||||
" the latest active\n"
|
||||
" block will be used.\n"
|
||||
"Result: \n"
|
||||
"\"names\" (array) all names in the trie that have claims\n");
|
||||
validateRequest(request, GETNAMESINTRIE, 0, 1);
|
||||
|
||||
LOCK(cs_main);
|
||||
|
||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
||||
|
@ -351,32 +315,9 @@ static UniValue getnamesintrie(const JSONRPCRequest& request)
|
|||
|
||||
static UniValue getvalueforname(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 2))
|
||||
throw std::runtime_error(
|
||||
"getvalueforname \"name\"\n"
|
||||
"Return the winning or specified by claimId value associated with a name\n"
|
||||
"Arguments:\n"
|
||||
"1. \"name\" (string) the name to look up\n"
|
||||
"2. \"blockhash\" (string, optional) get the value\n"
|
||||
" associated with the name\n"
|
||||
" at the block specified\n"
|
||||
" by this block hash.\n"
|
||||
" If none is given,\n"
|
||||
" the latest active\n"
|
||||
" block will be used.\n"
|
||||
"3. \"claimId\" (string, optional) can be partial one\n"
|
||||
"Result: \n"
|
||||
"\"value\" (string) the value of the name, if it exists\n"
|
||||
"\"claimId\" (string) the claimId for this name claim\n"
|
||||
"\"txid\" (string) the hash of the transaction which successfully claimed the name\n"
|
||||
"\"n\" (numeric) vout value\n"
|
||||
"\"amount\" (numeric) txout amount\n"
|
||||
"\"effective amount\" (numeric) txout amount plus amount from all supports associated with the claim\n"
|
||||
"\"height\" (numeric) the height of the block in which this transaction is located\n"
|
||||
"\"name\" (string) the original name of this claim (before normalization)\n");
|
||||
validateRequest(request, GETVALUEFORNAME, 1, 2);
|
||||
|
||||
LOCK(cs_main);
|
||||
|
||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
||||
|
@ -404,65 +345,18 @@ static UniValue getvalueforname(const JSONRPCRequest& request)
|
|||
if (claimNsupports.IsNull())
|
||||
return ret;
|
||||
|
||||
ret.pushKV("normalizedName", escapeNonUtf8(res.name));
|
||||
ret.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(res.name));
|
||||
ret.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
||||
ret.pushKV("lastTakeoverHeight", res.nLastTakeoverHeight);
|
||||
ret.pushKV(T_LASTTAKEOVERHEIGHT, res.nLastTakeoverHeight);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
UniValue getclaimsforname(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 1))
|
||||
throw std::runtime_error(
|
||||
"getclaimsforname\n"
|
||||
"Return all claims and supports for a name\n"
|
||||
"Arguments: \n"
|
||||
"1. \"name\" (string) the name for which to get claims and supports\n"
|
||||
"2. \"blockhash\" (string, optional) get claims for name\n"
|
||||
" at the block specified\n"
|
||||
" by this block hash.\n"
|
||||
" If none is given,\n"
|
||||
" the latest active\n"
|
||||
" block will be used.\n"
|
||||
"Result:\n"
|
||||
"{\n"
|
||||
" \"nLastTakeoverHeight\" (numeric) the last height at which ownership of the name changed\n"
|
||||
" \"normalized_name\" (string) the name of these claims after normalization\n"
|
||||
" \"claims\": [ (array of object) claims for this name\n"
|
||||
" {\n"
|
||||
" \"claimId\" (string) the claimId of this claim\n"
|
||||
" \"txid\" (string) the txid of this claim\n"
|
||||
" \"n\" (numeric) the index of the claim in the transaction's list of outputs\n"
|
||||
" \"nHeight\" (numeric) the height at which the claim was included in the blockchain\n"
|
||||
" \"nValidAtHeight\" (numeric) the height at which the claim became/becomes valid\n"
|
||||
" \"nAmount\" (numeric) the amount of the claim\n"
|
||||
" \"value\" (string) the metadata of the claim\n"
|
||||
" \"nEffectiveAmount\" (numeric) the total effective amount of the claim, taking into effect whether the claim or support has reached its nValidAtHeight\n"
|
||||
" \"supports\" : [ (array of object) supports for this claim\n"
|
||||
" \"txid\" (string) the txid of the support\n"
|
||||
" \"n\" (numeric) the index of the support in the transaction's list of outputs\n"
|
||||
" \"nHeight\" (numeric) the height at which the support was included in the blockchain\n"
|
||||
" \"nValidAtHeight\" (numeric) the height at which the support became/becomes valid\n"
|
||||
" \"nAmount\" (numeric) the amount of the support\n"
|
||||
" \"value\" (string) the metadata of the support if any\n"
|
||||
" ]\n"
|
||||
" \"name\" (string) the original name of this claim before normalization\n"
|
||||
" }\n"
|
||||
" ],\n"
|
||||
" \"supports without claims\": [ (array of object) supports that did not match a claim for this name\n"
|
||||
" {\n"
|
||||
" \"txid\" (string) the txid of the support\n"
|
||||
" \"n\" (numeric) the index of the support in the transaction's list of outputs\n"
|
||||
" \"nHeight\" (numeric) the height at which the support was included in the blockchain\n"
|
||||
" \"nValidAtHeight\" (numeric) the height at which the support became/becomes valid\n"
|
||||
" \"nAmount\" (numeric) the amount of the support\n"
|
||||
" }\n"
|
||||
" ]\n"
|
||||
"}\n");
|
||||
validateRequest(request, GETCLAIMSFORNAME, 1, 1);
|
||||
|
||||
LOCK(cs_main);
|
||||
|
||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
||||
|
@ -475,7 +369,7 @@ UniValue getclaimsforname(const JSONRPCRequest& request)
|
|||
auto claimsForName = trieCache.getClaimsForName(name);
|
||||
|
||||
UniValue result(UniValue::VOBJ);
|
||||
result.pushKV("normalized_name", escapeNonUtf8(claimsForName.name));
|
||||
result.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(claimsForName.name));
|
||||
|
||||
UniValue claimObjs(UniValue::VARR);
|
||||
for (auto& claim : claimsForName.claimsNsupports)
|
||||
|
@ -485,42 +379,15 @@ UniValue getclaimsforname(const JSONRPCRequest& request)
|
|||
for (auto& support : claimsForName.unmatchedSupports)
|
||||
unmatchedSupports.push_back(supportToJSON(coinsCache, support));
|
||||
|
||||
result.pushKV("claims", claimObjs);
|
||||
result.pushKV("lastTakeoverHeight", claimsForName.nLastTakeoverHeight);
|
||||
result.pushKV("supportsWithoutClaims", unmatchedSupports);
|
||||
result.pushKV(T_CLAIMS, claimObjs);
|
||||
result.pushKV(T_LASTTAKEOVERHEIGHT, claimsForName.nLastTakeoverHeight);
|
||||
result.pushKV(T_SUPPORTSWITHOUTCLAIM, unmatchedSupports);
|
||||
return result;
|
||||
}
|
||||
|
||||
UniValue getclaimbyid(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
||||
throw std::runtime_error(
|
||||
"getclaimbyid\n"
|
||||
"Get a claim by claim id\n"
|
||||
"Arguments: \n"
|
||||
"1. \"claimId\" (string) the claimId of this claim or patial id (at least 3 chars)\n"
|
||||
"Result:\n"
|
||||
"{\n"
|
||||
" \"name\" (string) the original name of the claim (before normalization)\n"
|
||||
" \"normalized_name\" (string) the name of this claim (after normalization)\n"
|
||||
" \"value\" (string) metadata of the claim\n"
|
||||
" \"claimId\" (string) the claimId of this claim\n"
|
||||
" \"txid\" (string) the hash of the transaction which has successfully claimed this name\n"
|
||||
" \"n\" (numeric) vout value\n"
|
||||
" \"amount\" (numeric) txout value\n"
|
||||
" \"effective amount\" (numeric) txout amount plus amount from all supports associated with the claim\n"
|
||||
" \"supports\" (array of object) supports for this claim\n"
|
||||
" [\n"
|
||||
" \"txid\" (string) the txid of the support\n"
|
||||
" \"n\" (numeric) the index of the support in the transaction's list of outputs\n"
|
||||
" \"height\" (numeric) the height at which the support was included in the blockchain\n"
|
||||
" \"valid at height\" (numeric) the height at which the support is valid\n"
|
||||
" \"amount\" (numeric) the amount of the support\n"
|
||||
" \"value\" (string) the metadata of the support if any\n"
|
||||
" ]\n"
|
||||
" \"height\" (numeric) the height of the block in which this claim transaction is located\n"
|
||||
" \"valid at height\" (numeric) the height at which the claim is valid\n"
|
||||
"}\n");
|
||||
validateRequest(request, GETCLAIMBYID, 1, 0);
|
||||
|
||||
LOCK(cs_main);
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
@ -540,9 +407,9 @@ UniValue getclaimbyid(const JSONRPCRequest& request)
|
|||
auto res = trieCache.getClaimsForName(name);
|
||||
auto& claimNsupports = !claimId.IsNull() ? res.find(claimId) : res.find(partialId);
|
||||
if (!claimNsupports.IsNull()) {
|
||||
claim.pushKV("normalizedName", escapeNonUtf8(res.name));
|
||||
claim.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(res.name));
|
||||
claim.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
||||
claim.pushKV("lastTakeoverHeight", res.nLastTakeoverHeight);
|
||||
claim.pushKV(T_LASTTAKEOVERHEIGHT, res.nLastTakeoverHeight);
|
||||
}
|
||||
}
|
||||
return claim;
|
||||
|
@ -550,16 +417,8 @@ UniValue getclaimbyid(const JSONRPCRequest& request)
|
|||
|
||||
UniValue gettotalclaimednames(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 0, 0))
|
||||
throw std::runtime_error(
|
||||
"gettotalclaimednames\n"
|
||||
"Return the total number of names that have been\n"
|
||||
"successfully claimed, and therefore exist in the trie\n"
|
||||
"Arguments:\n"
|
||||
"Result:\n"
|
||||
"\"total names\" (numeric) the total number of\n"
|
||||
" names in the trie\n"
|
||||
);
|
||||
validateRequest(request, GETTOTALCLAIMEDNAMES, 0, 0);
|
||||
|
||||
LOCK(cs_main);
|
||||
auto num_names = pclaimTrie->getTotalNamesInTrie();
|
||||
return int(num_names);
|
||||
|
@ -567,15 +426,8 @@ UniValue gettotalclaimednames(const JSONRPCRequest& request)
|
|||
|
||||
UniValue gettotalclaims(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 0, 0))
|
||||
throw std::runtime_error(
|
||||
"gettotalclaims\n"
|
||||
"Return the total number of active claims in the trie\n"
|
||||
"Arguments:\n"
|
||||
"Result:\n"
|
||||
"\"total claims\" (numeric) the total number\n"
|
||||
" of active claims\n"
|
||||
);
|
||||
validateRequest(request, GETTOTALCLAIMS, 0, 0);
|
||||
|
||||
LOCK(cs_main);
|
||||
auto num_claims = pclaimTrie->getTotalClaimsInTrie();
|
||||
return int(num_claims);
|
||||
|
@ -583,17 +435,8 @@ UniValue gettotalclaims(const JSONRPCRequest& request)
|
|||
|
||||
UniValue gettotalvalueofclaims(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 0, 1))
|
||||
throw std::runtime_error(
|
||||
"gettotalvalueofclaims\n"
|
||||
"Return the total value of the claims in the trie\n"
|
||||
"Arguments:\n"
|
||||
"1. \"controlling_only\" (boolean) only include the value\n"
|
||||
" of controlling claims\n"
|
||||
"Result:\n"
|
||||
"\"total value\" (numeric) the total value of the\n"
|
||||
" claims in the trie\n"
|
||||
);
|
||||
validateRequest(request, GETTOTALVALUEOFCLAIMS, 0, 1);
|
||||
|
||||
LOCK(cs_main);
|
||||
bool controlling_only = false;
|
||||
if (request.params.size() == 1)
|
||||
|
@ -604,31 +447,7 @@ UniValue gettotalvalueofclaims(const JSONRPCRequest& request)
|
|||
|
||||
UniValue getclaimsfortx(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
||||
throw std::runtime_error(
|
||||
"getclaimsfortx\n"
|
||||
"Return any claims or supports found in a transaction\n"
|
||||
"Arguments:\n"
|
||||
"1. \"txid\" (string) the txid of the transaction to check for unspent claims\n"
|
||||
"Result:\n"
|
||||
"[\n"
|
||||
" {\n"
|
||||
" \"nOut\" (numeric) the index of the claim or support in the transaction's list of outputs\n"
|
||||
" \"claim type\" (string) 'claim' or 'support'\n"
|
||||
" \"name\" (string) the name claimed or supported\n"
|
||||
" \"claimId\" (string) if a claim, its ID\n"
|
||||
" \"value\" (string) if a name claim, the value of the claim\n"
|
||||
" \"supported txid\" (string) if a support, the txid of the supported claim\n"
|
||||
" \"supported nout\" (numeric) if a support, the index of the supported claim in its transaction\n"
|
||||
" \"depth\" (numeric) the depth of the transaction in the main chain\n"
|
||||
" \"in claim trie\" (boolean) if a name claim, whether the claim is active, i.e. has made it into the trie\n"
|
||||
" \"is controlling\" (boolean) if a name claim, whether the claim is the current controlling claim for the name\n"
|
||||
" \"in support map\" (boolean) if a support, whether the support is active, i.e. has made it into the support map\n"
|
||||
" \"in queue\" (boolean) whether the claim is in a queue waiting to be inserted into the trie or support map\n"
|
||||
" \"blocks to valid\" (numeric) if in a queue, the number of blocks until it's inserted into the trie or support map\n"
|
||||
" }\n"
|
||||
"]\n"
|
||||
);
|
||||
validateRequest(request, GETCLAIMSFORTX, 1, 0);
|
||||
|
||||
LOCK(cs_main);
|
||||
uint256 hash = ParseHashV(request.params[0], "txid (parameter 1)");
|
||||
|
@ -643,102 +462,66 @@ UniValue getclaimsfortx(const JSONRPCRequest& request)
|
|||
std::vector<CTxOut> txouts{ coin.out };
|
||||
int nHeight = coin.nHeight;
|
||||
|
||||
for (unsigned int i = 0; i < txouts.size(); ++i)
|
||||
{
|
||||
if (!txouts[i].IsNull())
|
||||
{
|
||||
vvchParams.clear();
|
||||
const CTxOut& txout = txouts[i];
|
||||
UniValue o(UniValue::VOBJ);
|
||||
if (DecodeClaimScript(txout.scriptPubKey, op, vvchParams))
|
||||
{
|
||||
o.pushKV("nOut", static_cast<int64_t>(i));
|
||||
std::string sName(vvchParams[0].begin(), vvchParams[0].end());
|
||||
o.pushKV("name", escapeNonUtf8(sName));
|
||||
if (op == OP_CLAIM_NAME)
|
||||
{
|
||||
uint160 claimId = ClaimIdHash(hash, i);
|
||||
o.pushKV("claimId", claimId.GetHex());
|
||||
o.pushKV("value", HexStr(vvchParams[1].begin(), vvchParams[1].end()));
|
||||
}
|
||||
else if (op == OP_UPDATE_CLAIM)
|
||||
{
|
||||
uint160 claimId(vvchParams[1]);
|
||||
o.pushKV("claimId", claimId.GetHex());
|
||||
o.pushKV("value", HexStr(vvchParams[2].begin(), vvchParams[2].end()));
|
||||
}
|
||||
else if (op == OP_SUPPORT_CLAIM)
|
||||
{
|
||||
uint160 supportedClaimId(vvchParams[1]);
|
||||
o.pushKV("supported claimId", supportedClaimId.GetHex());
|
||||
if (vvchParams.size() > 2)
|
||||
o.pushKV("supported value", HexStr(vvchParams[2].begin(), vvchParams[2].end()));
|
||||
}
|
||||
if (nHeight > 0)
|
||||
{
|
||||
o.pushKV("depth", chainActive.Height() - nHeight);
|
||||
if (op == OP_CLAIM_NAME || op == OP_UPDATE_CLAIM)
|
||||
{
|
||||
bool inClaimTrie = trieCache.haveClaim(sName, COutPoint(hash, i));
|
||||
o.pushKV("in claim trie", inClaimTrie);
|
||||
if (inClaimTrie)
|
||||
{
|
||||
CClaimValue claim;
|
||||
if (!trieCache.getInfoForName(sName, claim))
|
||||
{
|
||||
LogPrintf("HaveClaim was true but getInfoForName returned false.");
|
||||
}
|
||||
o.pushKV("is controlling", (claim.outPoint.hash == hash && claim.outPoint.n == i));
|
||||
}
|
||||
else
|
||||
{
|
||||
int nValidAtHeight;
|
||||
if (trieCache.haveClaimInQueue(sName, COutPoint(hash, i), nValidAtHeight))
|
||||
{
|
||||
o.pushKV("in queue", true);
|
||||
o.pushKV("blocks to valid", nValidAtHeight - chainActive.Height());
|
||||
}
|
||||
else
|
||||
{
|
||||
o.pushKV("in queue", false);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (op == OP_SUPPORT_CLAIM)
|
||||
{
|
||||
bool inSupportMap = trieCache.haveSupport(sName, COutPoint(hash, i));
|
||||
o.pushKV("in support map", inSupportMap);
|
||||
if (!inSupportMap)
|
||||
{
|
||||
int nValidAtHeight;
|
||||
if (trieCache.haveSupportInQueue(sName, COutPoint(hash, i), nValidAtHeight))
|
||||
{
|
||||
o.pushKV("in queue", true);
|
||||
o.pushKV("blocks to valid", nValidAtHeight - chainActive.Height());
|
||||
}
|
||||
else
|
||||
{
|
||||
o.pushKV("in queue", false);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
o.pushKV("depth", 0);
|
||||
if (op == OP_CLAIM_NAME || op == OP_UPDATE_CLAIM)
|
||||
{
|
||||
o.pushKV("in claim trie", false);
|
||||
}
|
||||
else if (op == OP_SUPPORT_CLAIM)
|
||||
{
|
||||
o.pushKV("in support map", false);
|
||||
}
|
||||
o.pushKV("in queue", false);
|
||||
}
|
||||
ret.push_back(o);
|
||||
}
|
||||
for (unsigned int i = 0; i < txouts.size(); ++i) {
|
||||
if (txouts[i].IsNull())
|
||||
continue;
|
||||
vvchParams.clear();
|
||||
const CTxOut& txout = txouts[i];
|
||||
if (!DecodeClaimScript(txout.scriptPubKey, op, vvchParams))
|
||||
continue;
|
||||
UniValue o(UniValue::VOBJ);
|
||||
o.pushKV(T_N, static_cast<int64_t>(i));
|
||||
std::string sName(vvchParams[0].begin(), vvchParams[0].end());
|
||||
o.pushKV(T_NAME, escapeNonUtf8(sName));
|
||||
if (op == OP_CLAIM_NAME) {
|
||||
uint160 claimId = ClaimIdHash(hash, i);
|
||||
o.pushKV(T_CLAIMID, claimId.GetHex());
|
||||
o.pushKV(T_VALUE, HexStr(vvchParams[1].begin(), vvchParams[1].end()));
|
||||
} else if (op == OP_UPDATE_CLAIM || op == OP_SUPPORT_CLAIM) {
|
||||
uint160 claimId(vvchParams[1]);
|
||||
o.pushKV(T_CLAIMID, claimId.GetHex());
|
||||
if (vvchParams.size() > 2)
|
||||
o.pushKV(T_VALUE, HexStr(vvchParams[2].begin(), vvchParams[2].end()));
|
||||
}
|
||||
if (nHeight > 0) {
|
||||
o.pushKV(T_DEPTH, chainActive.Height() - nHeight);
|
||||
if (op == OP_CLAIM_NAME || op == OP_UPDATE_CLAIM) {
|
||||
bool inClaimTrie = trieCache.haveClaim(sName, COutPoint(hash, i));
|
||||
o.pushKV(T_INCLAIMTRIE, inClaimTrie);
|
||||
if (inClaimTrie) {
|
||||
CClaimValue claim;
|
||||
if (!trieCache.getInfoForName(sName, claim))
|
||||
LogPrintf("HaveClaim was true but getInfoForName returned false.");
|
||||
o.pushKV(T_ISCONTROLLING, (claim.outPoint.hash == hash && claim.outPoint.n == i));
|
||||
} else {
|
||||
int nValidAtHeight;
|
||||
if (trieCache.haveClaimInQueue(sName, COutPoint(hash, i), nValidAtHeight)) {
|
||||
o.pushKV(T_INQUEUE, true);
|
||||
o.pushKV(T_BLOCKSTOVALID, nValidAtHeight - chainActive.Height());
|
||||
} else
|
||||
o.pushKV(T_INQUEUE, false);
|
||||
}
|
||||
} else if (op == OP_SUPPORT_CLAIM) {
|
||||
bool inSupportMap = trieCache.haveSupport(sName, COutPoint(hash, i));
|
||||
o.pushKV(T_INSUPPORTMAP, inSupportMap);
|
||||
if (!inSupportMap) {
|
||||
int nValidAtHeight;
|
||||
if (trieCache.haveSupportInQueue(sName, COutPoint(hash, i), nValidAtHeight)) {
|
||||
o.pushKV(T_INQUEUE, true);
|
||||
o.pushKV(T_BLOCKSTOVALID, nValidAtHeight - chainActive.Height());
|
||||
} else
|
||||
o.pushKV(T_INQUEUE, false);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
o.pushKV(T_DEPTH, 0);
|
||||
if (op == OP_CLAIM_NAME || op == OP_UPDATE_CLAIM)
|
||||
o.pushKV(T_INCLAIMTRIE, false);
|
||||
else if (op == OP_SUPPORT_CLAIM)
|
||||
o.pushKV(T_INSUPPORTMAP, false);
|
||||
o.pushKV(T_INQUEUE, false);
|
||||
}
|
||||
ret.push_back(o);
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
@ -754,111 +537,46 @@ UniValue proofToJSON(const CClaimTrieProof& proof)
|
|||
|
||||
for (const auto& itChildren : itNode.children) {
|
||||
UniValue child(UniValue::VOBJ);
|
||||
child.pushKV("character", itChildren.first);
|
||||
child.pushKV(T_CHARACTER, itChildren.first);
|
||||
if (!itChildren.second.IsNull())
|
||||
child.pushKV("nodeHash", itChildren.second.GetHex());
|
||||
child.pushKV(T_NODEHASH, itChildren.second.GetHex());
|
||||
children.push_back(child);
|
||||
}
|
||||
|
||||
node.pushKV("children", children);
|
||||
node.pushKV(T_CHILDREN, children);
|
||||
|
||||
if (itNode.hasValue && !itNode.valHash.IsNull())
|
||||
node.pushKV("valueHash", itNode.valHash.GetHex());
|
||||
|
||||
node.pushKV(T_VALUEHASH, itNode.valHash.GetHex());
|
||||
nodes.push_back(node);
|
||||
}
|
||||
|
||||
if (!nodes.empty())
|
||||
result.push_back(Pair("nodes", nodes));
|
||||
result.push_back(Pair(T_NODES, nodes));
|
||||
|
||||
UniValue pairs(UniValue::VARR);
|
||||
|
||||
for (const auto& itPair : proof.pairs) {
|
||||
UniValue child(UniValue::VOBJ);
|
||||
child.push_back(Pair("odd", itPair.first));
|
||||
child.push_back(Pair("hash", itPair.second.GetHex()));
|
||||
child.push_back(Pair(T_ODD, itPair.first));
|
||||
child.push_back(Pair(T_HASH, itPair.second.GetHex()));
|
||||
pairs.push_back(child);
|
||||
}
|
||||
|
||||
if (!pairs.empty())
|
||||
result.push_back(Pair("pairs", pairs));
|
||||
result.push_back(Pair(T_PAIRS, pairs));
|
||||
|
||||
if (proof.hasValue) {
|
||||
result.pushKV("txhash", proof.outPoint.hash.GetHex());
|
||||
result.pushKV("nOut", (int)proof.outPoint.n);
|
||||
result.pushKV("last takeover height", (int)proof.nHeightOfLastTakeover);
|
||||
result.pushKV(T_TXID, proof.outPoint.hash.GetHex());
|
||||
result.pushKV(T_N, (int)proof.outPoint.n);
|
||||
result.pushKV(T_LASTTAKEOVERHEIGHT, (int)proof.nHeightOfLastTakeover);
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
UniValue getnameproof(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 2))
|
||||
throw std::runtime_error(
|
||||
"getnameproof\n"
|
||||
"Return the cryptographic proof that a name maps to a value\n"
|
||||
"or doesn't.\n"
|
||||
"Arguments:\n"
|
||||
"1. \"name\" (string) the name to get a proof for\n"
|
||||
"2. \"blockhash\" (string, optional) the hash of the block\n"
|
||||
" which is the basis\n"
|
||||
" of the proof. If\n"
|
||||
" none is given, \n"
|
||||
" the latest block\n"
|
||||
" will be used.\n"
|
||||
"3. \"claimId\" (string, optional, post-fork) for validating a specific claim\n"
|
||||
"Result: \n"
|
||||
"{\n"
|
||||
" \"nodes\" : [ (array of object, pre-fork) full nodes (i.e.\n"
|
||||
" those which lead to\n"
|
||||
" the requested name)\n"
|
||||
" \"children\" : [ (array of object) the children of\n"
|
||||
" this node\n"
|
||||
" \"child\" : { (object) a child node, either leaf or\n"
|
||||
" reference to a full node\n"
|
||||
" \"character\" : \"char\" (string) the character which\n"
|
||||
" leads from the parent\n"
|
||||
" to this child node\n"
|
||||
" \"nodeHash\" : \"hash\" (string, if exists) the hash of\n"
|
||||
" the node if\n"
|
||||
" this is a \n"
|
||||
" leaf node\n"
|
||||
" }\n"
|
||||
" ]\n"
|
||||
" \"valueHash\" (string, if exists) the hash of this\n"
|
||||
" node's value, if\n"
|
||||
" it has one. If \n"
|
||||
" this is the\n"
|
||||
" requested name\n"
|
||||
" this will not\n"
|
||||
" exist whether\n"
|
||||
" the node has a\n"
|
||||
" value or not\n"
|
||||
" ]\n"
|
||||
" \"pairs\" : [ (array of pairs, post-fork) hash can be validated by \n"
|
||||
" hashing claim from the bottom up\n"
|
||||
" {\n"
|
||||
" \"odd\" (boolean) this value goes on the right of hash\n"
|
||||
" \"hash\" (boolean) the hash to be mixed in\n"
|
||||
" }\n"
|
||||
" ]\n"
|
||||
" \"txhash\" : \"hash\" (string, if exists) the txid of the\n"
|
||||
" claim which controls\n"
|
||||
" this name, if there\n"
|
||||
" is one.\n"
|
||||
" \"nOut\" : n, (numeric) the nOut of the claim which\n"
|
||||
" controls this name, if there\n"
|
||||
" is one.\n"
|
||||
" \"last takeover height\" (numeric) the most recent height at\n"
|
||||
" which the value of a name\n"
|
||||
" changed other than through\n"
|
||||
" an update to the winning\n"
|
||||
" bid\n"
|
||||
" }\n"
|
||||
"}\n");
|
||||
validateRequest(request, GETNAMEPROOF, 1, 2);
|
||||
|
||||
LOCK(cs_main);
|
||||
|
||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||
CClaimTrieCache trieCache(pclaimTrie);
|
||||
|
||||
|
@ -892,14 +610,7 @@ UniValue getnameproof(const JSONRPCRequest& request)
|
|||
|
||||
UniValue checknormalization(const JSONRPCRequest& request)
|
||||
{
|
||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
||||
throw std::runtime_error(
|
||||
"checknormalization\n"
|
||||
"Given an unnormalized name of a claim, return normalized version of it\n"
|
||||
"Arguments:\n"
|
||||
"1. \"name\" (string) the name to normalize\n"
|
||||
"Result: \n"
|
||||
"\"normalized\" (string) fully normalized name\n");
|
||||
validateRequest(request, CHECKNORMALIZATION, 1, 0);
|
||||
|
||||
const bool force = true;
|
||||
const std::string name = request.params[0].get_str();
|
||||
|
@ -911,18 +622,18 @@ UniValue checknormalization(const JSONRPCRequest& request)
|
|||
static const CRPCCommand commands[] =
|
||||
{ // category name actor (function) argNames
|
||||
// --------------------- ------------------------ ----------------------- ----------
|
||||
{ "Claimtrie", "getclaimsintrie", &getclaimsintrie, { "blockhash" } },
|
||||
{ "Claimtrie", "getnamesintrie", &getnamesintrie, { "blockhash" } },
|
||||
{ "Claimtrie", "getclaimsintrie", &getclaimsintrie, { T_BLOCKHASH } },
|
||||
{ "Claimtrie", "getnamesintrie", &getnamesintrie, { T_BLOCKHASH } },
|
||||
{ "hidden", "getclaimtrie", &getclaimtrie, { } },
|
||||
{ "Claimtrie", "getvalueforname", &getvalueforname, { "name","blockhash","claimId" } },
|
||||
{ "Claimtrie", "getclaimsforname", &getclaimsforname, { "name","blockhash" } },
|
||||
{ "Claimtrie", "getvalueforname", &getvalueforname, { T_NAME,T_BLOCKHASH,T_CLAIMID } },
|
||||
{ "Claimtrie", "getclaimsforname", &getclaimsforname, { T_NAME,T_BLOCKHASH } },
|
||||
{ "Claimtrie", "gettotalclaimednames", &gettotalclaimednames, { "" } },
|
||||
{ "Claimtrie", "gettotalclaims", &gettotalclaims, { "" } },
|
||||
{ "Claimtrie", "gettotalvalueofclaims", &gettotalvalueofclaims, { "controlling_only" } },
|
||||
{ "Claimtrie", "getclaimsfortx", &getclaimsfortx, { "txid" } },
|
||||
{ "Claimtrie", "getnameproof", &getnameproof, { "name","blockhash","claimId"} },
|
||||
{ "Claimtrie", "getclaimbyid", &getclaimbyid, { "claimId" } },
|
||||
{ "Claimtrie", "checknormalization", &checknormalization, { "name" }},
|
||||
{ "Claimtrie", "gettotalvalueofclaims", &gettotalvalueofclaims, { T_CONTROLLINGONLY } },
|
||||
{ "Claimtrie", "getclaimsfortx", &getclaimsfortx, { T_TXID } },
|
||||
{ "Claimtrie", "getnameproof", &getnameproof, { T_NAME,T_BLOCKHASH,T_CLAIMID} },
|
||||
{ "Claimtrie", "getclaimbyid", &getclaimbyid, { T_CLAIMID } },
|
||||
{ "Claimtrie", "checknormalization", &checknormalization, { T_NAME }},
|
||||
};
|
||||
|
||||
void RegisterClaimTrieRPCCommands(CRPCTable &tableRPC)
|
||||
|
|
|
@ -13,6 +13,7 @@
|
|||
#include <pow.h>
|
||||
#include <primitives/transaction.h>
|
||||
#include <random.h>
|
||||
#include <rpc/claimrpchelp.h>
|
||||
#include <rpc/server.h>
|
||||
#include <streams.h>
|
||||
#include <test/test_bitcoin.h>
|
||||
|
@ -3971,15 +3972,15 @@ BOOST_AUTO_TEST_CASE(getvalueforname_test)
|
|||
req.params.push_back(UniValue(sName1));
|
||||
|
||||
UniValue results = getvalueforname(req);
|
||||
BOOST_CHECK_EQUAL(results["value"].get_str(), HexStr(sValue1));
|
||||
BOOST_CHECK_EQUAL(results["amount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(results["effectiveAmount"].get_int(), 5);
|
||||
BOOST_CHECK_EQUAL(results[T_VALUE].get_str(), HexStr(sValue1));
|
||||
BOOST_CHECK_EQUAL(results[T_AMOUNT].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(results[T_EFFECTIVEAMOUNT].get_int(), 5);
|
||||
|
||||
req.params.push_back(blockHash.GetHex());
|
||||
|
||||
results = getvalueforname(req);
|
||||
BOOST_CHECK_EQUAL(results["amount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(results["effectiveAmount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(results[T_AMOUNT].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(results[T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(getclaimsforname_test)
|
||||
|
@ -4005,31 +4006,31 @@ BOOST_AUTO_TEST_CASE(getclaimsforname_test)
|
|||
req.params.push_back(UniValue(sName1));
|
||||
|
||||
UniValue results = getclaimsforname(req);
|
||||
UniValue claims = results["claims"];
|
||||
UniValue claims = results[T_CLAIMS];
|
||||
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 1);
|
||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 1);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||
|
||||
fixture.IncrementBlocks(1);
|
||||
|
||||
results = getclaimsforname(req);
|
||||
claims = results["claims"];
|
||||
claims = results[T_CLAIMS];
|
||||
BOOST_CHECK_EQUAL(claims.size(), 2U);
|
||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 3);
|
||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 3);
|
||||
BOOST_CHECK_EQUAL(claims[1]["effectiveAmount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(claims[1]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 3);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 3);
|
||||
BOOST_CHECK_EQUAL(claims[1][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(claims[1][T_SUPPORTS].size(), 0U);
|
||||
|
||||
req.params.push_back(blockHash.GetHex());
|
||||
|
||||
results = getclaimsforname(req);
|
||||
claims = results["claims"];
|
||||
claims = results[T_CLAIMS];
|
||||
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 1);
|
||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 1);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(claim_rpcs_rollback2_test)
|
||||
|
@ -4059,13 +4060,13 @@ BOOST_AUTO_TEST_CASE(claim_rpcs_rollback2_test)
|
|||
req.params.push_back(blockHash.GetHex());
|
||||
|
||||
UniValue claimsResults = getclaimsforname(req);
|
||||
BOOST_CHECK_EQUAL(claimsResults["lastTakeoverHeight"].get_int(), height + 5);
|
||||
BOOST_CHECK_EQUAL(claimsResults["claims"][0]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(claimsResults["claims"][1]["supports"].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(claimsResults[T_LASTTAKEOVERHEIGHT].get_int(), height + 5);
|
||||
BOOST_CHECK_EQUAL(claimsResults[T_CLAIMS][0][T_SUPPORTS].size(), 0U);
|
||||
BOOST_CHECK_EQUAL(claimsResults[T_CLAIMS][1][T_SUPPORTS].size(), 0U);
|
||||
|
||||
UniValue valueResults = getvalueforname(req);
|
||||
BOOST_CHECK_EQUAL(valueResults["value"].get_str(), HexStr(sValue2));
|
||||
BOOST_CHECK_EQUAL(valueResults["amount"].get_int(), 2);
|
||||
BOOST_CHECK_EQUAL(valueResults[T_VALUE].get_str(), HexStr(sValue2));
|
||||
BOOST_CHECK_EQUAL(valueResults[T_AMOUNT].get_int(), 2);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(claim_rpcs_rollback3_test)
|
||||
|
@ -4100,11 +4101,11 @@ BOOST_AUTO_TEST_CASE(claim_rpcs_rollback3_test)
|
|||
req.params.push_back(blockHash.GetHex());
|
||||
|
||||
UniValue claimsResults = getclaimsforname(req);
|
||||
BOOST_CHECK_EQUAL(claimsResults["lastTakeoverHeight"].get_int(), height + 1);
|
||||
BOOST_CHECK_EQUAL(claimsResults[T_LASTTAKEOVERHEIGHT].get_int(), height + 1);
|
||||
|
||||
UniValue valueResults = getvalueforname(req);
|
||||
BOOST_CHECK_EQUAL(valueResults["value"].get_str(), HexStr(sValue1));
|
||||
BOOST_CHECK_EQUAL(valueResults["amount"].get_int(), 3);
|
||||
BOOST_CHECK_EQUAL(valueResults[T_VALUE].get_str(), HexStr(sValue1));
|
||||
BOOST_CHECK_EQUAL(valueResults[T_AMOUNT].get_int(), 3);
|
||||
}
|
||||
|
||||
BOOST_AUTO_TEST_CASE(update_on_support2_test)
|
||||
|
|
Loading…
Reference in a new issue