Split help and rpc methods
Use constants for field names Signed-off-by: Anthony Fieroni <bvbfan@abv.bg>
This commit is contained in:
parent
f0ec79d047
commit
3c693027e5
4 changed files with 448 additions and 445 deletions
|
@ -179,6 +179,7 @@ BITCOIN_CORE_H = \
|
||||||
reverse_iterator.h \
|
reverse_iterator.h \
|
||||||
reverselock.h \
|
reverselock.h \
|
||||||
rpc/blockchain.h \
|
rpc/blockchain.h \
|
||||||
|
rpc/claimrpchelp.h \
|
||||||
rpc/client.h \
|
rpc/client.h \
|
||||||
rpc/protocol.h \
|
rpc/protocol.h \
|
||||||
rpc/rawtransaction_util.h \
|
rpc/rawtransaction_util.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 <core_io.h>
|
||||||
#include <logging.h>
|
#include <logging.h>
|
||||||
#include <nameclaim.h>
|
#include <nameclaim.h>
|
||||||
|
#include <rpc/claimrpchelp.h>
|
||||||
#include <rpc/server.h>
|
#include <rpc/server.h>
|
||||||
#include <shutdown.h>
|
#include <shutdown.h>
|
||||||
#include <txdb.h>
|
#include <txdb.h>
|
||||||
|
@ -24,6 +25,8 @@ void ParseClaimtrieId(const UniValue& v, std::string& partialId, uint160& claimI
|
||||||
strHex = v.get_str();
|
strHex = v.get_str();
|
||||||
if (!IsHex(strHex))
|
if (!IsHex(strHex))
|
||||||
throw JSONRPCError(RPC_INVALID_PARAMETER, strName + " must be a hexadecimal string");
|
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)
|
if (strHex.length() == claimIdHexLength)
|
||||||
claimId.SetHex(strHex);
|
claimId.SetHex(strHex);
|
||||||
else
|
else
|
||||||
|
@ -173,18 +176,18 @@ UniValue claimToJSON(const CCoinsViewCache& coinsCache, const CClaimValue& claim
|
||||||
|
|
||||||
std::string targetName;
|
std::string targetName;
|
||||||
if (getClaimById(claim.claimId, targetName))
|
if (getClaimById(claim.claimId, targetName))
|
||||||
result.pushKV("name", escapeNonUtf8(targetName));
|
result.pushKV(T_NAME, escapeNonUtf8(targetName));
|
||||||
|
|
||||||
std::string sValue;
|
std::string sValue;
|
||||||
if (getValueForOutPoint(coinsCache, claim.outPoint, sValue))
|
if (getValueForOutPoint(coinsCache, claim.outPoint, sValue))
|
||||||
result.pushKV("value", sValue);
|
result.pushKV(T_VALUE, sValue);
|
||||||
|
|
||||||
result.pushKV("claimId", claim.claimId.GetHex());
|
result.pushKV(T_CLAIMID, claim.claimId.GetHex());
|
||||||
result.pushKV("txId", claim.outPoint.hash.GetHex());
|
result.pushKV(T_TXID, claim.outPoint.hash.GetHex());
|
||||||
result.pushKV("n", (int)claim.outPoint.n);
|
result.pushKV(T_N, (int)claim.outPoint.n);
|
||||||
result.pushKV("height", claim.nHeight);
|
result.pushKV(T_HEIGHT, claim.nHeight);
|
||||||
result.pushKV("validAtHeight", claim.nValidAtHeight);
|
result.pushKV(T_VALIDATHEIGHT, claim.nValidAtHeight);
|
||||||
result.pushKV("amount", claim.nAmount);
|
result.pushKV(T_AMOUNT, claim.nAmount);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -195,13 +198,13 @@ UniValue supportToJSON(const CCoinsViewCache& coinsCache, const CSupportValue& s
|
||||||
|
|
||||||
std::string value;
|
std::string value;
|
||||||
if (getValueForOutPoint(coinsCache, support.outPoint, 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(T_TXID, support.outPoint.hash.GetHex());
|
||||||
ret.pushKV("n", (int)support.outPoint.n);
|
ret.pushKV(T_N, (int)support.outPoint.n);
|
||||||
ret.pushKV("height", support.nHeight);
|
ret.pushKV(T_HEIGHT, support.nHeight);
|
||||||
ret.pushKV("validAtHeight", support.nValidAtHeight);
|
ret.pushKV(T_VALIDATHEIGHT, support.nValidAtHeight);
|
||||||
ret.pushKV("amount", support.nAmount);
|
ret.pushKV(T_AMOUNT, support.nAmount);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -212,17 +215,14 @@ UniValue claimAndSupportsToJSON(const CCoinsViewCache& coinsCache, const CClaimN
|
||||||
auto& supports = claimNsupports.supports;
|
auto& supports = claimNsupports.supports;
|
||||||
|
|
||||||
auto result = claimToJSON(coinsCache, claim);
|
auto result = claimToJSON(coinsCache, claim);
|
||||||
result.pushKV("effectiveAmount", claimNsupports.effectiveAmount);
|
result.pushKV(T_EFFECTIVEAMOUNT, claimNsupports.effectiveAmount);
|
||||||
|
|
||||||
if (claim.nEffectiveAmount > claimNsupports.effectiveAmount)
|
|
||||||
result.pushKV("pendingEffectiveAmount", claim.nEffectiveAmount);
|
|
||||||
|
|
||||||
UniValue supportObjs(UniValue::VARR);
|
UniValue supportObjs(UniValue::VARR);
|
||||||
for (auto& support : supports)
|
for (auto& support : supports)
|
||||||
supportObjs.push_back(supportToJSON(coinsCache, support));
|
supportObjs.push_back(supportToJSON(coinsCache, support));
|
||||||
|
|
||||||
if (!supportObjs.empty())
|
if (!supportObjs.empty())
|
||||||
result.pushKV("supports", supportObjs);
|
result.pushKV(T_SUPPORTS, supportObjs);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -233,48 +233,25 @@ bool validParams(const UniValue& params, uint8_t required, uint8_t optional)
|
||||||
return count >= required && count <= required + 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)
|
static UniValue getclaimsintrie(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || request.params.size() > 1)
|
validateRequest(request, GETCLAIMSINTRIE, 0, 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");
|
|
||||||
|
|
||||||
if (!IsDeprecatedRPCEnabled("getclaimsintrie")) {
|
if (!IsDeprecatedRPCEnabled("getclaimsintrie")) {
|
||||||
const auto msg = "getclaimsintrie is deprecated and will be removed in v0.18. To use this command, start with -deprecatedrpc=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 std::runtime_error(msg);
|
||||||
}
|
|
||||||
throw JSONRPCError(RPC_METHOD_DEPRECATED, msg);
|
throw JSONRPCError(RPC_METHOD_DEPRECATED, msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
UniValue ret(UniValue::VARR);
|
UniValue ret(UniValue::VARR);
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
|
||||||
|
@ -297,8 +274,8 @@ static UniValue getclaimsintrie(const JSONRPCRequest& request)
|
||||||
claims.push_back(claimToJSON(coinsCache, claim));
|
claims.push_back(claimToJSON(coinsCache, claim));
|
||||||
|
|
||||||
UniValue nodeObj(UniValue::VOBJ);
|
UniValue nodeObj(UniValue::VOBJ);
|
||||||
nodeObj.pushKV("normalized_name", escapeNonUtf8(name));
|
nodeObj.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(name));
|
||||||
nodeObj.pushKV("claims", claims);
|
nodeObj.pushKV(T_CLAIMS, claims);
|
||||||
ret.push_back(nodeObj);
|
ret.push_back(nodeObj);
|
||||||
});
|
});
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -312,22 +289,9 @@ static UniValue getclaimtrie(const JSONRPCRequest& request)
|
||||||
|
|
||||||
static UniValue getnamesintrie(const JSONRPCRequest& request)
|
static UniValue getnamesintrie(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 0, 1))
|
validateRequest(request, GETNAMESINTRIE, 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");
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
|
||||||
|
@ -351,32 +315,9 @@ static UniValue getnamesintrie(const JSONRPCRequest& request)
|
||||||
|
|
||||||
static UniValue getvalueforname(const JSONRPCRequest& request)
|
static UniValue getvalueforname(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 2))
|
validateRequest(request, GETVALUEFORNAME, 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");
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
|
||||||
|
@ -404,65 +345,18 @@ static UniValue getvalueforname(const JSONRPCRequest& request)
|
||||||
if (claimNsupports.IsNull())
|
if (claimNsupports.IsNull())
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
ret.pushKV("normalizedName", escapeNonUtf8(res.name));
|
ret.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(res.name));
|
||||||
ret.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
ret.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
||||||
ret.pushKV("lastTakeoverHeight", res.nLastTakeoverHeight);
|
ret.pushKV(T_LASTTAKEOVERHEIGHT, res.nLastTakeoverHeight);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
UniValue getclaimsforname(const JSONRPCRequest& request)
|
UniValue getclaimsforname(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 1))
|
validateRequest(request, GETCLAIMSFORNAME, 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");
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
|
||||||
|
@ -475,7 +369,7 @@ UniValue getclaimsforname(const JSONRPCRequest& request)
|
||||||
auto claimsForName = trieCache.getClaimsForName(name);
|
auto claimsForName = trieCache.getClaimsForName(name);
|
||||||
|
|
||||||
UniValue result(UniValue::VOBJ);
|
UniValue result(UniValue::VOBJ);
|
||||||
result.pushKV("normalized_name", escapeNonUtf8(claimsForName.name));
|
result.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(claimsForName.name));
|
||||||
|
|
||||||
UniValue claimObjs(UniValue::VARR);
|
UniValue claimObjs(UniValue::VARR);
|
||||||
for (auto& claim : claimsForName.claimsNsupports)
|
for (auto& claim : claimsForName.claimsNsupports)
|
||||||
|
@ -485,42 +379,15 @@ UniValue getclaimsforname(const JSONRPCRequest& request)
|
||||||
for (auto& support : claimsForName.unmatchedSupports)
|
for (auto& support : claimsForName.unmatchedSupports)
|
||||||
unmatchedSupports.push_back(supportToJSON(coinsCache, support));
|
unmatchedSupports.push_back(supportToJSON(coinsCache, support));
|
||||||
|
|
||||||
result.pushKV("claims", claimObjs);
|
result.pushKV(T_CLAIMS, claimObjs);
|
||||||
result.pushKV("lastTakeoverHeight", claimsForName.nLastTakeoverHeight);
|
result.pushKV(T_LASTTAKEOVERHEIGHT, claimsForName.nLastTakeoverHeight);
|
||||||
result.pushKV("supportsWithoutClaims", unmatchedSupports);
|
result.pushKV(T_SUPPORTSWITHOUTCLAIM, unmatchedSupports);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
UniValue getclaimbyid(const JSONRPCRequest& request)
|
UniValue getclaimbyid(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
validateRequest(request, GETCLAIMBYID, 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");
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
@ -540,9 +407,9 @@ UniValue getclaimbyid(const JSONRPCRequest& request)
|
||||||
auto res = trieCache.getClaimsForName(name);
|
auto res = trieCache.getClaimsForName(name);
|
||||||
auto& claimNsupports = !claimId.IsNull() ? res.find(claimId) : res.find(partialId);
|
auto& claimNsupports = !claimId.IsNull() ? res.find(claimId) : res.find(partialId);
|
||||||
if (!claimNsupports.IsNull()) {
|
if (!claimNsupports.IsNull()) {
|
||||||
claim.pushKV("normalizedName", escapeNonUtf8(res.name));
|
claim.pushKV(T_NORMALIZEDNAME, escapeNonUtf8(res.name));
|
||||||
claim.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
claim.pushKVs(claimAndSupportsToJSON(coinsCache, claimNsupports));
|
||||||
claim.pushKV("lastTakeoverHeight", res.nLastTakeoverHeight);
|
claim.pushKV(T_LASTTAKEOVERHEIGHT, res.nLastTakeoverHeight);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return claim;
|
return claim;
|
||||||
|
@ -550,16 +417,8 @@ UniValue getclaimbyid(const JSONRPCRequest& request)
|
||||||
|
|
||||||
UniValue gettotalclaimednames(const JSONRPCRequest& request)
|
UniValue gettotalclaimednames(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 0, 0))
|
validateRequest(request, GETTOTALCLAIMEDNAMES, 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"
|
|
||||||
);
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
auto num_names = pclaimTrie->getTotalNamesInTrie();
|
auto num_names = pclaimTrie->getTotalNamesInTrie();
|
||||||
return int(num_names);
|
return int(num_names);
|
||||||
|
@ -567,15 +426,8 @@ UniValue gettotalclaimednames(const JSONRPCRequest& request)
|
||||||
|
|
||||||
UniValue gettotalclaims(const JSONRPCRequest& request)
|
UniValue gettotalclaims(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 0, 0))
|
validateRequest(request, GETTOTALCLAIMS, 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"
|
|
||||||
);
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
auto num_claims = pclaimTrie->getTotalClaimsInTrie();
|
auto num_claims = pclaimTrie->getTotalClaimsInTrie();
|
||||||
return int(num_claims);
|
return int(num_claims);
|
||||||
|
@ -583,17 +435,8 @@ UniValue gettotalclaims(const JSONRPCRequest& request)
|
||||||
|
|
||||||
UniValue gettotalvalueofclaims(const JSONRPCRequest& request)
|
UniValue gettotalvalueofclaims(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 0, 1))
|
validateRequest(request, GETTOTALVALUEOFCLAIMS, 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"
|
|
||||||
);
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
bool controlling_only = false;
|
bool controlling_only = false;
|
||||||
if (request.params.size() == 1)
|
if (request.params.size() == 1)
|
||||||
|
@ -604,31 +447,7 @@ UniValue gettotalvalueofclaims(const JSONRPCRequest& request)
|
||||||
|
|
||||||
UniValue getclaimsfortx(const JSONRPCRequest& request)
|
UniValue getclaimsfortx(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
validateRequest(request, GETCLAIMSFORTX, 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"
|
|
||||||
);
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
uint256 hash = ParseHashV(request.params[0], "txid (parameter 1)");
|
uint256 hash = ParseHashV(request.params[0], "txid (parameter 1)");
|
||||||
|
@ -643,102 +462,66 @@ UniValue getclaimsfortx(const JSONRPCRequest& request)
|
||||||
std::vector<CTxOut> txouts{ coin.out };
|
std::vector<CTxOut> txouts{ coin.out };
|
||||||
int nHeight = coin.nHeight;
|
int nHeight = coin.nHeight;
|
||||||
|
|
||||||
for (unsigned int i = 0; i < txouts.size(); ++i)
|
for (unsigned int i = 0; i < txouts.size(); ++i) {
|
||||||
{
|
if (txouts[i].IsNull())
|
||||||
if (!txouts[i].IsNull())
|
continue;
|
||||||
{
|
vvchParams.clear();
|
||||||
vvchParams.clear();
|
const CTxOut& txout = txouts[i];
|
||||||
const CTxOut& txout = txouts[i];
|
if (!DecodeClaimScript(txout.scriptPubKey, op, vvchParams))
|
||||||
UniValue o(UniValue::VOBJ);
|
continue;
|
||||||
if (DecodeClaimScript(txout.scriptPubKey, op, vvchParams))
|
UniValue o(UniValue::VOBJ);
|
||||||
{
|
o.pushKV(T_N, static_cast<int64_t>(i));
|
||||||
o.pushKV("nOut", static_cast<int64_t>(i));
|
std::string sName(vvchParams[0].begin(), vvchParams[0].end());
|
||||||
std::string sName(vvchParams[0].begin(), vvchParams[0].end());
|
o.pushKV(T_NAME, escapeNonUtf8(sName));
|
||||||
o.pushKV("name", escapeNonUtf8(sName));
|
if (op == OP_CLAIM_NAME) {
|
||||||
if (op == OP_CLAIM_NAME)
|
uint160 claimId = ClaimIdHash(hash, i);
|
||||||
{
|
o.pushKV(T_CLAIMID, claimId.GetHex());
|
||||||
uint160 claimId = ClaimIdHash(hash, i);
|
o.pushKV(T_VALUE, HexStr(vvchParams[1].begin(), vvchParams[1].end()));
|
||||||
o.pushKV("claimId", claimId.GetHex());
|
} else if (op == OP_UPDATE_CLAIM || op == OP_SUPPORT_CLAIM) {
|
||||||
o.pushKV("value", HexStr(vvchParams[1].begin(), vvchParams[1].end()));
|
uint160 claimId(vvchParams[1]);
|
||||||
}
|
o.pushKV(T_CLAIMID, claimId.GetHex());
|
||||||
else if (op == OP_UPDATE_CLAIM)
|
if (vvchParams.size() > 2)
|
||||||
{
|
o.pushKV(T_VALUE, HexStr(vvchParams[2].begin(), vvchParams[2].end()));
|
||||||
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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
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;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -754,111 +537,46 @@ UniValue proofToJSON(const CClaimTrieProof& proof)
|
||||||
|
|
||||||
for (const auto& itChildren : itNode.children) {
|
for (const auto& itChildren : itNode.children) {
|
||||||
UniValue child(UniValue::VOBJ);
|
UniValue child(UniValue::VOBJ);
|
||||||
child.pushKV("character", itChildren.first);
|
child.pushKV(T_CHARACTER, itChildren.first);
|
||||||
if (!itChildren.second.IsNull())
|
if (!itChildren.second.IsNull())
|
||||||
child.pushKV("nodeHash", itChildren.second.GetHex());
|
child.pushKV(T_NODEHASH, itChildren.second.GetHex());
|
||||||
children.push_back(child);
|
children.push_back(child);
|
||||||
}
|
}
|
||||||
|
node.pushKV(T_CHILDREN, children);
|
||||||
node.pushKV("children", children);
|
|
||||||
|
|
||||||
if (itNode.hasValue && !itNode.valHash.IsNull())
|
if (itNode.hasValue && !itNode.valHash.IsNull())
|
||||||
node.pushKV("valueHash", itNode.valHash.GetHex());
|
node.pushKV(T_VALUEHASH, itNode.valHash.GetHex());
|
||||||
|
|
||||||
nodes.push_back(node);
|
nodes.push_back(node);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!nodes.empty())
|
if (!nodes.empty())
|
||||||
result.push_back(Pair("nodes", nodes));
|
result.push_back(Pair(T_NODES, nodes));
|
||||||
|
|
||||||
UniValue pairs(UniValue::VARR);
|
UniValue pairs(UniValue::VARR);
|
||||||
|
|
||||||
for (const auto& itPair : proof.pairs) {
|
for (const auto& itPair : proof.pairs) {
|
||||||
UniValue child(UniValue::VOBJ);
|
UniValue child(UniValue::VOBJ);
|
||||||
child.push_back(Pair("odd", itPair.first));
|
child.push_back(Pair(T_ODD, itPair.first));
|
||||||
child.push_back(Pair("hash", itPair.second.GetHex()));
|
child.push_back(Pair(T_HASH, itPair.second.GetHex()));
|
||||||
pairs.push_back(child);
|
pairs.push_back(child);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!pairs.empty())
|
if (!pairs.empty())
|
||||||
result.push_back(Pair("pairs", pairs));
|
result.push_back(Pair(T_PAIRS, pairs));
|
||||||
|
|
||||||
if (proof.hasValue) {
|
if (proof.hasValue) {
|
||||||
result.pushKV("txhash", proof.outPoint.hash.GetHex());
|
result.pushKV(T_TXID, proof.outPoint.hash.GetHex());
|
||||||
result.pushKV("nOut", (int)proof.outPoint.n);
|
result.pushKV(T_N, (int)proof.outPoint.n);
|
||||||
result.pushKV("last takeover height", (int)proof.nHeightOfLastTakeover);
|
result.pushKV(T_LASTTAKEOVERHEIGHT, (int)proof.nHeightOfLastTakeover);
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
UniValue getnameproof(const JSONRPCRequest& request)
|
UniValue getnameproof(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 2))
|
validateRequest(request, GETNAMEPROOF, 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");
|
|
||||||
|
|
||||||
LOCK(cs_main);
|
LOCK(cs_main);
|
||||||
|
|
||||||
CCoinsViewCache coinsCache(pcoinsTip.get());
|
CCoinsViewCache coinsCache(pcoinsTip.get());
|
||||||
CClaimTrieCache trieCache(pclaimTrie);
|
CClaimTrieCache trieCache(pclaimTrie);
|
||||||
|
|
||||||
|
@ -892,14 +610,7 @@ UniValue getnameproof(const JSONRPCRequest& request)
|
||||||
|
|
||||||
UniValue checknormalization(const JSONRPCRequest& request)
|
UniValue checknormalization(const JSONRPCRequest& request)
|
||||||
{
|
{
|
||||||
if (request.fHelp || !validParams(request.params, 1, 0))
|
validateRequest(request, CHECKNORMALIZATION, 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");
|
|
||||||
|
|
||||||
const bool force = true;
|
const bool force = true;
|
||||||
const std::string name = request.params[0].get_str();
|
const std::string name = request.params[0].get_str();
|
||||||
|
@ -911,18 +622,18 @@ UniValue checknormalization(const JSONRPCRequest& request)
|
||||||
static const CRPCCommand commands[] =
|
static const CRPCCommand commands[] =
|
||||||
{ // category name actor (function) argNames
|
{ // category name actor (function) argNames
|
||||||
// --------------------- ------------------------ ----------------------- ----------
|
// --------------------- ------------------------ ----------------------- ----------
|
||||||
{ "Claimtrie", "getclaimsintrie", &getclaimsintrie, { "blockhash" } },
|
{ "Claimtrie", "getclaimsintrie", &getclaimsintrie, { T_BLOCKHASH } },
|
||||||
{ "Claimtrie", "getnamesintrie", &getnamesintrie, { "blockhash" } },
|
{ "Claimtrie", "getnamesintrie", &getnamesintrie, { T_BLOCKHASH } },
|
||||||
{ "hidden", "getclaimtrie", &getclaimtrie, { } },
|
{ "hidden", "getclaimtrie", &getclaimtrie, { } },
|
||||||
{ "Claimtrie", "getvalueforname", &getvalueforname, { "name","blockhash","claimId" } },
|
{ "Claimtrie", "getvalueforname", &getvalueforname, { T_NAME,T_BLOCKHASH,T_CLAIMID } },
|
||||||
{ "Claimtrie", "getclaimsforname", &getclaimsforname, { "name","blockhash" } },
|
{ "Claimtrie", "getclaimsforname", &getclaimsforname, { T_NAME,T_BLOCKHASH } },
|
||||||
{ "Claimtrie", "gettotalclaimednames", &gettotalclaimednames, { "" } },
|
{ "Claimtrie", "gettotalclaimednames", &gettotalclaimednames, { "" } },
|
||||||
{ "Claimtrie", "gettotalclaims", &gettotalclaims, { "" } },
|
{ "Claimtrie", "gettotalclaims", &gettotalclaims, { "" } },
|
||||||
{ "Claimtrie", "gettotalvalueofclaims", &gettotalvalueofclaims, { "controlling_only" } },
|
{ "Claimtrie", "gettotalvalueofclaims", &gettotalvalueofclaims, { T_CONTROLLINGONLY } },
|
||||||
{ "Claimtrie", "getclaimsfortx", &getclaimsfortx, { "txid" } },
|
{ "Claimtrie", "getclaimsfortx", &getclaimsfortx, { T_TXID } },
|
||||||
{ "Claimtrie", "getnameproof", &getnameproof, { "name","blockhash","claimId"} },
|
{ "Claimtrie", "getnameproof", &getnameproof, { T_NAME,T_BLOCKHASH,T_CLAIMID} },
|
||||||
{ "Claimtrie", "getclaimbyid", &getclaimbyid, { "claimId" } },
|
{ "Claimtrie", "getclaimbyid", &getclaimbyid, { T_CLAIMID } },
|
||||||
{ "Claimtrie", "checknormalization", &checknormalization, { "name" }},
|
{ "Claimtrie", "checknormalization", &checknormalization, { T_NAME }},
|
||||||
};
|
};
|
||||||
|
|
||||||
void RegisterClaimTrieRPCCommands(CRPCTable &tableRPC)
|
void RegisterClaimTrieRPCCommands(CRPCTable &tableRPC)
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
#include <pow.h>
|
#include <pow.h>
|
||||||
#include <primitives/transaction.h>
|
#include <primitives/transaction.h>
|
||||||
#include <random.h>
|
#include <random.h>
|
||||||
|
#include <rpc/claimrpchelp.h>
|
||||||
#include <rpc/server.h>
|
#include <rpc/server.h>
|
||||||
#include <streams.h>
|
#include <streams.h>
|
||||||
#include <test/test_bitcoin.h>
|
#include <test/test_bitcoin.h>
|
||||||
|
@ -3971,15 +3972,15 @@ BOOST_AUTO_TEST_CASE(getvalueforname_test)
|
||||||
req.params.push_back(UniValue(sName1));
|
req.params.push_back(UniValue(sName1));
|
||||||
|
|
||||||
UniValue results = getvalueforname(req);
|
UniValue results = getvalueforname(req);
|
||||||
BOOST_CHECK_EQUAL(results["value"].get_str(), HexStr(sValue1));
|
BOOST_CHECK_EQUAL(results[T_VALUE].get_str(), HexStr(sValue1));
|
||||||
BOOST_CHECK_EQUAL(results["amount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(results[T_AMOUNT].get_int(), 2);
|
||||||
BOOST_CHECK_EQUAL(results["effectiveAmount"].get_int(), 5);
|
BOOST_CHECK_EQUAL(results[T_EFFECTIVEAMOUNT].get_int(), 5);
|
||||||
|
|
||||||
req.params.push_back(blockHash.GetHex());
|
req.params.push_back(blockHash.GetHex());
|
||||||
|
|
||||||
results = getvalueforname(req);
|
results = getvalueforname(req);
|
||||||
BOOST_CHECK_EQUAL(results["amount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(results[T_AMOUNT].get_int(), 2);
|
||||||
BOOST_CHECK_EQUAL(results["effectiveAmount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(results[T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(getclaimsforname_test)
|
BOOST_AUTO_TEST_CASE(getclaimsforname_test)
|
||||||
|
@ -4005,31 +4006,31 @@ BOOST_AUTO_TEST_CASE(getclaimsforname_test)
|
||||||
req.params.push_back(UniValue(sName1));
|
req.params.push_back(UniValue(sName1));
|
||||||
|
|
||||||
UniValue results = getclaimsforname(req);
|
UniValue results = getclaimsforname(req);
|
||||||
UniValue claims = results["claims"];
|
UniValue claims = results[T_CLAIMS];
|
||||||
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
||||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 1);
|
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 1);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||||
|
|
||||||
fixture.IncrementBlocks(1);
|
fixture.IncrementBlocks(1);
|
||||||
|
|
||||||
results = getclaimsforname(req);
|
results = getclaimsforname(req);
|
||||||
claims = results["claims"];
|
claims = results[T_CLAIMS];
|
||||||
BOOST_CHECK_EQUAL(claims.size(), 2U);
|
BOOST_CHECK_EQUAL(claims.size(), 2U);
|
||||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 3);
|
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 3);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 3);
|
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 3);
|
||||||
BOOST_CHECK_EQUAL(claims[1]["effectiveAmount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(claims[1][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||||
BOOST_CHECK_EQUAL(claims[1]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claims[1][T_SUPPORTS].size(), 0U);
|
||||||
|
|
||||||
req.params.push_back(blockHash.GetHex());
|
req.params.push_back(blockHash.GetHex());
|
||||||
|
|
||||||
results = getclaimsforname(req);
|
results = getclaimsforname(req);
|
||||||
claims = results["claims"];
|
claims = results[T_CLAIMS];
|
||||||
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
BOOST_CHECK_EQUAL(claims.size(), 1U);
|
||||||
BOOST_CHECK_EQUAL(results["lastTakeoverHeight"].get_int(), height + 1);
|
BOOST_CHECK_EQUAL(results[T_LASTTAKEOVERHEIGHT].get_int(), height + 1);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["effectiveAmount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(claims[0][T_EFFECTIVEAMOUNT].get_int(), 2);
|
||||||
BOOST_CHECK_EQUAL(claims[0]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claims[0][T_SUPPORTS].size(), 0U);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(claim_rpcs_rollback2_test)
|
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());
|
req.params.push_back(blockHash.GetHex());
|
||||||
|
|
||||||
UniValue claimsResults = getclaimsforname(req);
|
UniValue claimsResults = getclaimsforname(req);
|
||||||
BOOST_CHECK_EQUAL(claimsResults["lastTakeoverHeight"].get_int(), height + 5);
|
BOOST_CHECK_EQUAL(claimsResults[T_LASTTAKEOVERHEIGHT].get_int(), height + 5);
|
||||||
BOOST_CHECK_EQUAL(claimsResults["claims"][0]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claimsResults[T_CLAIMS][0][T_SUPPORTS].size(), 0U);
|
||||||
BOOST_CHECK_EQUAL(claimsResults["claims"][1]["supports"].size(), 0U);
|
BOOST_CHECK_EQUAL(claimsResults[T_CLAIMS][1][T_SUPPORTS].size(), 0U);
|
||||||
|
|
||||||
UniValue valueResults = getvalueforname(req);
|
UniValue valueResults = getvalueforname(req);
|
||||||
BOOST_CHECK_EQUAL(valueResults["value"].get_str(), HexStr(sValue2));
|
BOOST_CHECK_EQUAL(valueResults[T_VALUE].get_str(), HexStr(sValue2));
|
||||||
BOOST_CHECK_EQUAL(valueResults["amount"].get_int(), 2);
|
BOOST_CHECK_EQUAL(valueResults[T_AMOUNT].get_int(), 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(claim_rpcs_rollback3_test)
|
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());
|
req.params.push_back(blockHash.GetHex());
|
||||||
|
|
||||||
UniValue claimsResults = getclaimsforname(req);
|
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);
|
UniValue valueResults = getvalueforname(req);
|
||||||
BOOST_CHECK_EQUAL(valueResults["value"].get_str(), HexStr(sValue1));
|
BOOST_CHECK_EQUAL(valueResults[T_VALUE].get_str(), HexStr(sValue1));
|
||||||
BOOST_CHECK_EQUAL(valueResults["amount"].get_int(), 3);
|
BOOST_CHECK_EQUAL(valueResults[T_AMOUNT].get_int(), 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOST_AUTO_TEST_CASE(update_on_support2_test)
|
BOOST_AUTO_TEST_CASE(update_on_support2_test)
|
||||||
|
|
Loading…
Add table
Reference in a new issue