RPC: add facility to enable RPCs to run outside cs_main, wallet locks
Use with 'stop' and 'help' RPCs. This provides a facility to individually evaluate the locking for an RPC, and potentially make it more parallel.
This commit is contained in:
parent
5f2b41d54d
commit
0e1d3551da
2 changed files with 63 additions and 58 deletions
|
@ -191,62 +191,62 @@ Value stop(const Array& params, bool fHelp)
|
|||
|
||||
|
||||
static const CRPCCommand vRPCCommands[] =
|
||||
{ // name function safe mode?
|
||||
// ------------------------ ----------------------- ----------
|
||||
{ "help", &help, true },
|
||||
{ "stop", &stop, true },
|
||||
{ "getblockcount", &getblockcount, true },
|
||||
{ "getconnectioncount", &getconnectioncount, true },
|
||||
{ "getpeerinfo", &getpeerinfo, true },
|
||||
{ "getdifficulty", &getdifficulty, true },
|
||||
{ "getgenerate", &getgenerate, true },
|
||||
{ "setgenerate", &setgenerate, true },
|
||||
{ "gethashespersec", &gethashespersec, true },
|
||||
{ "getinfo", &getinfo, true },
|
||||
{ "getmininginfo", &getmininginfo, true },
|
||||
{ "getnewaddress", &getnewaddress, true },
|
||||
{ "getaccountaddress", &getaccountaddress, true },
|
||||
{ "setaccount", &setaccount, true },
|
||||
{ "getaccount", &getaccount, false },
|
||||
{ "getaddressesbyaccount", &getaddressesbyaccount, true },
|
||||
{ "sendtoaddress", &sendtoaddress, false },
|
||||
{ "getreceivedbyaddress", &getreceivedbyaddress, false },
|
||||
{ "getreceivedbyaccount", &getreceivedbyaccount, false },
|
||||
{ "listreceivedbyaddress", &listreceivedbyaddress, false },
|
||||
{ "listreceivedbyaccount", &listreceivedbyaccount, false },
|
||||
{ "backupwallet", &backupwallet, true },
|
||||
{ "keypoolrefill", &keypoolrefill, true },
|
||||
{ "walletpassphrase", &walletpassphrase, true },
|
||||
{ "walletpassphrasechange", &walletpassphrasechange, false },
|
||||
{ "walletlock", &walletlock, true },
|
||||
{ "encryptwallet", &encryptwallet, false },
|
||||
{ "validateaddress", &validateaddress, true },
|
||||
{ "getbalance", &getbalance, false },
|
||||
{ "move", &movecmd, false },
|
||||
{ "sendfrom", &sendfrom, false },
|
||||
{ "sendmany", &sendmany, false },
|
||||
{ "addmultisigaddress", &addmultisigaddress, false },
|
||||
{ "getrawmempool", &getrawmempool, true },
|
||||
{ "getblock", &getblock, false },
|
||||
{ "getblockhash", &getblockhash, false },
|
||||
{ "gettransaction", &gettransaction, false },
|
||||
{ "listtransactions", &listtransactions, false },
|
||||
{ "signmessage", &signmessage, false },
|
||||
{ "verifymessage", &verifymessage, false },
|
||||
{ "getwork", &getwork, true },
|
||||
{ "listaccounts", &listaccounts, false },
|
||||
{ "settxfee", &settxfee, false },
|
||||
{ "getblocktemplate", &getblocktemplate, true },
|
||||
{ "submitblock", &submitblock, false },
|
||||
{ "listsinceblock", &listsinceblock, false },
|
||||
{ "dumpprivkey", &dumpprivkey, false },
|
||||
{ "importprivkey", &importprivkey, false },
|
||||
{ "listunspent", &listunspent, false },
|
||||
{ "getrawtransaction", &getrawtransaction, false },
|
||||
{ "createrawtransaction", &createrawtransaction, false },
|
||||
{ "decoderawtransaction", &decoderawtransaction, false },
|
||||
{ "signrawtransaction", &signrawtransaction, false },
|
||||
{ "sendrawtransaction", &sendrawtransaction, false },
|
||||
{ // name function safemd unlocked
|
||||
// ------------------------ ----------------------- ------ --------
|
||||
{ "help", &help, true, true },
|
||||
{ "stop", &stop, true, true },
|
||||
{ "getblockcount", &getblockcount, true, false },
|
||||
{ "getconnectioncount", &getconnectioncount, true, false },
|
||||
{ "getpeerinfo", &getpeerinfo, true, false },
|
||||
{ "getdifficulty", &getdifficulty, true, false },
|
||||
{ "getgenerate", &getgenerate, true, false },
|
||||
{ "setgenerate", &setgenerate, true, false },
|
||||
{ "gethashespersec", &gethashespersec, true, false },
|
||||
{ "getinfo", &getinfo, true, false },
|
||||
{ "getmininginfo", &getmininginfo, true, false },
|
||||
{ "getnewaddress", &getnewaddress, true, false },
|
||||
{ "getaccountaddress", &getaccountaddress, true, false },
|
||||
{ "setaccount", &setaccount, true, false },
|
||||
{ "getaccount", &getaccount, false, false },
|
||||
{ "getaddressesbyaccount", &getaddressesbyaccount, true, false },
|
||||
{ "sendtoaddress", &sendtoaddress, false, false },
|
||||
{ "getreceivedbyaddress", &getreceivedbyaddress, false, false },
|
||||
{ "getreceivedbyaccount", &getreceivedbyaccount, false, false },
|
||||
{ "listreceivedbyaddress", &listreceivedbyaddress, false, false },
|
||||
{ "listreceivedbyaccount", &listreceivedbyaccount, false, false },
|
||||
{ "backupwallet", &backupwallet, true, false },
|
||||
{ "keypoolrefill", &keypoolrefill, true, false },
|
||||
{ "walletpassphrase", &walletpassphrase, true, false },
|
||||
{ "walletpassphrasechange", &walletpassphrasechange, false, false },
|
||||
{ "walletlock", &walletlock, true, false },
|
||||
{ "encryptwallet", &encryptwallet, false, false },
|
||||
{ "validateaddress", &validateaddress, true, false },
|
||||
{ "getbalance", &getbalance, false, false },
|
||||
{ "move", &movecmd, false, false },
|
||||
{ "sendfrom", &sendfrom, false, false },
|
||||
{ "sendmany", &sendmany, false, false },
|
||||
{ "addmultisigaddress", &addmultisigaddress, false, false },
|
||||
{ "getrawmempool", &getrawmempool, true, false },
|
||||
{ "getblock", &getblock, false, false },
|
||||
{ "getblockhash", &getblockhash, false, false },
|
||||
{ "gettransaction", &gettransaction, false, false },
|
||||
{ "listtransactions", &listtransactions, false, false },
|
||||
{ "signmessage", &signmessage, false, false },
|
||||
{ "verifymessage", &verifymessage, false, false },
|
||||
{ "getwork", &getwork, true, false },
|
||||
{ "listaccounts", &listaccounts, false, false },
|
||||
{ "settxfee", &settxfee, false, false },
|
||||
{ "getblocktemplate", &getblocktemplate, true, false },
|
||||
{ "submitblock", &submitblock, false, false },
|
||||
{ "listsinceblock", &listsinceblock, false, false },
|
||||
{ "dumpprivkey", &dumpprivkey, false, false },
|
||||
{ "importprivkey", &importprivkey, false, false },
|
||||
{ "listunspent", &listunspent, false, false },
|
||||
{ "getrawtransaction", &getrawtransaction, false, false },
|
||||
{ "createrawtransaction", &createrawtransaction, false, false },
|
||||
{ "decoderawtransaction", &decoderawtransaction, false, false },
|
||||
{ "signrawtransaction", &signrawtransaction, false, false },
|
||||
{ "sendrawtransaction", &sendrawtransaction, false, false },
|
||||
};
|
||||
|
||||
CRPCTable::CRPCTable()
|
||||
|
@ -1008,9 +1008,13 @@ json_spirit::Value CRPCTable::execute(const std::string &strMethod, const json_s
|
|||
// Execute
|
||||
Value result;
|
||||
{
|
||||
if (pcmd->unlocked)
|
||||
result = pcmd->actor(params, false);
|
||||
else {
|
||||
LOCK2(cs_main, pwalletMain->cs_wallet);
|
||||
result = pcmd->actor(params, false);
|
||||
}
|
||||
}
|
||||
return result;
|
||||
}
|
||||
catch (std::exception& e)
|
||||
|
|
|
@ -46,6 +46,7 @@ public:
|
|||
std::string name;
|
||||
rpcfn_type actor;
|
||||
bool okSafeMode;
|
||||
bool unlocked;
|
||||
};
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in a new issue