Multiple fixes for "masternode list"
1. Make strMode lower case before comparing it (keyIDXXX would otherwise be case sensitive, leading to confusion for users) 2. Remove "rank" and "keyid" mode from help 3. Add keyIDOwner/keyIDVoting/pubKeyOperator to help and strMode check 4. Remove "pubkey" from strMode check 5. Call ToString() on address instead of whole DMN state 6. Add missing std::setw(10) to "full" mode
This commit is contained in:
parent
e54f6b274a
commit
78c22ad0fb
@ -142,12 +142,13 @@ void masternode_list_help()
|
|||||||
" info - Print info in format 'status payee IP'\n"
|
" info - Print info in format 'status payee IP'\n"
|
||||||
" (can be additionally filtered, partial match)\n"
|
" (can be additionally filtered, partial match)\n"
|
||||||
" json - Print info in JSON format (can be additionally filtered, partial match)\n"
|
" json - Print info in JSON format (can be additionally filtered, partial match)\n"
|
||||||
|
" keyIDOwner - Print the masternode owner key id\n"
|
||||||
|
" keyIDVoting - Print the masternode voting key id\n"
|
||||||
" lastpaidblock - Print the last block height a node was paid on the network\n"
|
" lastpaidblock - Print the last block height a node was paid on the network\n"
|
||||||
" lastpaidtime - Print the last time a node was paid on the network\n"
|
" lastpaidtime - Print the last time a node was paid on the network\n"
|
||||||
" payee - Print Dash address associated with a masternode (can be additionally filtered,\n"
|
" payee - Print Dash address associated with a masternode (can be additionally filtered,\n"
|
||||||
" partial match)\n"
|
" partial match)\n"
|
||||||
" keyid - Print the masternode (not collateral) key id\n"
|
" pubKeyOperator - Print the masternode operator public key\n"
|
||||||
" rank - Print rank of a masternode based on current block\n"
|
|
||||||
" status - Print masternode status: ENABLED / POSE_BAN / OUTPOINT_SPENT\n"
|
" status - Print masternode status: ENABLED / POSE_BAN / OUTPOINT_SPENT\n"
|
||||||
" (can be additionally filtered, partial match)\n"
|
" (can be additionally filtered, partial match)\n"
|
||||||
);
|
);
|
||||||
@ -812,10 +813,13 @@ UniValue masternodelist(const JSONRPCRequest& request)
|
|||||||
if (request.params.size() >= 1) strMode = request.params[0].get_str();
|
if (request.params.size() >= 1) strMode = request.params[0].get_str();
|
||||||
if (request.params.size() == 2) strFilter = request.params[1].get_str();
|
if (request.params.size() == 2) strFilter = request.params[1].get_str();
|
||||||
|
|
||||||
|
std::transform(strMode.begin(), strMode.end(), strMode.begin(), ::tolower);
|
||||||
|
|
||||||
if (request.fHelp || (
|
if (request.fHelp || (
|
||||||
strMode != "addr" && strMode != "full" && strMode != "info" && strMode != "json" &&
|
strMode != "addr" && strMode != "full" && strMode != "info" && strMode != "json" &&
|
||||||
|
strMode != "keyidowner" && strMode != "keyidvoting" &&
|
||||||
strMode != "lastpaidtime" && strMode != "lastpaidblock" &&
|
strMode != "lastpaidtime" && strMode != "lastpaidblock" &&
|
||||||
strMode != "payee" && strMode != "pubkey" &&
|
strMode != "payee" && strMode != "pubkeyoperator" &&
|
||||||
strMode != "status"))
|
strMode != "status"))
|
||||||
{
|
{
|
||||||
masternode_list_help();
|
masternode_list_help();
|
||||||
@ -863,7 +867,7 @@ UniValue masternodelist(const JSONRPCRequest& request)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (strMode == "addr") {
|
if (strMode == "addr") {
|
||||||
std::string strAddress = dmn->pdmnState->ToString();
|
std::string strAddress = dmn->pdmnState->addr.ToString(false);
|
||||||
if (strFilter !="" && strAddress.find(strFilter) == std::string::npos &&
|
if (strFilter !="" && strAddress.find(strFilter) == std::string::npos &&
|
||||||
strOutpoint.find(strFilter) == std::string::npos) return;
|
strOutpoint.find(strFilter) == std::string::npos) return;
|
||||||
obj.push_back(Pair(strOutpoint, strAddress));
|
obj.push_back(Pair(strOutpoint, strAddress));
|
||||||
@ -871,7 +875,7 @@ UniValue masternodelist(const JSONRPCRequest& request)
|
|||||||
std::ostringstream streamFull;
|
std::ostringstream streamFull;
|
||||||
streamFull << std::setw(18) <<
|
streamFull << std::setw(18) <<
|
||||||
dmnToStatus(dmn) << " " <<
|
dmnToStatus(dmn) << " " <<
|
||||||
payeeStr << " " <<
|
payeeStr << " " << std::setw(10) <<
|
||||||
dmnToLastPaidTime(dmn) << " " << std::setw(6) <<
|
dmnToLastPaidTime(dmn) << " " << std::setw(6) <<
|
||||||
dmn->pdmnState->nLastPaidHeight << " " <<
|
dmn->pdmnState->nLastPaidHeight << " " <<
|
||||||
dmn->pdmnState->addr.ToString();
|
dmn->pdmnState->addr.ToString();
|
||||||
@ -916,13 +920,13 @@ UniValue masternodelist(const JSONRPCRequest& request)
|
|||||||
if (strFilter !="" && payeeStr.find(strFilter) == std::string::npos &&
|
if (strFilter !="" && payeeStr.find(strFilter) == std::string::npos &&
|
||||||
strOutpoint.find(strFilter) == std::string::npos) return;
|
strOutpoint.find(strFilter) == std::string::npos) return;
|
||||||
obj.push_back(Pair(strOutpoint, payeeStr));
|
obj.push_back(Pair(strOutpoint, payeeStr));
|
||||||
} else if (strMode == "keyIDOwner") {
|
} else if (strMode == "keyidowner") {
|
||||||
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
||||||
obj.push_back(Pair(strOutpoint, HexStr(dmn->pdmnState->keyIDOwner)));
|
obj.push_back(Pair(strOutpoint, HexStr(dmn->pdmnState->keyIDOwner)));
|
||||||
} else if (strMode == "pubKeyOperator") {
|
} else if (strMode == "pubkeyoperator") {
|
||||||
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
||||||
obj.push_back(Pair(strOutpoint, dmn->pdmnState->pubKeyOperator.ToString()));
|
obj.push_back(Pair(strOutpoint, dmn->pdmnState->pubKeyOperator.ToString()));
|
||||||
} else if (strMode == "keyIDVoting") {
|
} else if (strMode == "keyidvoting") {
|
||||||
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
if (strFilter !="" && strOutpoint.find(strFilter) == std::string::npos) return;
|
||||||
obj.push_back(Pair(strOutpoint, HexStr(dmn->pdmnState->keyIDVoting)));
|
obj.push_back(Pair(strOutpoint, HexStr(dmn->pdmnState->keyIDVoting)));
|
||||||
} else if (strMode == "status") {
|
} else if (strMode == "status") {
|
||||||
|
Loading…
Reference in New Issue
Block a user