Dash Core  0.12.2.1
P2P Digital Currency
keystore.h
Go to the documentation of this file.
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.
5 
6 #ifndef BITCOIN_KEYSTORE_H
7 #define BITCOIN_KEYSTORE_H
8 
9 #include "hdchain.h"
10 #include "key.h"
11 #include "pubkey.h"
12 #include "script/script.h"
13 #include "script/standard.h"
14 #include "sync.h"
15 
16 #include <boost/signals2/signal.hpp>
17 #include <boost/variant.hpp>
18 
20 class CKeyStore
21 {
22 protected:
24 
25 public:
26  virtual ~CKeyStore() {}
27 
29  virtual bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey) =0;
30  virtual bool AddKey(const CKey &key);
31 
33  virtual bool HaveKey(const CKeyID &address) const =0;
34  virtual bool GetKey(const CKeyID &address, CKey& keyOut) const =0;
35  virtual void GetKeys(std::set<CKeyID> &setAddress) const =0;
36  virtual bool GetPubKey(const CKeyID &address, CPubKey& vchPubKeyOut) const =0;
37 
39  virtual bool AddCScript(const CScript& redeemScript) =0;
40  virtual bool HaveCScript(const CScriptID &hash) const =0;
41  virtual bool GetCScript(const CScriptID &hash, CScript& redeemScriptOut) const =0;
42 
44  virtual bool AddWatchOnly(const CScript &dest) =0;
45  virtual bool RemoveWatchOnly(const CScript &dest) =0;
46  virtual bool HaveWatchOnly(const CScript &dest) const =0;
47  virtual bool HaveWatchOnly() const =0;
48 };
49 
50 typedef std::map<CKeyID, CKey> KeyMap;
51 typedef std::map<CKeyID, CPubKey> WatchKeyMap;
52 typedef std::map<CScriptID, CScript > ScriptMap;
53 typedef std::set<CScript> WatchOnlySet;
54 
56 class CBasicKeyStore : public CKeyStore
57 {
58 protected:
63  /* the HD chain data model*/
65 
66 public:
67  bool AddKeyPubKey(const CKey& key, const CPubKey &pubkey);
68  bool GetPubKey(const CKeyID &address, CPubKey& vchPubKeyOut) const;
69  bool HaveKey(const CKeyID &address) const
70  {
71  bool result;
72  {
74  result = (mapKeys.count(address) > 0);
75  }
76  return result;
77  }
78  void GetKeys(std::set<CKeyID> &setAddress) const
79  {
80  setAddress.clear();
81  {
83  KeyMap::const_iterator mi = mapKeys.begin();
84  while (mi != mapKeys.end())
85  {
86  setAddress.insert((*mi).first);
87  mi++;
88  }
89  }
90  }
91  bool GetKey(const CKeyID &address, CKey &keyOut) const
92  {
93  {
95  KeyMap::const_iterator mi = mapKeys.find(address);
96  if (mi != mapKeys.end())
97  {
98  keyOut = mi->second;
99  return true;
100  }
101  }
102  return false;
103  }
104  virtual bool AddCScript(const CScript& redeemScript);
105  virtual bool HaveCScript(const CScriptID &hash) const;
106  virtual bool GetCScript(const CScriptID &hash, CScript& redeemScriptOut) const;
107 
108  virtual bool AddWatchOnly(const CScript &dest);
109  virtual bool RemoveWatchOnly(const CScript &dest);
110  virtual bool HaveWatchOnly(const CScript &dest) const;
111  virtual bool HaveWatchOnly() const;
112 
113  bool GetHDChain(CHDChain& hdChainRet) const;
114 };
115 
116 typedef std::vector<unsigned char, secure_allocator<unsigned char> > CKeyingMaterial;
117 typedef std::map<CKeyID, std::pair<CPubKey, std::vector<unsigned char> > > CryptedKeyMap;
118 
119 #endif // BITCOIN_KEYSTORE_H
virtual bool GetCScript(const CScriptID &hash, CScript &redeemScriptOut) const
Definition: keystore.cpp:57
std::map< CScriptID, CScript > ScriptMap
Definition: keystore.h:52
bool HaveKey(const CKeyID &address) const
Check whether a key corresponding to a given address is present in the store.
Definition: keystore.h:69
std::vector< unsigned char, secure_allocator< unsigned char > > CKeyingMaterial
Definition: keystore.h:116
Definition: pubkey.h:27
std::map< CKeyID, std::pair< CPubKey, std::vector< unsigned char > > > CryptedKeyMap
Definition: keystore.h:117
virtual ~CKeyStore()
Definition: keystore.h:26
virtual bool AddWatchOnly(const CScript &dest)
Support for Watch-only addresses.
Definition: keystore.cpp:85
virtual bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey)=0
Add a key to the store.
virtual void GetKeys(std::set< CKeyID > &setAddress) const =0
virtual bool HaveWatchOnly() const
Definition: keystore.cpp:111
std::set< CScript > WatchOnlySet
Definition: keystore.h:53
virtual bool GetPubKey(const CKeyID &address, CPubKey &vchPubKeyOut) const =0
WatchKeyMap mapWatchKeys
Definition: keystore.h:60
virtual bool GetCScript(const CScriptID &hash, CScript &redeemScriptOut) const =0
virtual bool AddCScript(const CScript &redeemScript)=0
Support for BIP 0013 : see https://github.com/bitcoin/bips/blob/master/bip-0013.mediawiki.
virtual bool RemoveWatchOnly(const CScript &dest)
Definition: keystore.cpp:95
bool GetKey(const CKeyID &address, CKey &keyOut) const
Definition: keystore.h:91
bool GetHDChain(CHDChain &hdChainRet) const
Definition: keystore.cpp:117
bool GetPubKey(const CKeyID &address, CPubKey &vchPubKeyOut) const
Definition: keystore.cpp:18
CCriticalSection cs_KeyStore
Definition: keystore.h:23
#define LOCK(cs)
Definition: sync.h:168
virtual bool AddCScript(const CScript &redeemScript)
Support for BIP 0013 : see https://github.com/bitcoin/bips/blob/master/bip-0013.mediawiki.
Definition: keystore.cpp:41
std::map< CKeyID, CPubKey > WatchKeyMap
Definition: keystore.h:51
KeyMap mapKeys
Definition: keystore.h:59
void GetKeys(std::set< CKeyID > &setAddress) const
Definition: keystore.h:78
virtual bool HaveWatchOnly() const =0
virtual bool HaveCScript(const CScriptID &hash) const =0
virtual bool HaveKey(const CKeyID &address) const =0
Check whether a key corresponding to a given address is present in the store.
virtual bool GetKey(const CKeyID &address, CKey &keyOut) const =0
virtual bool AddWatchOnly(const CScript &dest)=0
Support for Watch-only addresses.
virtual bool RemoveWatchOnly(const CScript &dest)=0
Definition: pubkey.h:37
virtual bool AddKey(const CKey &key)
Definition: keystore.cpp:14
virtual bool HaveCScript(const CScriptID &hash) const
Definition: keystore.cpp:51
std::map< CKeyID, CKey > KeyMap
Definition: keystore.h:50
Definition: key.h:35
bool AddKeyPubKey(const CKey &key, const CPubKey &pubkey)
Add a key to the store.
Definition: keystore.cpp:34
CHDChain hdChain
Definition: keystore.h:64
result
Definition: rpcuser.py:37
WatchOnlySet setWatchOnly
Definition: keystore.h:62
ScriptMap mapScripts
Definition: keystore.h:61