neobytes/src/qt/clientmodel.cpp

157 lines
3.6 KiB
C++
Raw Normal View History

#include "clientmodel.h"
#include "main.h"
2011-05-28 20:32:19 +02:00
#include "guiconstants.h"
#include "optionsmodel.h"
#include "addresstablemodel.h"
2011-06-05 16:03:29 +02:00
#include "transactiontablemodel.h"
#include <QTimer>
ClientModel::ClientModel(QObject *parent) :
2011-06-05 16:03:29 +02:00
QObject(parent), optionsModel(0), addressTableModel(0),
transactionTableModel(0)
{
2011-06-05 11:04:14 +02:00
/* Until signal notifications is built into the bitcoin core,
simply update everything after polling using a timer.
*/
QTimer *timer = new QTimer(this);
connect(timer, SIGNAL(timeout()), this, SLOT(update()));
timer->start(MODEL_UPDATE_DELAY);
optionsModel = new OptionsModel(this);
addressTableModel = new AddressTableModel(this);
2011-06-05 16:03:29 +02:00
transactionTableModel = new TransactionTableModel(this);
}
qint64 ClientModel::getBalance()
{
return GetBalance();
}
QString ClientModel::getAddress()
{
std::vector<unsigned char> vchPubKey;
if (CWalletDB("r").ReadDefaultKey(vchPubKey))
{
return QString::fromStdString(PubKeyToAddress(vchPubKey));
2011-06-07 18:59:01 +02:00
}
else
{
return QString();
}
}
int ClientModel::getNumConnections()
{
return vNodes.size();
}
int ClientModel::getNumBlocks()
{
return nBestHeight;
}
int ClientModel::getNumTransactions()
{
int numTransactions = 0;
CRITICAL_BLOCK(cs_mapWallet)
{
numTransactions = mapWallet.size();
}
return numTransactions;
}
void ClientModel::update()
{
2011-06-05 11:04:14 +02:00
/* Plainly emit all signals for now. To be precise this should check
wether the values actually changed first.
*/
emit balanceChanged(getBalance());
emit addressChanged(getAddress());
emit numConnectionsChanged(getNumConnections());
emit numBlocksChanged(getNumBlocks());
emit numTransactionsChanged(getNumTransactions());
}
2011-05-30 20:20:12 +02:00
2011-06-03 20:48:03 +02:00
void ClientModel::setAddress(const QString &defaultAddress)
{
uint160 hash160;
std::string strAddress = defaultAddress.toStdString();
if (!AddressToHash160(strAddress, hash160))
return;
if (!mapPubKeys.count(hash160))
return;
CWalletDB().WriteDefaultKey(mapPubKeys[hash160]);
}
2011-05-30 20:20:12 +02:00
ClientModel::StatusCode ClientModel::sendCoins(const QString &payTo, qint64 payAmount)
{
uint160 hash160 = 0;
bool valid = false;
if(!AddressToHash160(payTo.toUtf8().constData(), hash160))
{
return InvalidAddress;
}
if(payAmount <= 0)
{
return InvalidAmount;
}
if(payAmount > getBalance())
{
return AmountExceedsBalance;
}
if((payAmount + nTransactionFee) > getBalance())
{
return AmountWithFeeExceedsBalance;
}
CRITICAL_BLOCK(cs_main)
{
// Send to bitcoin address
CWalletTx wtx;
CScript scriptPubKey;
scriptPubKey << OP_DUP << OP_HASH160 << hash160 << OP_EQUALVERIFY << OP_CHECKSIG;
std::string strError = SendMoney(scriptPubKey, payAmount, wtx, true);
if (strError == "")
2011-06-07 18:59:01 +02:00
{
2011-05-30 20:20:12 +02:00
return OK;
2011-06-07 18:59:01 +02:00
}
2011-05-30 20:20:12 +02:00
else if (strError == "ABORTED")
2011-06-07 18:59:01 +02:00
{
2011-05-30 20:20:12 +02:00
return Aborted;
2011-06-07 18:59:01 +02:00
}
2011-05-30 20:20:12 +02:00
else
{
emit error(tr("Sending..."), QString::fromStdString(strError));
return MiscError;
}
}
// Add addresses that we've sent to to the address book
std::string strAddress = payTo.toStdString();
CRITICAL_BLOCK(cs_mapAddressBook)
if (!mapAddressBook.count(strAddress))
SetAddressBookName(strAddress, "");
2011-05-30 20:20:12 +02:00
return OK;
}
OptionsModel *ClientModel::getOptionsModel()
{
return optionsModel;
}
AddressTableModel *ClientModel::getAddressTableModel()
{
return addressTableModel;
}
2011-06-05 16:03:29 +02:00
TransactionTableModel *ClientModel::getTransactionTableModel()
{
return transactionTableModel;
}