monero-gui/src/libwalletqt/Wallet.cpp

283 lines
7.0 KiB
C++
Raw Normal View History

2016-02-23 17:59:26 +02:00
#include "Wallet.h"
2016-06-08 13:53:24 +03:00
#include "PendingTransaction.h"
#include "TransactionHistory.h"
#include "model/TransactionHistoryModel.h"
2016-10-07 23:05:51 +03:00
#include "model/TransactionHistorySortFilterModel.h"
#include "wallet/wallet2_api.h"
2016-02-29 16:39:39 +02:00
#include <QFile>
#include <QDir>
#include <QDebug>
#include <QUrl>
2016-06-17 16:35:07 +03:00
#include <QTimer>
2016-02-29 16:39:39 +02:00
namespace {
2016-11-01 19:14:39 +02:00
static const int DAEMON_BLOCKCHAIN_HEIGHT_CACHE_TTL_SECONDS = 10;
static const int DAEMON_BLOCKCHAIN_TARGET_HEIGHT_CACHE_TTL_SECONDS = 60;
2016-02-29 16:39:39 +02:00
}
2016-07-13 15:24:40 +03:00
class WalletListenerImpl : public Bitmonero::WalletListener
{
public:
WalletListenerImpl(Wallet * w)
: m_wallet(w)
{
}
virtual void moneySpent(const std::string &txId, uint64_t amount)
{
2016-07-14 13:09:39 +03:00
qDebug() << __FUNCTION__;
emit m_wallet->moneySpent(QString::fromStdString(txId), amount);
2016-07-13 15:24:40 +03:00
}
2016-07-13 15:24:40 +03:00
virtual void moneyReceived(const std::string &txId, uint64_t amount)
{
qDebug() << __FUNCTION__;
emit m_wallet->moneyReceived(QString::fromStdString(txId), amount);
}
virtual void newBlock(uint64_t height)
{
// qDebug() << __FUNCTION__;
emit m_wallet->newBlock(height);
2016-07-13 15:24:40 +03:00
}
virtual void updated()
{
2016-07-14 13:09:39 +03:00
qDebug() << __FUNCTION__;
2016-07-13 15:24:40 +03:00
emit m_wallet->updated();
}
// called when wallet refreshed by background thread or explicitly
virtual void refreshed()
{
2016-07-14 13:09:39 +03:00
qDebug() << __FUNCTION__;
2016-07-13 15:24:40 +03:00
emit m_wallet->refreshed();
}
private:
Wallet * m_wallet;
};
Wallet::Wallet(QObject * parent)
: Wallet(nullptr, parent)
{
}
2016-02-29 16:39:39 +02:00
QString Wallet::getSeed() const
2016-02-29 16:39:39 +02:00
{
return QString::fromStdString(m_walletImpl->seed());
2016-02-29 16:39:39 +02:00
}
QString Wallet::getSeedLanguage() const
2016-02-29 16:39:39 +02:00
{
return QString::fromStdString(m_walletImpl->getSeedLanguage());
2016-02-29 16:39:39 +02:00
}
2016-06-08 13:53:24 +03:00
void Wallet::setSeedLanguage(const QString &lang)
{
2016-06-08 13:53:24 +03:00
m_walletImpl->setSeedLanguage(lang.toStdString());
}
Wallet::Status Wallet::status() const
{
return static_cast<Status>(m_walletImpl->status());
}
2016-07-14 13:09:39 +03:00
bool Wallet::connected() const
{
return m_walletImpl->connected();
}
bool Wallet::synchronized() const
{
return m_walletImpl->synchronized();
}
QString Wallet::errorString() const
{
return QString::fromStdString(m_walletImpl->errorString());
}
2016-02-29 16:39:39 +02:00
bool Wallet::setPassword(const QString &password)
{
return m_walletImpl->setPassword(password.toStdString());
2016-02-23 17:59:26 +02:00
}
2016-02-29 16:39:39 +02:00
QString Wallet::address() const
2016-02-29 16:39:39 +02:00
{
return QString::fromStdString(m_walletImpl->address());
2016-02-29 16:39:39 +02:00
}
bool Wallet::store(const QString &path)
2016-02-29 16:39:39 +02:00
{
return m_walletImpl->store(path.toStdString());
2016-02-29 16:39:39 +02:00
}
2016-10-10 22:36:57 +03:00
bool Wallet::init(const QString &daemonAddress, quint64 upperTransactionLimit, bool isRecovering, quint64 restoreHeight)
2016-06-08 13:53:24 +03:00
{
return m_walletImpl->init(daemonAddress.toStdString(), upperTransactionLimit);
}
2016-10-10 22:36:57 +03:00
void Wallet::initAsync(const QString &daemonAddress, quint64 upperTransactionLimit, bool isRecovering, quint64 restoreHeight)
2016-07-14 13:09:39 +03:00
{
2016-10-10 22:36:57 +03:00
if (isRecovering){
qDebug() << "RESTORING";
m_walletImpl->setRecoveringFromSeed(true);
m_walletImpl->setRefreshFromBlockHeight(restoreHeight);
}
2016-07-14 13:09:39 +03:00
m_walletImpl->initAsync(daemonAddress.toStdString(), upperTransactionLimit);
}
2016-06-08 13:53:24 +03:00
bool Wallet::connectToDaemon()
{
return m_walletImpl->connectToDaemon();
}
void Wallet::setTrustedDaemon(bool arg)
{
m_walletImpl->setTrustedDaemon(arg);
}
quint64 Wallet::balance() const
{
return m_walletImpl->balance();
}
quint64 Wallet::unlockedBalance() const
{
return m_walletImpl->unlockedBalance();
}
quint64 Wallet::blockChainHeight() const
{
return m_walletImpl->blockChainHeight();
}
quint64 Wallet::daemonBlockChainHeight() const
{
// cache daemon blockchain height for some time (60 seconds by default)
if (m_daemonBlockChainHeight == 0
|| m_daemonBlockChainHeightTime.elapsed() / 1000 > m_daemonBlockChainHeightTtl) {
m_daemonBlockChainHeight = m_walletImpl->daemonBlockChainHeight();
m_daemonBlockChainHeightTime.restart();
}
return m_daemonBlockChainHeight;
}
quint64 Wallet::daemonBlockChainTargetHeight() const
{
2016-11-01 19:14:39 +02:00
if (m_daemonBlockChainTargetHeight == 0
|| m_daemonBlockChainTargetHeightTime.elapsed() / 1000 > m_daemonBlockChainTargetHeightTtl) {
m_daemonBlockChainTargetHeight = m_walletImpl->daemonBlockChainTargetHeight();
m_daemonBlockChainTargetHeightTime.restart();
}
return m_daemonBlockChainTargetHeight;
}
2016-06-08 13:53:24 +03:00
bool Wallet::refresh()
{
2016-06-17 16:35:07 +03:00
bool result = m_walletImpl->refresh();
2016-10-04 23:12:58 +03:00
m_history->refresh();
2016-06-17 16:35:07 +03:00
if (result)
emit updated();
return result;
2016-06-08 13:53:24 +03:00
}
2016-07-13 15:24:40 +03:00
void Wallet::refreshAsync()
{
m_walletImpl->refreshAsync();
}
void Wallet::setAutoRefreshInterval(int seconds)
{
m_walletImpl->setAutoRefreshInterval(seconds);
}
int Wallet::autoRefreshInterval() const
{
return m_walletImpl->autoRefreshInterval();
}
PendingTransaction *Wallet::createTransaction(const QString &dst_addr, const QString &payment_id,
2016-06-27 15:45:48 +03:00
quint64 amount, quint32 mixin_count,
PendingTransaction::Priority priority)
2016-06-08 13:53:24 +03:00
{
Bitmonero::PendingTransaction * ptImpl = m_walletImpl->createTransaction(
2016-06-27 15:45:48 +03:00
dst_addr.toStdString(), payment_id.toStdString(), amount, mixin_count,
static_cast<Bitmonero::PendingTransaction::Priority>(priority));
2016-06-08 13:53:24 +03:00
PendingTransaction * result = new PendingTransaction(ptImpl, this);
return result;
}
void Wallet::disposeTransaction(PendingTransaction *t)
{
m_walletImpl->disposeTransaction(t->m_pimpl);
delete t;
}
TransactionHistory *Wallet::history() const
2016-06-08 13:53:24 +03:00
{
return m_history;
}
2016-10-07 23:05:51 +03:00
TransactionHistorySortFilterModel *Wallet::historyModel() const
{
if (!m_historyModel) {
Wallet * w = const_cast<Wallet*>(this);
m_historyModel = new TransactionHistoryModel(w);
m_historyModel->setTransactionHistory(this->history());
2016-10-07 23:05:51 +03:00
m_historySortFilterModel = new TransactionHistorySortFilterModel(w);
m_historySortFilterModel->setSourceModel(m_historyModel);
}
2016-10-07 23:05:51 +03:00
return m_historySortFilterModel;
}
2016-02-29 16:39:39 +02:00
QString Wallet::generatePaymentId() const
{
return QString::fromStdString(Bitmonero::Wallet::genPaymentId());
}
QString Wallet::integratedAddress(const QString &paymentId) const
{
return QString::fromStdString(m_walletImpl->integratedAddress(paymentId.toStdString()));
}
QString Wallet::paymentId() const
{
return m_paymentId;
}
void Wallet::setPaymentId(const QString &paymentId)
{
m_paymentId = paymentId;
}
2016-02-29 16:39:39 +02:00
Wallet::Wallet(Bitmonero::Wallet *w, QObject *parent)
: QObject(parent)
, m_walletImpl(w)
, m_history(nullptr)
, m_historyModel(nullptr)
, m_daemonBlockChainHeight(0)
, m_daemonBlockChainHeightTtl(DAEMON_BLOCKCHAIN_HEIGHT_CACHE_TTL_SECONDS)
2016-11-01 19:14:39 +02:00
, m_daemonBlockChainTargetHeight(0)
, m_daemonBlockChainTargetHeightTtl(DAEMON_BLOCKCHAIN_TARGET_HEIGHT_CACHE_TTL_SECONDS)
2016-02-29 16:39:39 +02:00
{
2016-10-04 23:12:58 +03:00
m_history = new TransactionHistory(m_walletImpl->history(), this);
2016-07-14 13:09:39 +03:00
m_walletImpl->setListener(new WalletListenerImpl(this));
2016-02-29 16:39:39 +02:00
}
Wallet::~Wallet()
2016-02-29 16:39:39 +02:00
{
2016-10-30 19:09:28 +02:00
qDebug("~Wallet: Closing wallet");
Bitmonero::WalletManagerFactory::getWalletManager()->closeWallet(m_walletImpl);
2016-02-29 16:39:39 +02:00
}