2014-08-27 17:22:33 +02:00
|
|
|
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
2018-01-02 18:12:05 +01:00
|
|
|
// Copyright (c) 2009-2017 The Bitcoin Core developers
|
2014-09-09 10:00:42 +02:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
2014-08-27 17:22:33 +02:00
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
2014-11-03 16:16:40 +01:00
|
|
|
#ifndef BITCOIN_SCRIPT_SIGN_H
|
|
|
|
#define BITCOIN_SCRIPT_SIGN_H
|
2014-08-27 17:22:33 +02:00
|
|
|
|
2017-11-10 01:57:53 +01:00
|
|
|
#include <script/interpreter.h>
|
2014-08-27 17:22:33 +02:00
|
|
|
|
2018-03-18 03:19:09 +01:00
|
|
|
class CKey;
|
2014-11-04 19:06:20 +01:00
|
|
|
class CKeyID;
|
2014-08-27 17:22:33 +02:00
|
|
|
class CScript;
|
2018-03-18 03:19:09 +01:00
|
|
|
class CScriptID;
|
2014-08-27 17:22:33 +02:00
|
|
|
class CTransaction;
|
2014-09-09 10:00:42 +02:00
|
|
|
|
2014-08-27 17:22:33 +02:00
|
|
|
struct CMutableTransaction;
|
|
|
|
|
2018-03-18 03:19:09 +01:00
|
|
|
/** An interface to be implemented by keystores that support signing. */
|
|
|
|
class SigningProvider
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual ~SigningProvider() {}
|
|
|
|
virtual bool GetCScript(const CScriptID &scriptid, CScript& script) const =0;
|
|
|
|
virtual bool GetPubKey(const CKeyID &address, CPubKey& pubkey) const =0;
|
|
|
|
virtual bool GetKey(const CKeyID &address, CKey& key) const =0;
|
|
|
|
};
|
|
|
|
|
2018-03-27 22:15:10 +02:00
|
|
|
/** Interface for signature creators. */
|
2014-11-04 19:06:20 +01:00
|
|
|
class BaseSignatureCreator {
|
|
|
|
public:
|
|
|
|
virtual ~BaseSignatureCreator() {}
|
|
|
|
virtual const BaseSignatureChecker& Checker() const =0;
|
|
|
|
|
|
|
|
/** Create a singular (non-script) signature. */
|
2018-03-27 22:15:10 +02:00
|
|
|
virtual bool CreateSig(const SigningProvider& provider, std::vector<unsigned char>& vchSig, const CKeyID& keyid, const CScript& scriptCode, SigVersion sigversion) const =0;
|
2014-11-04 19:06:20 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
/** A signature creator for transactions. */
|
|
|
|
class TransactionSignatureCreator : public BaseSignatureCreator {
|
|
|
|
const CTransaction* txTo;
|
|
|
|
unsigned int nIn;
|
|
|
|
int nHashType;
|
2015-12-27 19:49:08 +01:00
|
|
|
CAmount amount;
|
2014-11-04 19:06:20 +01:00
|
|
|
const TransactionSignatureChecker checker;
|
|
|
|
|
|
|
|
public:
|
2018-03-27 22:15:10 +02:00
|
|
|
TransactionSignatureCreator(const CTransaction* txToIn, unsigned int nInIn, const CAmount& amountIn, int nHashTypeIn=SIGHASH_ALL);
|
2017-06-20 21:58:56 +02:00
|
|
|
const BaseSignatureChecker& Checker() const override { return checker; }
|
2018-03-27 22:15:10 +02:00
|
|
|
bool CreateSig(const SigningProvider& provider, std::vector<unsigned char>& vchSig, const CKeyID& keyid, const CScript& scriptCode, SigVersion sigversion) const override;
|
2016-03-31 14:54:58 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
class MutableTransactionSignatureCreator : public TransactionSignatureCreator {
|
|
|
|
CTransaction tx;
|
|
|
|
|
|
|
|
public:
|
2018-03-27 22:15:10 +02:00
|
|
|
MutableTransactionSignatureCreator(const CMutableTransaction* txToIn, unsigned int nInIn, const CAmount& amountIn, int nHashTypeIn) : TransactionSignatureCreator(&tx, nInIn, amountIn, nHashTypeIn), tx(*txToIn) {}
|
2014-11-04 19:06:20 +01:00
|
|
|
};
|
|
|
|
|
2016-06-29 11:48:51 +02:00
|
|
|
/** A signature creator that just produces 72-byte empty signatures. */
|
2018-03-27 22:34:39 +02:00
|
|
|
extern const BaseSignatureCreator& DUMMY_SIGNATURE_CREATOR;
|
2016-03-31 14:54:58 +02:00
|
|
|
|
|
|
|
struct SignatureData {
|
|
|
|
CScript scriptSig;
|
|
|
|
CScriptWitness scriptWitness;
|
|
|
|
|
|
|
|
SignatureData() {}
|
|
|
|
explicit SignatureData(const CScript& script) : scriptSig(script) {}
|
2015-05-01 15:21:06 +02:00
|
|
|
};
|
|
|
|
|
2014-11-04 19:06:20 +01:00
|
|
|
/** Produce a script signature using a generic signature creator. */
|
2018-03-27 22:15:10 +02:00
|
|
|
bool ProduceSignature(const SigningProvider& provider, const BaseSignatureCreator& creator, const CScript& scriptPubKey, SignatureData& sigdata);
|
2014-11-04 19:06:20 +01:00
|
|
|
|
|
|
|
/** Produce a script signature for a transaction. */
|
2018-03-18 03:19:09 +01:00
|
|
|
bool SignSignature(const SigningProvider &provider, const CScript& fromPubKey, CMutableTransaction& txTo, unsigned int nIn, const CAmount& amount, int nHashType);
|
|
|
|
bool SignSignature(const SigningProvider &provider, const CTransaction& txFrom, CMutableTransaction& txTo, unsigned int nIn, int nHashType);
|
2014-08-27 17:22:33 +02:00
|
|
|
|
2014-11-04 19:06:20 +01:00
|
|
|
/** Combine two script signatures using a generic signature checker, intelligently, possibly with OP_0 placeholders. */
|
2016-03-31 14:54:58 +02:00
|
|
|
SignatureData CombineSignatures(const CScript& scriptPubKey, const BaseSignatureChecker& checker, const SignatureData& scriptSig1, const SignatureData& scriptSig2);
|
2014-11-04 19:06:20 +01:00
|
|
|
|
2016-03-31 14:54:58 +02:00
|
|
|
/** Extract signature data from a transaction, and insert it. */
|
|
|
|
SignatureData DataFromTransaction(const CMutableTransaction& tx, unsigned int nIn);
|
|
|
|
void UpdateTransaction(CMutableTransaction& tx, unsigned int nIn, const SignatureData& data);
|
2018-03-05 22:37:24 +01:00
|
|
|
void UpdateInput(CTxIn& input, const SignatureData& data);
|
2014-08-27 17:22:33 +02:00
|
|
|
|
2017-12-01 01:48:31 +01:00
|
|
|
/* Check whether we know how to sign for an output like this, assuming we
|
|
|
|
* have all private keys. While this function does not need private keys, the passed
|
2018-03-18 03:19:09 +01:00
|
|
|
* provider is used to look up public keys and redeemscripts by hash.
|
2017-12-01 01:48:31 +01:00
|
|
|
* Solvability is unrelated to whether we consider this output to be ours. */
|
2018-03-18 03:19:09 +01:00
|
|
|
bool IsSolvable(const SigningProvider& provider, const CScript& script);
|
2017-12-01 01:48:31 +01:00
|
|
|
|
2014-11-03 16:16:40 +01:00
|
|
|
#endif // BITCOIN_SCRIPT_SIGN_H
|