Browse Source

Merge branch 'gettransaction' of https://github.com/gavinandresen/bitcoin-git into integration

0.8
Gavin Andresen 14 years ago
parent
commit
76e97c4002
  1. 14
      rpc.cpp

14
rpc.cpp

@ -877,7 +877,7 @@ Value listreceivedbyaccount(const Array& params, bool fHelp) @@ -877,7 +877,7 @@ Value listreceivedbyaccount(const Array& params, bool fHelp)
return ListReceived(params, true);
}
void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDepth, Array& ret)
void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDepth, bool fLong, Array& ret)
{
int64 nGenerated, nFee;
string strSentAccount;
@ -894,6 +894,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe @@ -894,6 +894,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe
entry.push_back(Pair("account", string("")));
entry.push_back(Pair("category", "generate"));
entry.push_back(Pair("amount", ValueFromAmount(nGenerated)));
if (fLong)
WalletTxToJSON(wtx, entry);
ret.push_back(entry);
}
@ -909,6 +910,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe @@ -909,6 +910,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe
entry.push_back(Pair("category", "send"));
entry.push_back(Pair("amount", ValueFromAmount(-s.second)));
entry.push_back(Pair("fee", ValueFromAmount(-nFee)));
if (fLong)
WalletTxToJSON(wtx, entry);
ret.push_back(entry);
}
@ -930,6 +932,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe @@ -930,6 +932,7 @@ void ListTransactions(const CWalletTx& wtx, const string& strAccount, int nMinDe
entry.push_back(Pair("address", r.first));
entry.push_back(Pair("category", "receive"));
entry.push_back(Pair("amount", ValueFromAmount(r.second)));
if (fLong)
WalletTxToJSON(wtx, entry);
ret.push_back(entry);
}
@ -996,7 +999,7 @@ Value listtransactions(const Array& params, bool fHelp) @@ -996,7 +999,7 @@ Value listtransactions(const Array& params, bool fHelp)
{
CWalletTx *const pwtx = (*it).second.first;
if (pwtx != 0)
ListTransactions(*pwtx, strAccount, 0, ret);
ListTransactions(*pwtx, strAccount, 0, true, ret);
CAccountingEntry *const pacentry = (*it).second.second;
if (pacentry != 0)
AcentryToJSON(*pacentry, strAccount, ret);
@ -1083,7 +1086,7 @@ Value gettransaction(const Array& params, bool fHelp) @@ -1083,7 +1086,7 @@ Value gettransaction(const Array& params, bool fHelp)
CRITICAL_BLOCK(cs_mapWallet)
{
if (!mapWallet.count(hash))
throw JSONRPCError(-5, "Invalid transaction id");
throw JSONRPCError(-5, "Invalid or non-wallet transaction id");
const CWalletTx& wtx = mapWallet[hash];
int64 nCredit = wtx.GetCredit();
@ -1094,7 +1097,12 @@ Value gettransaction(const Array& params, bool fHelp) @@ -1094,7 +1097,12 @@ Value gettransaction(const Array& params, bool fHelp)
entry.push_back(Pair("amount", ValueFromAmount(nNet - nFee)));
if (wtx.IsFromMe())
entry.push_back(Pair("fee", ValueFromAmount(nFee)));
WalletTxToJSON(mapWallet[hash], entry);
Array details;
ListTransactions(mapWallet[hash], "*", 0, false, details);
entry.push_back(Pair("details", details));
}
return entry;

Loading…
Cancel
Save