mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-11 20:32:35 -03:00
Merge #10870: [Qt] Use wallet 0 in rpc console if running with multiple wallets
9737572
[Qt] Use wallet 0 in rpc console if running with multiple wallets (Jonas Schnelli)
Pull request description:
Current master with multiwallet results in accessing wallet 0 in QT (send / receive / tx history / etc.), **but** the RPC console cannot access that wallet (only non-wallet commands work).
This is a quick solution to re-allow accessing the same wallet (Index 0) via RPC console in multiwallet.
The solutions design is not "state of the art" (should go over WalletModel). Ideally we work on an overall multiwallet support for the GUI (which then would remove this change).
I think we should consider this as a bugfix.
Tree-SHA512: 16cf844662248ffd3d82c7d0cbe5879f231fbc7d4f5a4aab4180a9087018519c98301e4ac311eaec2cc39dddf25d3edf9be99a6622ea682c138a820a9b21fd0c
This commit is contained in:
commit
412b466d11
1 changed files with 9 additions and 0 deletions
|
@ -25,6 +25,7 @@
|
||||||
|
|
||||||
#ifdef ENABLE_WALLET
|
#ifdef ENABLE_WALLET
|
||||||
#include <db_cxx.h>
|
#include <db_cxx.h>
|
||||||
|
#include <wallet/wallet.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <QKeyEvent>
|
#include <QKeyEvent>
|
||||||
|
@ -301,6 +302,14 @@ bool RPCConsole::RPCParseCommandLine(std::string &strResult, const std::string &
|
||||||
JSONRPCRequest req;
|
JSONRPCRequest req;
|
||||||
req.params = RPCConvertValues(stack.back()[0], std::vector<std::string>(stack.back().begin() + 1, stack.back().end()));
|
req.params = RPCConvertValues(stack.back()[0], std::vector<std::string>(stack.back().begin() + 1, stack.back().end()));
|
||||||
req.strMethod = stack.back()[0];
|
req.strMethod = stack.back()[0];
|
||||||
|
#ifdef ENABLE_WALLET
|
||||||
|
// TODO: Move this logic to WalletModel
|
||||||
|
if (!vpwallets.empty()) {
|
||||||
|
// in Qt, use always the wallet with index 0 when running with multiple wallets
|
||||||
|
QByteArray encodedName = QUrl::toPercentEncoding(QString::fromStdString(vpwallets[0]->GetName()));
|
||||||
|
req.URI = "/wallet/"+std::string(encodedName.constData(), encodedName.length());
|
||||||
|
}
|
||||||
|
#endif
|
||||||
lastResult = tableRPC.execute(req);
|
lastResult = tableRPC.execute(req);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue