1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2014 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
6 #ifndef BITCOIN_KEYSTORE_H
7 #define BITCOIN_KEYSTORE_H
11 #include "script/script.h"
12 #include "script/standard.h"
15 #include <boost/signals2/signal.hpp>
16 #include <boost/variant.hpp>
18 /** A virtual base class for key stores */
22 mutable CCriticalSection cs_KeyStore
;
25 virtual ~CKeyStore() {}
27 //! Add a key to the store.
28 virtual bool AddKeyPubKey(const CKey
&key
, const CPubKey
&pubkey
) =0;
29 virtual bool AddKey(const CKey
&key
);
31 //! Check whether a key corresponding to a given address is present in the store.
32 virtual bool HaveKey(const CKeyID
&address
) const =0;
33 virtual bool GetKey(const CKeyID
&address
, CKey
& keyOut
) const =0;
34 virtual void GetKeys(std::set
<CKeyID
> &setAddress
) const =0;
35 virtual bool GetPubKey(const CKeyID
&address
, CPubKey
& vchPubKeyOut
) const;
37 //! Support for BIP 0013 : see https://github.com/bitcoin/bips/blob/master/bip-0013.mediawiki
38 virtual bool AddCScript(const CScript
& redeemScript
) =0;
39 virtual bool HaveCScript(const CScriptID
&hash
) const =0;
40 virtual bool GetCScript(const CScriptID
&hash
, CScript
& redeemScriptOut
) const =0;
42 //! Support for Watch-only addresses
43 virtual bool AddWatchOnly(const CScript
&dest
) =0;
44 virtual bool RemoveWatchOnly(const CScript
&dest
) =0;
45 virtual bool HaveWatchOnly(const CScript
&dest
) const =0;
46 virtual bool HaveWatchOnly() const =0;
49 typedef std::map
<CKeyID
, CKey
> KeyMap
;
50 typedef std::map
<CScriptID
, CScript
> ScriptMap
;
51 typedef std::set
<CScript
> WatchOnlySet
;
53 /** Basic key store, that keeps keys in an address->secret map */
54 class CBasicKeyStore
: public CKeyStore
59 WatchOnlySet setWatchOnly
;
62 bool AddKeyPubKey(const CKey
& key
, const CPubKey
&pubkey
);
63 bool HaveKey(const CKeyID
&address
) const
68 result
= (mapKeys
.count(address
) > 0);
72 void GetKeys(std::set
<CKeyID
> &setAddress
) const
77 KeyMap::const_iterator mi
= mapKeys
.begin();
78 while (mi
!= mapKeys
.end())
80 setAddress
.insert((*mi
).first
);
85 bool GetKey(const CKeyID
&address
, CKey
&keyOut
) const
89 KeyMap::const_iterator mi
= mapKeys
.find(address
);
90 if (mi
!= mapKeys
.end())
98 virtual bool AddCScript(const CScript
& redeemScript
);
99 virtual bool HaveCScript(const CScriptID
&hash
) const;
100 virtual bool GetCScript(const CScriptID
&hash
, CScript
& redeemScriptOut
) const;
102 virtual bool AddWatchOnly(const CScript
&dest
);
103 virtual bool RemoveWatchOnly(const CScript
&dest
);
104 virtual bool HaveWatchOnly(const CScript
&dest
) const;
105 virtual bool HaveWatchOnly() const;
108 typedef std::vector
<unsigned char, secure_allocator
<unsigned char> > CKeyingMaterial
;
109 typedef std::map
<CKeyID
, std::pair
<CPubKey
, std::vector
<unsigned char> > > CryptedKeyMap
;
111 #endif // BITCOIN_KEYSTORE_H