mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-17 18:40:09 +00:00
Merge pull request #3137 from Diapolo/RPC
RPC: error code changes and prevent crash with walletpassphrase
This commit is contained in:
commit
9d580b82c5
@ -49,10 +49,13 @@ enum RPCErrorCode
|
|||||||
RPC_INVALID_PARAMETER = -8, // Invalid, missing or duplicate parameter
|
RPC_INVALID_PARAMETER = -8, // Invalid, missing or duplicate parameter
|
||||||
RPC_DATABASE_ERROR = -20, // Database error
|
RPC_DATABASE_ERROR = -20, // Database error
|
||||||
RPC_DESERIALIZATION_ERROR = -22, // Error parsing or validating structure in raw format
|
RPC_DESERIALIZATION_ERROR = -22, // Error parsing or validating structure in raw format
|
||||||
|
RPC_SERVER_NOT_STARTED = -18, // RPC server was not started (StartRPCThreads() not called)
|
||||||
|
|
||||||
// P2P client errors
|
// P2P client errors
|
||||||
RPC_CLIENT_NOT_CONNECTED = -9, // Bitcoin is not connected
|
RPC_CLIENT_NOT_CONNECTED = -9, // Bitcoin is not connected
|
||||||
RPC_CLIENT_IN_INITIAL_DOWNLOAD = -10, // Still downloading initial blocks
|
RPC_CLIENT_IN_INITIAL_DOWNLOAD = -10, // Still downloading initial blocks
|
||||||
|
RPC_CLIENT_NODE_ALREADY_ADDED = -23, // Node is already added
|
||||||
|
RPC_CLIENT_NODE_NOT_ADDED = -24, // Node has not been added before
|
||||||
|
|
||||||
// Wallet errors
|
// Wallet errors
|
||||||
RPC_WALLET_ERROR = -4, // Unspecified problem with wallet (key not found etc.)
|
RPC_WALLET_ERROR = -4, // Unspecified problem with wallet (key not found etc.)
|
||||||
|
@ -27,7 +27,7 @@ Value ping(const Array& params, bool fHelp)
|
|||||||
"Requests that a ping be sent to all other nodes, to measure ping time.\n"
|
"Requests that a ping be sent to all other nodes, to measure ping time.\n"
|
||||||
"Results provided in getpeerinfo, pingtime and pingwait fields are decimal seconds.\n"
|
"Results provided in getpeerinfo, pingtime and pingwait fields are decimal seconds.\n"
|
||||||
"Ping command is handled in queue with all other commands, so it measures processing backlog, not just network ping.");
|
"Ping command is handled in queue with all other commands, so it measures processing backlog, not just network ping.");
|
||||||
|
|
||||||
// Request that each node send a ping during next message processing pass
|
// Request that each node send a ping during next message processing pass
|
||||||
LOCK(cs_vNodes);
|
LOCK(cs_vNodes);
|
||||||
BOOST_FOREACH(CNode* pNode, vNodes) {
|
BOOST_FOREACH(CNode* pNode, vNodes) {
|
||||||
@ -120,13 +120,13 @@ Value addnode(const Array& params, bool fHelp)
|
|||||||
if (strCommand == "add")
|
if (strCommand == "add")
|
||||||
{
|
{
|
||||||
if (it != vAddedNodes.end())
|
if (it != vAddedNodes.end())
|
||||||
throw JSONRPCError(-23, "Error: Node already added");
|
throw JSONRPCError(RPC_CLIENT_NODE_ALREADY_ADDED, "Error: Node already added");
|
||||||
vAddedNodes.push_back(strNode);
|
vAddedNodes.push_back(strNode);
|
||||||
}
|
}
|
||||||
else if(strCommand == "remove")
|
else if(strCommand == "remove")
|
||||||
{
|
{
|
||||||
if (it == vAddedNodes.end())
|
if (it == vAddedNodes.end())
|
||||||
throw JSONRPCError(-24, "Error: Node has not been added.");
|
throw JSONRPCError(RPC_CLIENT_NODE_NOT_ADDED, "Error: Node has not been added.");
|
||||||
vAddedNodes.erase(it);
|
vAddedNodes.erase(it);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,7 +163,7 @@ Value getaddednodeinfo(const Array& params, bool fHelp)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (laddedNodes.size() == 0)
|
if (laddedNodes.size() == 0)
|
||||||
throw JSONRPCError(-24, "Error: Node has not been added.");
|
throw JSONRPCError(RPC_CLIENT_NODE_NOT_ADDED, "Error: Node has not been added.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fDns)
|
if (!fDns)
|
||||||
|
@ -1271,7 +1271,7 @@ Value keypoolrefill(const Array& params, bool fHelp)
|
|||||||
unsigned int kpSize = max(GetArg("-keypool", 100), 0LL);
|
unsigned int kpSize = max(GetArg("-keypool", 100), 0LL);
|
||||||
if (params.size() > 0) {
|
if (params.size() > 0) {
|
||||||
if (params[0].get_int() < 0)
|
if (params[0].get_int() < 0)
|
||||||
throw JSONRPCError(-8, "Invalid parameter, expected valid size");
|
throw JSONRPCError(RPC_INVALID_PARAMETER, "Invalid parameter, expected valid size");
|
||||||
kpSize = (unsigned int) params[0].get_int();
|
kpSize = (unsigned int) params[0].get_int();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1301,6 +1301,8 @@ Value walletpassphrase(const Array& params, bool fHelp)
|
|||||||
"Stores the wallet decryption key in memory for <timeout> seconds.");
|
"Stores the wallet decryption key in memory for <timeout> seconds.");
|
||||||
if (fHelp)
|
if (fHelp)
|
||||||
return true;
|
return true;
|
||||||
|
if (!fServer)
|
||||||
|
throw JSONRPCError(RPC_SERVER_NOT_STARTED, "Error: RPC server was not started, use server=1 to change this.");
|
||||||
if (!pwalletMain->IsCrypted())
|
if (!pwalletMain->IsCrypted())
|
||||||
throw JSONRPCError(RPC_WALLET_WRONG_ENC_STATE, "Error: running with an unencrypted wallet, but walletpassphrase was called.");
|
throw JSONRPCError(RPC_WALLET_WRONG_ENC_STATE, "Error: running with an unencrypted wallet, but walletpassphrase was called.");
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user