Do not allow users to get keys from keypool without reserving them
[bitcoinplatinum.git] / src / keystore.h
blob965ae0c79ad865193afe0fb7041ca2c0ffe5f751
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2015 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
9 #include "key.h"
10 #include "pubkey.h"
11 #include "script/script.h"
12 #include "script/standard.h"
13 #include "sync.h"
15 #include <boost/signals2/signal.hpp>
17 /** A virtual base class for key stores */
18 class CKeyStore
20 protected:
21 mutable CCriticalSection cs_KeyStore;
23 public:
24 virtual ~CKeyStore() {}
26 //! Add a key to the store.
27 virtual bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey) =0;
28 virtual bool AddKey(const CKey &key);
30 //! Check whether a key corresponding to a given address is present in the store.
31 virtual bool HaveKey(const CKeyID &address) const =0;
32 virtual bool GetKey(const CKeyID &address, CKey& keyOut) const =0;
33 virtual void GetKeys(std::set<CKeyID> &setAddress) const =0;
34 virtual bool GetPubKey(const CKeyID &address, CPubKey& vchPubKeyOut) const =0;
36 //! Support for BIP 0013 : see https://github.com/bitcoin/bips/blob/master/bip-0013.mediawiki
37 virtual bool AddCScript(const CScript& redeemScript) =0;
38 virtual bool HaveCScript(const CScriptID &hash) const =0;
39 virtual bool GetCScript(const CScriptID &hash, CScript& redeemScriptOut) const =0;
41 //! Support for Watch-only addresses
42 virtual bool AddWatchOnly(const CScript &dest) =0;
43 virtual bool RemoveWatchOnly(const CScript &dest) =0;
44 virtual bool HaveWatchOnly(const CScript &dest) const =0;
45 virtual bool HaveWatchOnly() const =0;
48 typedef std::map<CKeyID, CKey> KeyMap;
49 typedef std::map<CKeyID, CPubKey> WatchKeyMap;
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
56 protected:
57 KeyMap mapKeys;
58 WatchKeyMap mapWatchKeys;
59 ScriptMap mapScripts;
60 WatchOnlySet setWatchOnly;
62 public:
63 bool AddKeyPubKey(const CKey& key, const CPubKey &pubkey) override;
64 bool GetPubKey(const CKeyID &address, CPubKey& vchPubKeyOut) const override;
65 bool HaveKey(const CKeyID &address) const override
67 bool result;
69 LOCK(cs_KeyStore);
70 result = (mapKeys.count(address) > 0);
72 return result;
74 void GetKeys(std::set<CKeyID> &setAddress) const override
76 setAddress.clear();
78 LOCK(cs_KeyStore);
79 KeyMap::const_iterator mi = mapKeys.begin();
80 while (mi != mapKeys.end())
82 setAddress.insert((*mi).first);
83 mi++;
87 bool GetKey(const CKeyID &address, CKey &keyOut) const override
90 LOCK(cs_KeyStore);
91 KeyMap::const_iterator mi = mapKeys.find(address);
92 if (mi != mapKeys.end())
94 keyOut = mi->second;
95 return true;
98 return false;
100 virtual bool AddCScript(const CScript& redeemScript) override;
101 virtual bool HaveCScript(const CScriptID &hash) const override;
102 virtual bool GetCScript(const CScriptID &hash, CScript& redeemScriptOut) const override;
104 virtual bool AddWatchOnly(const CScript &dest) override;
105 virtual bool RemoveWatchOnly(const CScript &dest) override;
106 virtual bool HaveWatchOnly(const CScript &dest) const override;
107 virtual bool HaveWatchOnly() const override;
110 typedef std::vector<unsigned char, secure_allocator<unsigned char> > CKeyingMaterial;
111 typedef std::map<CKeyID, std::pair<CPubKey, std::vector<unsigned char> > > CryptedKeyMap;
113 #endif // BITCOIN_KEYSTORE_H