diff --git a/src/Makefile.am b/src/Makefile.am index d1e393264..eb50b59ec 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -179,6 +179,7 @@ BITCOIN_CORE_H = \ reverse_iterator.h \ reverselock.h \ rpc/blockchain.h \ + rpc/claimrpchelp.h \ rpc/client.h \ rpc/protocol.h \ rpc/rawtransaction_util.h \ diff --git a/src/rpc/claimrpchelp.h b/src/rpc/claimrpchelp.h new file mode 100644 index 000000000..28202f8bb --- /dev/null +++ b/src/rpc/claimrpchelp.h @@ -0,0 +1,290 @@ + +#include + +// 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 +)", + +}; diff --git a/src/rpc/claimtrie.cpp b/src/rpc/claimtrie.cpp index 479c192ae..d9ca050cd 100644 --- a/src/rpc/claimtrie.cpp +++ b/src/rpc/claimtrie.cpp @@ -3,6 +3,7 @@ #include #include #include +#include #include #include #include @@ -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 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(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(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) diff --git a/src/test/claimtriebranching_tests.cpp b/src/test/claimtriebranching_tests.cpp index cb22e554e..454162d0a 100644 --- a/src/test/claimtriebranching_tests.cpp +++ b/src/test/claimtriebranching_tests.cpp @@ -13,6 +13,7 @@ #include #include #include +#include #include #include #include @@ -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)