2018-07-09 18:15:50 +10:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2022-12-24 23:49:50 +00:00
|
|
|
// Copyright (c) 2009-2022 The Bitcoin Core developers
|
2018-07-09 18:15:50 +10:00
|
|
|
// 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
|
|
|
|
|
2023-08-08 10:57:31 -04:00
|
|
|
#include <addresstype.h>
|
2019-06-06 22:52:24 +02:00
|
|
|
#include <script/signingprovider.h>
|
2018-07-09 18:15:50 +10:00
|
|
|
|
2019-06-27 14:53:27 -04:00
|
|
|
#include <array>
|
2021-08-04 13:38:36 +08:00
|
|
|
#include <optional>
|
2018-07-09 18:15:50 +10:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
enum class OutputType {
|
|
|
|
LEGACY,
|
|
|
|
P2SH_SEGWIT,
|
|
|
|
BECH32,
|
2021-06-04 16:38:47 -04:00
|
|
|
BECH32M,
|
2022-07-28 16:19:56 +02:00
|
|
|
UNKNOWN,
|
2018-07-09 18:15:50 +10:00
|
|
|
};
|
|
|
|
|
2020-12-26 12:40:37 +01:00
|
|
|
static constexpr auto OUTPUT_TYPES = std::array{
|
|
|
|
OutputType::LEGACY,
|
|
|
|
OutputType::P2SH_SEGWIT,
|
|
|
|
OutputType::BECH32,
|
2021-06-04 16:38:47 -04:00
|
|
|
OutputType::BECH32M,
|
2020-12-26 12:40:37 +01:00
|
|
|
};
|
2019-06-27 14:53:27 -04:00
|
|
|
|
2021-08-04 13:38:36 +08:00
|
|
|
std::optional<OutputType> ParseOutputType(const std::string& str);
|
2018-07-09 18:15:50 +10:00
|
|
|
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);
|
|
|
|
|
2018-07-09 19:30:39 +10:00
|
|
|
/**
|
|
|
|
* Get a destination of the requested type (if possible) to the specified script.
|
|
|
|
* This function will automatically add the script (and any other
|
|
|
|
* necessary scripts) to the keystore.
|
|
|
|
*/
|
2019-06-06 16:33:23 +02:00
|
|
|
CTxDestination AddAndGetDestinationForScript(FillableSigningProvider& keystore, const CScript& script, OutputType);
|
2018-07-09 19:30:39 +10:00
|
|
|
|
2021-06-04 17:35:47 -04:00
|
|
|
/** Get the OutputType for a CTxDestination */
|
|
|
|
std::optional<OutputType> OutputTypeFromDestination(const CTxDestination& dest);
|
|
|
|
|
2018-07-09 18:15:50 +10:00
|
|
|
#endif // BITCOIN_OUTPUTTYPE_H
|