29 throw std::runtime_error(
strprintf(
"'%s' received invalid response, expected array of signers",
command));
34 if (!
error.isNull()) {
42 if (fingerprint.
isNull()) {
43 throw std::runtime_error(
strprintf(
"'%s' received invalid response, missing signer fingerprint",
command));
45 const std::string fingerprintStr = fingerprint.
get_str();
47 bool duplicate =
false;
49 if (signer.m_fingerprint.compare(fingerprintStr) == 0) duplicate =
true;
80 auto matches_signer_fingerprint = [&](
const PSBTInput& input) {
81 for (
const auto& entry : input.hd_keypaths) {
82 if (parsed_m_fingerprint ==
MakeUCharSpan(entry.second.fingerprint))
return true;
87 if (!std::any_of(psbtx.inputs.begin(), psbtx.inputs.end(), matches_signer_fingerprint)) {
93 const std::string stdinStr =
"signtx \"" +
EncodeBase64(ssTx.
str()) +
"\"";
97 if (
find_value(signer_result,
"error").isStr()) {
102 if (!
find_value(signer_result,
"psbt").isStr()) {
103 error =
"Unexpected result from signer";
108 std::string signer_psbt_error;
114 psbtx = signer_psbtx;
UniValue RunCommandParseJSON(const std::string &str_command, const std::string &str_std_in)
Execute a command which returns JSON, and parse the result.
Enables interaction with an external signing device or service, such as a hardware wallet...
const std::vector< UniValue > & getValues() const
std::string m_command
The command which handles interaction with the external signer.
ExternalSigner(const std::string &command, const std::string chain, const std::string &fingerprint, const std::string name)
std::string EncodeBase64(Span< const unsigned char > input)
const std::string & get_str() const
A version of CTransaction with the PSBT format.
Double ended buffer combining vector and stream-like interfaces.
std::string m_fingerprint
Master key fingerprint of the signer.
const std::string & getValStr() const
std::string m_chain
Bitcoin mainnet, testnet, etc.
const UniValue & find_value(const UniValue &obj, const std::string &name)
UniValue DisplayAddress(const std::string &descriptor) const
Display address on the device.
std::vector< Byte > ParseHex(std::string_view str)
Parse the hex string into bytes (uint8_t or std::byte).
const std::string NetworkArg() const
bool DecodeBase64PSBT(PartiallySignedTransaction &psbt, const std::string &base64_tx, std::string &error)
Decode a base64ed PSBT into a PartiallySignedTransaction.
static bool Enumerate(const std::string &command, std::vector< ExternalSigner > &signers, const std::string chain)
Obtain a list of signers.
UniValue GetDescriptors(const int account)
Get receive and change Descriptor(s) from device for a given account.
bool SignTransaction(PartiallySignedTransaction &psbt, std::string &error)
Sign PartiallySignedTransaction on the device.
static const int PROTOCOL_VERSION
network protocol versioning
constexpr auto MakeUCharSpan(V &&v) -> decltype(UCharSpanCast(Span
Like the Span constructor, but for (const) unsigned char member types only.
bool error(const char *fmt, const Args &... args)