diff options
| author | Patrick Strateman <[email protected]> | 2016-06-02 23:16:42 -0700 |
|---|---|---|
| committer | Patrick Strateman <[email protected]> | 2016-06-06 07:02:05 -0700 |
| commit | 152ab236ea1c1106340196f45918fd84f57a0b63 (patch) | |
| tree | ec99b28f0b317d83a6828efe3e39538b17633966 /src/wallet/wallet.cpp | |
| parent | Merge #8137: Improve CWallet API with new AccountMove function. (diff) | |
| download | discoin-152ab236ea1c1106340196f45918fd84f57a0b63.tar.xz discoin-152ab236ea1c1106340196f45918fd84f57a0b63.zip | |
Improve CWallet API with new GetAccountPubkey function.
Remove one more caller that is passing CWalletDB.
Diffstat (limited to 'src/wallet/wallet.cpp')
| -rw-r--r-- | src/wallet/wallet.cpp | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/wallet/wallet.cpp b/src/wallet/wallet.cpp index fb56e7c1d..f3d165472 100644 --- a/src/wallet/wallet.cpp +++ b/src/wallet/wallet.cpp @@ -640,6 +640,44 @@ bool CWallet::AccountMove(std::string strFrom, std::string strTo, CAmount nAmoun return true; } +bool CWallet::GetAccountPubkey(CPubKey &pubKey, std::string strAccount, bool bForceNew) +{ + CWalletDB walletdb(strWalletFile); + + CAccount account; + walletdb.ReadAccount(strAccount, account); + + if (!bForceNew) { + if (!account.vchPubKey.IsValid()) + bForceNew = true; + else { + // Check if the current key has been used + CScript scriptPubKey = GetScriptForDestination(account.vchPubKey.GetID()); + for (map<uint256, CWalletTx>::iterator it = mapWallet.begin(); + it != mapWallet.end() && account.vchPubKey.IsValid(); + ++it) + BOOST_FOREACH(const CTxOut& txout, (*it).second.vout) + if (txout.scriptPubKey == scriptPubKey) { + bForceNew = true; + break; + } + } + } + + // Generate a new key + if (bForceNew) { + if (!GetKeyFromPool(account.vchPubKey)) + return false; + + SetAddressBook(account.vchPubKey.GetID(), strAccount, "receive"); + walletdb.WriteAccount(strAccount, account); + } + + pubKey = account.vchPubKey; + + return true; +} + void CWallet::MarkDirty() { { |