|
|
@ -155,26 +155,25 @@ CBitcoinAddress GetAccountAddress(string strAccount, bool bForceNew=false) |
|
|
|
CAccount account; |
|
|
|
CAccount account; |
|
|
|
walletdb.ReadAccount(strAccount, account); |
|
|
|
walletdb.ReadAccount(strAccount, account); |
|
|
|
|
|
|
|
|
|
|
|
bool bKeyUsed = false; |
|
|
|
if (!bForceNew) { |
|
|
|
|
|
|
|
if (!account.vchPubKey.IsValid()) |
|
|
|
// Check if the current key has been used
|
|
|
|
bForceNew = true; |
|
|
|
if (account.vchPubKey.IsValid()) |
|
|
|
else { |
|
|
|
{ |
|
|
|
// Check if the current key has been used
|
|
|
|
CScript scriptPubKey = GetScriptForDestination(account.vchPubKey.GetID()); |
|
|
|
CScript scriptPubKey = GetScriptForDestination(account.vchPubKey.GetID()); |
|
|
|
for (map<uint256, CWalletTx>::iterator it = pwalletMain->mapWallet.begin(); |
|
|
|
for (map<uint256, CWalletTx>::iterator it = pwalletMain->mapWallet.begin(); |
|
|
|
it != pwalletMain->mapWallet.end() && account.vchPubKey.IsValid(); |
|
|
|
it != pwalletMain->mapWallet.end() && account.vchPubKey.IsValid(); |
|
|
|
++it) |
|
|
|
++it) |
|
|
|
{ |
|
|
|
BOOST_FOREACH(const CTxOut& txout, (*it).second.vout) |
|
|
|
const CWalletTx& wtx = (*it).second; |
|
|
|
if (txout.scriptPubKey == scriptPubKey) { |
|
|
|
BOOST_FOREACH(const CTxOut& txout, wtx.vout) |
|
|
|
bForceNew = true; |
|
|
|
if (txout.scriptPubKey == scriptPubKey) |
|
|
|
break; |
|
|
|
bKeyUsed = true; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Generate a new key
|
|
|
|
// Generate a new key
|
|
|
|
if (!account.vchPubKey.IsValid() || bForceNew || bKeyUsed) |
|
|
|
if (bForceNew) { |
|
|
|
{ |
|
|
|
|
|
|
|
if (!pwalletMain->GetKeyFromPool(account.vchPubKey)) |
|
|
|
if (!pwalletMain->GetKeyFromPool(account.vchPubKey)) |
|
|
|
throw JSONRPCError(RPC_WALLET_KEYPOOL_RAN_OUT, "Error: Keypool ran out, please call keypoolrefill first"); |
|
|
|
throw JSONRPCError(RPC_WALLET_KEYPOOL_RAN_OUT, "Error: Keypool ran out, please call keypoolrefill first"); |
|
|
|
|
|
|
|
|
|
|
|