X-Git-Url: https://git.novaco.in/?a=blobdiff_plain;f=src%2Fwalletdb.h;h=714b3ccf5c48b7b596121433f5e8f4965121abac;hb=ef17ac0211ddd486127e1f94756fbb3fd704a9b4;hp=b5b7f02dc8f0b3a90c36393f20d7f600042330f7;hpb=52c85881648d3381c29da10925c06cbd083cc570;p=novacoin.git diff --git a/src/walletdb.h b/src/walletdb.h index b5b7f02..714b3cc 100644 --- a/src/walletdb.h +++ b/src/walletdb.h @@ -6,7 +6,7 @@ #define BITCOIN_WALLETDB_H #include "db.h" -#include "base58.h" +//#include "base58.h" #include "keystore.h" class CKeyPool; @@ -83,32 +83,59 @@ public: return Erase(std::make_pair(std::string("tx"), hash)); } - bool WriteKey(const CPubKey& vchPubKey, const CPrivKey& vchPrivKey, const CKeyMetadata &keyMeta) + bool WriteKey(const CPubKey& key, const CPrivKey& vchPrivKey, const CKeyMetadata &keyMeta) { nWalletDBUpdated++; - if(!Write(std::make_pair(std::string("keymeta"), vchPubKey), keyMeta)) + if(!Write(std::make_pair(std::string("keymeta"), key), keyMeta)) return false; - if(!Write(std::make_pair(std::string("key"), vchPubKey.Raw()), vchPrivKey, false)) + if(!Write(std::make_pair(std::string("key"), key), vchPrivKey, false)) return false; return true; } - bool WriteCryptedKey(const CPubKey& vchPubKey, const std::vector& vchCryptedSecret, const CKeyMetadata &keyMeta) + bool WriteMalleableKey(const CMalleableKeyView& keyView, const CSecret& vchSecretH, const CKeyMetadata &keyMeta) + { + nWalletDBUpdated++; + if(!Write(std::make_pair(std::string("malmeta"), keyView.ToString()), keyMeta)) + return false; + + if(!Write(std::make_pair(std::string("malpair"), keyView.ToString()), vchSecretH, false)) + return false; + + return true; + } + + bool WriteCryptedMalleableKey(const CMalleableKeyView& keyView, const std::vector& vchCryptedSecretH, const CKeyMetadata &keyMeta) + { + nWalletDBUpdated++; + if(!Write(std::make_pair(std::string("malmeta"), keyView.ToString()), keyMeta)) + return false; + + if(!Write(std::make_pair(std::string("malcpair"), keyView.ToString()), vchCryptedSecretH, false)) + return false; + + Erase(std::make_pair(std::string("malpair"), keyView.ToString())); + + return true; + } + + + bool WriteCryptedKey(const CPubKey& key, const std::vector& vchCryptedSecret, const CKeyMetadata &keyMeta) { nWalletDBUpdated++; bool fEraseUnencryptedKey = true; - if(!Write(std::make_pair(std::string("keymeta"), vchPubKey), keyMeta)) + if(!Write(std::make_pair(std::string("keymeta"), key), keyMeta)) return false; - if (!Write(std::make_pair(std::string("ckey"), vchPubKey.Raw()), vchCryptedSecret, false)) + if (!Write(std::make_pair(std::string("ckey"), key), vchCryptedSecret, false)) return false; if (fEraseUnencryptedKey) { - Erase(std::make_pair(std::string("key"), vchPubKey.Raw())); - Erase(std::make_pair(std::string("wkey"), vchPubKey.Raw())); + Erase(std::make_pair(std::string("key"), key)); + Erase(std::make_pair(std::string("wkey"), key)); } return true; } @@ -125,9 +152,14 @@ public: return Erase(std::make_pair(std::string("mkey"), nID)); } - bool EraseCryptedKey(const CPubKey& vchPubKey) + bool EraseCryptedKey(const CPubKey& key) + { + return Erase(std::make_pair(std::string("ckey"), key)); + } + + bool EraseCryptedMalleableKey(const CMalleableKeyView& keyView) { - return Erase(std::make_pair(std::string("ckey"), vchPubKey.Raw())); + return Erase(std::make_pair(std::string("malcpair"), keyView.ToString())); } bool WriteCScript(const uint160& hash, const CScript& redeemScript) @@ -165,10 +197,10 @@ public: return Write(std::string("orderposnext"), nOrderPosNext); } - bool WriteDefaultKey(const CPubKey& vchPubKey) + bool WriteDefaultKey(const CPubKey& key) { nWalletDBUpdated++; - return Write(std::string("defaultkey"), vchPubKey.Raw()); + return Write(std::string("defaultkey"), key); } bool ReadPool(int64_t nPool, CKeyPool& keypool) @@ -204,6 +236,9 @@ public: DBErrors ReorderTransactions(CWallet*); DBErrors LoadWallet(CWallet* pwallet); + DBErrors FindWalletTx(CWallet* pwallet, std::vector& vTxHash); + DBErrors ZapWalletTx(CWallet* pwallet); + static bool Recover(CDBEnv& dbenv, std::string filename, bool fOnlyKeys); static bool Recover(CDBEnv& dbenv, std::string filename); };