Branch data Line data Source code
1 : : // Copyright (c) 2011-2022 The Bitcoin Core developers
2 : : // Distributed under the MIT software license, see the accompanying
3 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 : :
5 : : #include <common/signmessage.h>
6 : : #include <key_io.h>
7 : : #include <rpc/util.h>
8 : : #include <wallet/rpc/util.h>
9 : : #include <wallet/wallet.h>
10 : :
11 : : #include <univalue.h>
12 : :
13 : : namespace wallet {
14 : 788 : RPCHelpMan signmessage()
15 : : {
16 : 788 : return RPCHelpMan{"signmessage",
17 : 788 : "\nSign a message with the private key of an address" +
18 [ + - ]: 788 : HELP_REQUIRING_PASSPHRASE,
19 : : {
20 [ + - ]: 788 : {"address", RPCArg::Type::STR, RPCArg::Optional::NO, "The bitcoin address to use for the private key."},
21 [ + - ]: 788 : {"message", RPCArg::Type::STR, RPCArg::Optional::NO, "The message to create a signature of."},
22 : : },
23 : 0 : RPCResult{
24 : : RPCResult::Type::STR, "signature", "The signature of the message encoded in base 64"
25 [ + - + - : 1576 : },
+ - ]
26 : 788 : RPCExamples{
27 : : "\nUnlock the wallet for 30 seconds\n"
28 [ + - + - : 1576 : + HelpExampleCli("walletpassphrase", "\"mypassphrase\" 30") +
+ - + - ]
29 : 788 : "\nCreate the signature\n"
30 [ + - + - : 3152 : + HelpExampleCli("signmessage", "\"1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XX\" \"my message\"") +
+ - + - ]
31 : 788 : "\nVerify the signature\n"
32 [ + - + - : 3152 : + HelpExampleCli("verifymessage", "\"1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XX\" \"signature\" \"my message\"") +
+ - + - ]
33 : 788 : "\nAs a JSON-RPC call\n"
34 [ + - + - : 3152 : + HelpExampleRpc("signmessage", "\"1D1ZrZNe3JUo7ZycKEYQQiQAWd9y54F4XX\", \"my message\"")
+ - + - ]
35 [ + - ]: 788 : },
36 : 17 : [&](const RPCHelpMan& self, const JSONRPCRequest& request) -> UniValue
37 : : {
38 [ - + ]: 17 : const std::shared_ptr<const CWallet> pwallet = GetWalletForJSONRPCRequest(request);
39 [ - + ]: 17 : if (!pwallet) return UniValue::VNULL;
40 : :
41 [ + - ]: 17 : LOCK(pwallet->cs_wallet);
42 : :
43 [ + + ]: 17 : EnsureWalletIsUnlocked(*pwallet);
44 : :
45 [ + - + - : 10 : std::string strAddress = request.params[0].get_str();
+ - ]
46 [ + - + - : 10 : std::string strMessage = request.params[1].get_str();
+ - ]
47 : :
48 [ + - ]: 10 : CTxDestination dest = DecodeDestination(strAddress);
49 [ + - + + ]: 10 : if (!IsValidDestination(dest)) {
50 [ + - + - ]: 2 : throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, "Invalid address");
51 : : }
52 : :
53 [ + - ]: 9 : const PKHash* pkhash = std::get_if<PKHash>(&dest);
54 : 9 : if (!pkhash) {
55 [ # # # # ]: 0 : throw JSONRPCError(RPC_TYPE_ERROR, "Address does not refer to key");
56 : : }
57 : :
58 [ + - ]: 9 : std::string signature;
59 [ + - ]: 9 : SigningResult err = pwallet->SignMessage(strMessage, *pkhash, signature);
60 [ - + ]: 9 : if (err == SigningResult::SIGNING_FAILED) {
61 [ # # # # ]: 0 : throw JSONRPCError(RPC_INVALID_ADDRESS_OR_KEY, SigningResultString(err));
62 [ - + ]: 9 : } else if (err != SigningResult::OK) {
63 [ # # # # ]: 0 : throw JSONRPCError(RPC_WALLET_ERROR, SigningResultString(err));
64 : : }
65 : :
66 [ + - ]: 9 : return signature;
67 [ + - ]: 38 : },
68 [ + - + - : 11032 : };
+ - + - +
- + - + -
+ + - - ]
69 [ + - + - : 3940 : }
+ - - - ]
70 : : } // namespace wallet
|