monero-gui/src/libwalletqt/Wallet.h

181 lines
5.6 KiB
C
Raw Normal View History

2016-02-23 15:59:26 +00:00
#ifndef WALLET_H
#define WALLET_H
#include <QObject>
#include <QTime>
2016-02-23 15:59:26 +00:00
2016-06-27 12:45:48 +00:00
#include "wallet/wallet2_api.h" // we need to have an access to the Bitmonero::Wallet::Status enum here;
#include "PendingTransaction.h" // we need to have an access to the PendingTransaction::Priority enum here;
namespace Bitmonero {
class Wallet; // forward declaration
}
2016-06-08 10:53:24 +00:00
2016-06-27 12:45:48 +00:00
2016-06-08 10:53:24 +00:00
class TransactionHistory;
class TransactionHistoryModel;
2016-10-07 20:05:51 +00:00
class TransactionHistorySortFilterModel;
2016-06-08 10:53:24 +00:00
2016-02-23 15:59:26 +00:00
class Wallet : public QObject
{
Q_OBJECT
Q_PROPERTY(QString seed READ getSeed)
2016-06-08 10:53:24 +00:00
Q_PROPERTY(QString seedLanguage READ getSeedLanguage)
Q_PROPERTY(Status status READ status)
2016-07-14 10:09:39 +00:00
Q_PROPERTY(bool connected READ connected)
Q_PROPERTY(bool synchronized READ synchronized)
2016-06-08 10:53:24 +00:00
Q_PROPERTY(QString errorString READ errorString)
Q_PROPERTY(QString address READ address)
Q_PROPERTY(quint64 balance READ balance)
Q_PROPERTY(quint64 unlockedBalance READ unlockedBalance)
Q_PROPERTY(TransactionHistory * history READ history)
Q_PROPERTY(QString paymentId READ paymentId WRITE setPaymentId)
Q_PROPERTY(TransactionHistorySortFilterModel * historyModel READ historyModel NOTIFY historyModelChanged)
2016-06-08 10:53:24 +00:00
2016-02-23 15:59:26 +00:00
public:
enum Status {
2016-06-08 10:53:24 +00:00
Status_Ok = Bitmonero::Wallet::Status_Ok,
Status_Error = Bitmonero::Wallet::Status_Error
};
2016-06-08 10:53:24 +00:00
Q_ENUM(Status)
2016-02-29 14:39:39 +00:00
//! returns mnemonic seed
2016-06-08 10:53:24 +00:00
QString getSeed() const;
2016-02-29 14:39:39 +00:00
//! returns seed language
2016-06-08 10:53:24 +00:00
QString getSeedLanguage() const;
//! set seed language
Q_INVOKABLE void setSeedLanguage(const QString &lang);
//! returns last operation's status
2016-06-08 10:53:24 +00:00
Status status() const;
//! returns true if wallet connected
2016-07-14 10:09:39 +00:00
bool connected() const;
//! returns true if wallet was ever synchronized
bool synchronized() const;
//! returns last operation's error message
2016-06-08 10:53:24 +00:00
QString errorString() const;
2016-02-29 14:39:39 +00:00
//! changes the password using existing parameters (path, seed, seed lang)
Q_INVOKABLE bool setPassword(const QString &password);
//! returns wallet's public address
2016-06-08 10:53:24 +00:00
QString address() const;
//! saves wallet to the file by given path
Q_INVOKABLE bool store(const QString &path);
2016-02-29 14:39:39 +00:00
2016-06-08 10:53:24 +00:00
//! initializes wallet
2016-10-10 19:36:57 +00:00
Q_INVOKABLE bool init(const QString &daemonAddress, quint64 upperTransactionLimit, bool isRecovering = false, quint64 restoreHeight = 0);
2016-06-08 10:53:24 +00:00
2016-07-14 10:09:39 +00:00
//! initializes wallet asynchronously
2016-10-10 19:36:57 +00:00
Q_INVOKABLE void initAsync(const QString &daemonAddress, quint64 upperTransactionLimit, bool isRecovering = false, quint64 restoreHeight = 0);
2016-07-14 10:09:39 +00:00
2016-06-08 10:53:24 +00:00
//! connects to daemon
Q_INVOKABLE bool connectToDaemon();
//! indicates id daemon is trusted
Q_INVOKABLE void setTrustedDaemon(bool arg);
//! returns balance
Q_INVOKABLE quint64 balance() const;
2016-06-08 10:53:24 +00:00
//! returns unlocked balance
Q_INVOKABLE quint64 unlockedBalance() const;
//! returns current wallet's block height
//! (can be less than daemon's blockchain height when wallet sync in progress)
Q_INVOKABLE quint64 blockChainHeight() const;
//! returns daemon's blockchain height
Q_INVOKABLE quint64 daemonBlockChainHeight() const;
2016-06-08 10:53:24 +00:00
//! returns daemon's blockchain target height
Q_INVOKABLE quint64 daemonBlockChainTargetHeight() const;
2016-06-08 10:53:24 +00:00
//! refreshes the wallet
Q_INVOKABLE bool refresh();
2016-07-13 12:24:40 +00:00
//! refreshes the wallet asynchronously
Q_INVOKABLE void refreshAsync();
//! setup auto-refresh interval in seconds
Q_INVOKABLE void setAutoRefreshInterval(int seconds);
//! return auto-refresh interval in seconds
Q_INVOKABLE int autoRefreshInterval() const;
2016-06-08 10:53:24 +00:00
//! creates transaction
Q_INVOKABLE PendingTransaction * createTransaction(const QString &dst_addr, const QString &payment_id,
2016-06-27 12:45:48 +00:00
quint64 amount, quint32 mixin_count,
2016-06-28 19:37:14 +00:00
PendingTransaction::Priority priority);
2016-06-08 10:53:24 +00:00
//! deletes transaction and frees memory
Q_INVOKABLE void disposeTransaction(PendingTransaction * t);
//! returns transaction history
TransactionHistory * history() const;
//! returns transaction history model
2016-10-07 20:05:51 +00:00
TransactionHistorySortFilterModel *historyModel() const;
//! generate payment id
Q_INVOKABLE QString generatePaymentId() const;
//! integrated address
Q_INVOKABLE QString integratedAddress(const QString &paymentId) const;
//! saved payment id
QString paymentId() const;
void setPaymentId(const QString &paymentId);
2016-06-08 10:53:24 +00:00
// TODO: setListenter() when it implemented in API
2016-06-17 13:35:07 +00:00
signals:
// emitted on every event happened with wallet
// (money sent/received, new block)
2016-06-17 13:35:07 +00:00
void updated();
2016-07-13 12:24:40 +00:00
// emitted when refresh process finished (could take a long time)
// signalling only after we
void refreshed();
void moneySpent(const QString &txId, quint64 amount);
void moneyReceived(const QString &txId, quint64 amount);
void newBlock(quint64 height);
void historyModelChanged() const;
2016-02-29 14:39:39 +00:00
private:
Wallet(QObject * parent = nullptr);
Wallet(Bitmonero::Wallet *w, QObject * parent = 0);
~Wallet();
2016-02-29 14:39:39 +00:00
private:
friend class WalletManager;
2016-07-13 12:24:40 +00:00
friend class WalletListenerImpl;
//! libwallet's
Bitmonero::Wallet * m_walletImpl;
2016-06-08 10:53:24 +00:00
// history lifetime managed by wallet;
TransactionHistory * m_history;
// Used for UI history view
mutable TransactionHistoryModel * m_historyModel;
2016-10-07 20:05:51 +00:00
mutable TransactionHistorySortFilterModel * m_historySortFilterModel;
QString m_paymentId;
mutable QTime m_daemonBlockChainHeightTime;
mutable quint64 m_daemonBlockChainHeight;
int m_daemonBlockChainHeightTtl;
mutable quint64 m_daemonBlockChainTargetHeight;
2016-02-23 15:59:26 +00:00
};
#endif // WALLET_H