Add outputtype module
Moves OutputType into its own module
This commit is contained in:
parent
88a15ebc8d
commit
9a44db2e46
7 changed files with 122 additions and 86 deletions
|
@ -135,6 +135,7 @@ BITCOIN_CORE_H = \
|
||||||
netbase.h \
|
netbase.h \
|
||||||
netmessagemaker.h \
|
netmessagemaker.h \
|
||||||
noui.h \
|
noui.h \
|
||||||
|
outputtype.h \
|
||||||
policy/feerate.h \
|
policy/feerate.h \
|
||||||
policy/fees.h \
|
policy/fees.h \
|
||||||
policy/policy.h \
|
policy/policy.h \
|
||||||
|
@ -265,6 +266,7 @@ libbitcoin_wallet_a_CPPFLAGS = $(AM_CPPFLAGS) $(BITCOIN_INCLUDES)
|
||||||
libbitcoin_wallet_a_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
libbitcoin_wallet_a_CXXFLAGS = $(AM_CXXFLAGS) $(PIE_FLAGS)
|
||||||
libbitcoin_wallet_a_SOURCES = \
|
libbitcoin_wallet_a_SOURCES = \
|
||||||
interfaces/wallet.cpp \
|
interfaces/wallet.cpp \
|
||||||
|
outputtype.cpp \
|
||||||
wallet/crypter.cpp \
|
wallet/crypter.cpp \
|
||||||
wallet/db.cpp \
|
wallet/db.cpp \
|
||||||
wallet/feebumper.cpp \
|
wallet/feebumper.cpp \
|
||||||
|
|
76
src/outputtype.cpp
Normal file
76
src/outputtype.cpp
Normal file
|
@ -0,0 +1,76 @@
|
||||||
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
||||||
|
// Copyright (c) 2009-2017 The Bitcoin Core developers
|
||||||
|
// Distributed under the MIT software license, see the accompanying
|
||||||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#include <outputtype.h>
|
||||||
|
|
||||||
|
#include <keystore.h>
|
||||||
|
#include <pubkey.h>
|
||||||
|
#include <script/script.h>
|
||||||
|
#include <script/standard.h>
|
||||||
|
|
||||||
|
#include <assert.h>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
static const std::string OUTPUT_TYPE_STRING_LEGACY = "legacy";
|
||||||
|
static const std::string OUTPUT_TYPE_STRING_P2SH_SEGWIT = "p2sh-segwit";
|
||||||
|
static const std::string OUTPUT_TYPE_STRING_BECH32 = "bech32";
|
||||||
|
|
||||||
|
bool ParseOutputType(const std::string& type, OutputType& output_type)
|
||||||
|
{
|
||||||
|
if (type == OUTPUT_TYPE_STRING_LEGACY) {
|
||||||
|
output_type = OutputType::LEGACY;
|
||||||
|
return true;
|
||||||
|
} else if (type == OUTPUT_TYPE_STRING_P2SH_SEGWIT) {
|
||||||
|
output_type = OutputType::P2SH_SEGWIT;
|
||||||
|
return true;
|
||||||
|
} else if (type == OUTPUT_TYPE_STRING_BECH32) {
|
||||||
|
output_type = OutputType::BECH32;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::string& FormatOutputType(OutputType type)
|
||||||
|
{
|
||||||
|
switch (type) {
|
||||||
|
case OutputType::LEGACY: return OUTPUT_TYPE_STRING_LEGACY;
|
||||||
|
case OutputType::P2SH_SEGWIT: return OUTPUT_TYPE_STRING_P2SH_SEGWIT;
|
||||||
|
case OutputType::BECH32: return OUTPUT_TYPE_STRING_BECH32;
|
||||||
|
default: assert(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
CTxDestination GetDestinationForKey(const CPubKey& key, OutputType type)
|
||||||
|
{
|
||||||
|
switch (type) {
|
||||||
|
case OutputType::LEGACY: return key.GetID();
|
||||||
|
case OutputType::P2SH_SEGWIT:
|
||||||
|
case OutputType::BECH32: {
|
||||||
|
if (!key.IsCompressed()) return key.GetID();
|
||||||
|
CTxDestination witdest = WitnessV0KeyHash(key.GetID());
|
||||||
|
CScript witprog = GetScriptForDestination(witdest);
|
||||||
|
if (type == OutputType::P2SH_SEGWIT) {
|
||||||
|
return CScriptID(witprog);
|
||||||
|
} else {
|
||||||
|
return witdest;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
default: assert(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<CTxDestination> GetAllDestinationsForKey(const CPubKey& key)
|
||||||
|
{
|
||||||
|
CKeyID keyid = key.GetID();
|
||||||
|
if (key.IsCompressed()) {
|
||||||
|
CTxDestination segwit = WitnessV0KeyHash(keyid);
|
||||||
|
CTxDestination p2sh = CScriptID(GetScriptForDestination(segwit));
|
||||||
|
return std::vector<CTxDestination>{std::move(keyid), std::move(p2sh), std::move(segwit)};
|
||||||
|
} else {
|
||||||
|
return std::vector<CTxDestination>{std::move(keyid)};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
41
src/outputtype.h
Normal file
41
src/outputtype.h
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
||||||
|
// Copyright (c) 2009-2017 The Bitcoin Core developers
|
||||||
|
// Distributed under the MIT software license, see the accompanying
|
||||||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#ifndef BITCOIN_OUTPUTTYPE_H
|
||||||
|
#define BITCOIN_OUTPUTTYPE_H
|
||||||
|
|
||||||
|
#include <script/standard.h>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
enum class OutputType {
|
||||||
|
LEGACY,
|
||||||
|
P2SH_SEGWIT,
|
||||||
|
BECH32,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Special output type for change outputs only. Automatically choose type
|
||||||
|
* based on address type setting and the types other of non-change outputs
|
||||||
|
* (see -changetype option documentation and implementation in
|
||||||
|
* CWallet::TransactionChangeType for details).
|
||||||
|
*/
|
||||||
|
CHANGE_AUTO,
|
||||||
|
};
|
||||||
|
|
||||||
|
bool ParseOutputType(const std::string& str, OutputType& output_type);
|
||||||
|
const std::string& FormatOutputType(OutputType type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get a destination of the requested type (if possible) to the specified key.
|
||||||
|
* The caller must make sure LearnRelatedScripts has been called beforehand.
|
||||||
|
*/
|
||||||
|
CTxDestination GetDestinationForKey(const CPubKey& key, OutputType);
|
||||||
|
|
||||||
|
/** Get all destinations (potentially) supported by the wallet for the given key. */
|
||||||
|
std::vector<CTxDestination> GetAllDestinationsForKey(const CPubKey& key);
|
||||||
|
|
||||||
|
#endif // BITCOIN_OUTPUTTYPE_H
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include <init.h>
|
#include <init.h>
|
||||||
#include <net.h>
|
#include <net.h>
|
||||||
#include <scheduler.h>
|
#include <scheduler.h>
|
||||||
|
#include <outputtype.h>
|
||||||
#include <util.h>
|
#include <util.h>
|
||||||
#include <utilmoneystr.h>
|
#include <utilmoneystr.h>
|
||||||
#include <validation.h>
|
#include <validation.h>
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
#include <validation.h>
|
#include <validation.h>
|
||||||
#include <key_io.h>
|
#include <key_io.h>
|
||||||
#include <net.h>
|
#include <net.h>
|
||||||
|
#include <outputtype.h>
|
||||||
#include <policy/feerate.h>
|
#include <policy/feerate.h>
|
||||||
#include <policy/fees.h>
|
#include <policy/fees.h>
|
||||||
#include <policy/policy.h>
|
#include <policy/policy.h>
|
||||||
|
|
|
@ -4453,35 +4453,6 @@ bool CWalletTx::AcceptToMemoryPool(const CAmount& nAbsurdFee, CValidationState&
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const std::string OUTPUT_TYPE_STRING_LEGACY = "legacy";
|
|
||||||
static const std::string OUTPUT_TYPE_STRING_P2SH_SEGWIT = "p2sh-segwit";
|
|
||||||
static const std::string OUTPUT_TYPE_STRING_BECH32 = "bech32";
|
|
||||||
|
|
||||||
bool ParseOutputType(const std::string& type, OutputType& output_type)
|
|
||||||
{
|
|
||||||
if (type == OUTPUT_TYPE_STRING_LEGACY) {
|
|
||||||
output_type = OutputType::LEGACY;
|
|
||||||
return true;
|
|
||||||
} else if (type == OUTPUT_TYPE_STRING_P2SH_SEGWIT) {
|
|
||||||
output_type = OutputType::P2SH_SEGWIT;
|
|
||||||
return true;
|
|
||||||
} else if (type == OUTPUT_TYPE_STRING_BECH32) {
|
|
||||||
output_type = OutputType::BECH32;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
const std::string& FormatOutputType(OutputType type)
|
|
||||||
{
|
|
||||||
switch (type) {
|
|
||||||
case OutputType::LEGACY: return OUTPUT_TYPE_STRING_LEGACY;
|
|
||||||
case OutputType::P2SH_SEGWIT: return OUTPUT_TYPE_STRING_P2SH_SEGWIT;
|
|
||||||
case OutputType::BECH32: return OUTPUT_TYPE_STRING_BECH32;
|
|
||||||
default: assert(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void CWallet::LearnRelatedScripts(const CPubKey& key, OutputType type)
|
void CWallet::LearnRelatedScripts(const CPubKey& key, OutputType type)
|
||||||
{
|
{
|
||||||
if (key.IsCompressed() && (type == OutputType::P2SH_SEGWIT || type == OutputType::BECH32)) {
|
if (key.IsCompressed() && (type == OutputType::P2SH_SEGWIT || type == OutputType::BECH32)) {
|
||||||
|
@ -4499,37 +4470,6 @@ void CWallet::LearnAllRelatedScripts(const CPubKey& key)
|
||||||
LearnRelatedScripts(key, OutputType::P2SH_SEGWIT);
|
LearnRelatedScripts(key, OutputType::P2SH_SEGWIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
CTxDestination GetDestinationForKey(const CPubKey& key, OutputType type)
|
|
||||||
{
|
|
||||||
switch (type) {
|
|
||||||
case OutputType::LEGACY: return key.GetID();
|
|
||||||
case OutputType::P2SH_SEGWIT:
|
|
||||||
case OutputType::BECH32: {
|
|
||||||
if (!key.IsCompressed()) return key.GetID();
|
|
||||||
CTxDestination witdest = WitnessV0KeyHash(key.GetID());
|
|
||||||
CScript witprog = GetScriptForDestination(witdest);
|
|
||||||
if (type == OutputType::P2SH_SEGWIT) {
|
|
||||||
return CScriptID(witprog);
|
|
||||||
} else {
|
|
||||||
return witdest;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
default: assert(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<CTxDestination> GetAllDestinationsForKey(const CPubKey& key)
|
|
||||||
{
|
|
||||||
CKeyID keyid = key.GetID();
|
|
||||||
if (key.IsCompressed()) {
|
|
||||||
CTxDestination segwit = WitnessV0KeyHash(keyid);
|
|
||||||
CTxDestination p2sh = CScriptID(GetScriptForDestination(segwit));
|
|
||||||
return std::vector<CTxDestination>{std::move(keyid), std::move(p2sh), std::move(segwit)};
|
|
||||||
} else {
|
|
||||||
return std::vector<CTxDestination>{std::move(keyid)};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
CTxDestination CWallet::AddAndGetDestinationForScript(const CScript& script, OutputType type)
|
CTxDestination CWallet::AddAndGetDestinationForScript(const CScript& script, OutputType type)
|
||||||
{
|
{
|
||||||
// Note that scripts over 520 bytes are not yet supported.
|
// Note that scripts over 520 bytes are not yet supported.
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#define BITCOIN_WALLET_WALLET_H
|
#define BITCOIN_WALLET_WALLET_H
|
||||||
|
|
||||||
#include <amount.h>
|
#include <amount.h>
|
||||||
|
#include <outputtype.h>
|
||||||
#include <policy/feerate.h>
|
#include <policy/feerate.h>
|
||||||
#include <streams.h>
|
#include <streams.h>
|
||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
|
@ -93,20 +94,6 @@ enum WalletFeature
|
||||||
FEATURE_LATEST = FEATURE_PRE_SPLIT_KEYPOOL
|
FEATURE_LATEST = FEATURE_PRE_SPLIT_KEYPOOL
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class OutputType {
|
|
||||||
LEGACY,
|
|
||||||
P2SH_SEGWIT,
|
|
||||||
BECH32,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Special output type for change outputs only. Automatically choose type
|
|
||||||
* based on address type setting and the types other of non-change outputs
|
|
||||||
* (see -changetype option documentation and implementation in
|
|
||||||
* CWallet::TransactionChangeType for details).
|
|
||||||
*/
|
|
||||||
CHANGE_AUTO,
|
|
||||||
};
|
|
||||||
|
|
||||||
//! Default for -addresstype
|
//! Default for -addresstype
|
||||||
constexpr OutputType DEFAULT_ADDRESS_TYPE{OutputType::P2SH_SEGWIT};
|
constexpr OutputType DEFAULT_ADDRESS_TYPE{OutputType::P2SH_SEGWIT};
|
||||||
|
|
||||||
|
@ -1266,18 +1253,6 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
bool ParseOutputType(const std::string& str, OutputType& output_type);
|
|
||||||
const std::string& FormatOutputType(OutputType type);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get a destination of the requested type (if possible) to the specified key.
|
|
||||||
* The caller must make sure LearnRelatedScripts has been called beforehand.
|
|
||||||
*/
|
|
||||||
CTxDestination GetDestinationForKey(const CPubKey& key, OutputType);
|
|
||||||
|
|
||||||
/** Get all destinations (potentially) supported by the wallet for the given key. */
|
|
||||||
std::vector<CTxDestination> GetAllDestinationsForKey(const CPubKey& key);
|
|
||||||
|
|
||||||
/** RAII object to check and reserve a wallet rescan */
|
/** RAII object to check and reserve a wallet rescan */
|
||||||
class WalletRescanReserver
|
class WalletRescanReserver
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue