transaction history api in progress

This commit is contained in:
Ilya Kitaev 2016-04-20 13:17:27 +03:00
parent 12345d382c
commit 663ed04eb8
7 changed files with 110 additions and 16 deletions

View file

@ -48,28 +48,28 @@ namespace Bitmonero {
PendingTransaction::~PendingTransaction() {} PendingTransaction::~PendingTransaction() {}
TransactionImpl::TransactionImpl(WalletImpl *wallet) PendingTransactionImpl::PendingTransactionImpl(WalletImpl *wallet)
: m_wallet(wallet) : m_wallet(wallet)
{ {
} }
TransactionImpl::~TransactionImpl() PendingTransactionImpl::~PendingTransactionImpl()
{ {
} }
int TransactionImpl::status() const int PendingTransactionImpl::status() const
{ {
return m_status; return m_status;
} }
string TransactionImpl::errorString() const string PendingTransactionImpl::errorString() const
{ {
return m_errorString; return m_errorString;
} }
bool TransactionImpl::commit() bool PendingTransactionImpl::commit()
{ {
LOG_PRINT_L0("m_pending_tx size: " << m_pending_tx.size()); LOG_PRINT_L0("m_pending_tx size: " << m_pending_tx.size());
@ -105,7 +105,7 @@ bool TransactionImpl::commit()
return m_status == Status_Ok; return m_status == Status_Ok;
} }
uint64_t TransactionImpl::amount() const uint64_t PendingTransactionImpl::amount() const
{ {
uint64_t result = 0; uint64_t result = 0;
for (const auto &ptx : m_pending_tx) { for (const auto &ptx : m_pending_tx) {
@ -116,7 +116,7 @@ uint64_t TransactionImpl::amount() const
return result; return result;
} }
uint64_t TransactionImpl::dust() const uint64_t PendingTransactionImpl::dust() const
{ {
uint32_t result = 0; uint32_t result = 0;
for (const auto & ptx : m_pending_tx) { for (const auto & ptx : m_pending_tx) {
@ -125,7 +125,7 @@ uint64_t TransactionImpl::dust() const
return result; return result;
} }
uint64_t TransactionImpl::fee() const uint64_t PendingTransactionImpl::fee() const
{ {
uint32_t result = 0; uint32_t result = 0;
for (const auto ptx : m_pending_tx) { for (const auto ptx : m_pending_tx) {

View file

@ -28,6 +28,70 @@
// //
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers // Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
#include "transaction_history.h" #include "transaction_history.h"
#include "transaction_info.h"
#include "wallet.h"
#include "crypto/hash.h"
#include "wallet/wallet2.h"
#include "contrib/epee/include/string_tools.h"
#include <string>
#include <list>
namespace Bitmonero {
TransactionHistoryImpl::TransactionHistoryImpl(WalletImpl *wallet)
{
}
TransactionHistoryImpl::~TransactionHistoryImpl()
{
}
int TransactionHistoryImpl::count() const
{
return 0;
}
TransactionInfo *TransactionHistoryImpl::transaction(const std::string &id) const
{
return nullptr;
}
std::vector<TransactionInfo *> TransactionHistoryImpl::getAll() const
{
return std::vector<TransactionInfo*>();
}
void TransactionHistoryImpl::refresh()
{
// TODO: configurable values;
uint64_t min_height = 0;
uint64_t max_height = (uint64_t)-1;
// TODO: delete old transactions;
std::list<std::pair<crypto::hash, tools::wallet2::payment_details>> payments;
m_wallet->m_wallet->get_payments(payments, min_height, max_height);
for (std::list<std::pair<crypto::hash, tools::wallet2::payment_details>>::const_iterator i = payments.begin(); i != payments.end(); ++i) {
const tools::wallet2::payment_details &pd = i->second;
std::string payment_id = string_tools::pod_to_hex(i->first);
if (payment_id.substr(16).find_first_not_of('0') == std::string::npos)
payment_id = payment_id.substr(0,16);
// TODO
TransactionInfo * ti = new TransactionInfo();
//output.insert(std::make_pair(pd.m_block_height, std::make_pair(true, (boost::format("%20.20s %s %s %s") % print_money(pd.m_amount) % string_tools::pod_to_hex(pd.m_tx_hash) % payment_id % "-").str())));
}
}
TransactionInfo *TransactionHistoryImpl::transaction(int index) const
{
return nullptr;
}
}

View file

@ -32,12 +32,23 @@
namespace Bitmonero { namespace Bitmonero {
class TransactionInfo;
class WalletImpl;
class TransactionHistoryImpl : public TransactionHistory class TransactionHistoryImpl : public TransactionHistory
{ {
public:
TransactionHistoryImpl(WalletImpl * wallet);
~TransactionHistoryImpl();
virtual int count() const; virtual int count() const;
virtual TransactionInfo * transaction(int index) const = 0; virtual TransactionInfo * transaction(int index) const;
virtual TransactionInfo * transaction(const std::string &id) const = 0; virtual TransactionInfo * transaction(const std::string &id) const;
virtual std::vector<TransactionInfo*> getAll() const = 0; virtual std::vector<TransactionInfo*> getAll() const;
virtual void refresh();
private:
std::vector<TransactionInfo*> m_history;
WalletImpl *m_wallet;
}; };
} }

View file

@ -34,6 +34,8 @@
namespace Bitmonero { namespace Bitmonero {
class TransactionHistoryImpl;
class TransactionInfoImpl : public TransactionInfo class TransactionInfoImpl : public TransactionInfo
{ {
public: public:
@ -47,6 +49,21 @@ public:
virtual std::string address() const; virtual std::string address() const;
virtual std::time_t timestamp() const; virtual std::time_t timestamp() const;
virtual std::string paymentId() const; virtual std::string paymentId() const;
private:
int m_direction;
bool m_hold;
bool m_failed;
uint64_t m_amount;
uint64_t m_fee;
uint64_t b_blockheight;
std::string m_address;
std::time_t m_timestamp;
std::string m_paymentid;
friend class TransactionHistoryImpl;
}; };
} // namespace } // namespace

View file

@ -288,7 +288,7 @@ PendingTransaction *WalletImpl::createTransaction(const string &dst_addr, uint64
if (fake_outs_count == 0) if (fake_outs_count == 0)
fake_outs_count = DEFAULT_MIX; fake_outs_count = DEFAULT_MIX;
TransactionImpl * transaction = new TransactionImpl(this); PendingTransactionImpl * transaction = new PendingTransactionImpl(this);
do { do {

View file

@ -38,7 +38,8 @@
namespace Bitmonero { namespace Bitmonero {
class TransactionHistoryImpl;
class PendingTransactionImpl;
class WalletImpl : public Wallet class WalletImpl : public Wallet
{ {
@ -72,7 +73,9 @@ private:
void clearStatus(); void clearStatus();
private: private:
friend class TransactionImpl; friend class PendingTransactionImpl;
friend class TransactionHistoryImpl;
tools::wallet2 * m_wallet; tools::wallet2 * m_wallet;
int m_status; int m_status;
std::string m_errorString; std::string m_errorString;

View file

@ -63,8 +63,7 @@ struct TransactionHistory
virtual TransactionInfo * transaction(int index) const = 0; virtual TransactionInfo * transaction(int index) const = 0;
virtual TransactionInfo * transaction(const std::string &id) const = 0; virtual TransactionInfo * transaction(const std::string &id) const = 0;
virtual std::vector<TransactionInfo*> getAll() const = 0; virtual std::vector<TransactionInfo*> getAll() const = 0;
// TODO: virtual void refresh() = 0;
// refresh();
}; };