Browse Source

update// created request objects to store inportant information

pull/115/head
Strider 4 years ago
parent
commit
5ad5d07c1c
  1. 1
      silentdragon-lite.pro
  2. 67
      src/Model/ContactRequest.cpp
  3. 33
      src/Model/ContactRequest.h
  4. 158
      src/chatmodel.cpp
  5. 1
      src/chatmodel.h

1
silentdragon-lite.pro

@ -79,6 +79,7 @@ SOURCES += \
src/Model/ChatItem.cpp \
src/Model/ContactRequestChatItem.cpp \
src/Model/ContactItem.cpp \
src/Model/ContactRequest.cpp \
src/Chat/Helper/ChatIDGenerator.cpp \
src/Chat/Chat.cpp \
src/FileSystem/FileSystem.cpp \

67
src/Model/ContactRequest.cpp

@ -0,0 +1,67 @@
// Copyright 2019-2020 The Hush developers
// GPLv3
#include "ContactRequest.h"
ContactRequest::ContactRequest() {}
ContactRequest::ContactRequest(QString sender, QString receiver, QString memo, QString cid)
{
_senderAddress = sender;
_receiverAddress = receiver;
_memo = memo;
_cid = cid;
}
QString ContactRequest::getSenderAddress()
{
return _senderAddress;
}
QString ContactRequest::getReceiverAddress()
{
return _receiverAddress;
}
QString ContactRequest::getMemo()
{
return _memo;
}
QString ContactRequest::getCid()
{
return _cid;
}
void ContactRequest::setSenderAddress(QString address)
{
_senderAddress = address;
}
void ContactRequest::setReceiverAddress(QString address)
{
_receiverAddress = address;
}
void ContactRequest::setMemo(QString memo)
{
_memo = memo;
}
void ContactRequest::setCid(QString cid)
{
_cid = cid;
}
QString ContactRequest::toString()
{
return "sender: " + _senderAddress + " receiver: " + _receiverAddress + " memo: " + _memo + " cid: " + _cid;
}
ContactRequest::~ContactRequest()
{
_senderAddress = "";
_receiverAddress = "";
_memo = "";
_cid = "";
}

33
src/Model/ContactRequest.h

@ -0,0 +1,33 @@
// Copyright 2019-2020 The Hush developers
// GPLv3
#ifndef CONTACTREQUEST_H
#define CONTACTREQUEST_H
#include <QString>
using json = nlohmann::json;
class ContactRequest
{
private:
QString _senderAddress;
QString _receiverAddress;
QString _memo;
QString _cid;
public:
ContactRequest();
ContactRequest(QString sender, QString receiver, QString memo, QString cid);
QString getSenderAddress();
QString getReceiverAddress();
QString getMemo();
QString getCid();
void setSenderAddress(QString address);
void setReceiverAddress(QString contact);
void setMemo(QString memo);
void setCid(QString cid);
QString toString();
~ContactRequest();
};
#endif

158
src/chatmodel.cpp

@ -16,6 +16,8 @@
using namespace std;
ContactRequest contactRequest = ContactRequest();
ChatModel::ChatModel(std::map<QString, ChatItem> chatItems)
{
this->chatItems = chatItems;
@ -455,45 +457,38 @@ QString MainWindow::doSendChatTxValidations(Tx tx) {
return "";
}
void::MainWindow::addContact() {
void::MainWindow::addContact()
{
Ui_Dialog request;
QDialog dialog(this);
request.setupUi(&dialog);
Settings::saveRestore(&dialog);
bool sapling = true;
rpc->createNewZaddr(sapling, [=] (json reply) {
QString myAddr = QString::fromStdString(reply.get<json::array_t>()[0]);
request.myzaddr->setText(myAddr);
ui->listReceiveAddresses->insertItem(0, myAddr);
ui->listReceiveAddresses->setCurrentIndex(0);
qDebug() << "new generated myAddr" << myAddr;
});
QString cid = QUuid::createUuid().toString(QUuid::WithoutBraces);
request.cid->setText(cid);
QObject::connect(request.sendRequestButton, &QPushButton::clicked, [&] () {
QString cid = request.cid->text();
auto addr = request.zaddr->text().trimmed();
QString getrequest = addr;
QString newLabel = request.labelRequest->text().trimmed();
auto myAddr = request.myzaddr->text().trimmed();
// ChatModel->addSendRequest(myAddr, cid, addr);
QString avatar = QString(":/icons/res/") + request.comboBoxAvatar->currentText() + QString(".png");
bool sapling = true;
rpc->createNewZaddr(sapling, [=] (json reply) {
QString myAddr = QString::fromStdString(reply.get<json::array_t>()[0]);
request.myzaddr->setText(myAddr);
ui->listReceiveAddresses->insertItem(0, myAddr);
ui->listReceiveAddresses->setCurrentIndex(0);
qDebug() << "new generated myAddr" << myAddr;
});
if (addr.isEmpty() || newLabel.isEmpty())
QString cid = QUuid::createUuid().toString(QUuid::WithoutBraces);
request.cid->setText(cid);
QObject::connect(request.sendRequestButton, &QPushButton::clicked, [&] () {
QString cid = request.cid->text();
QString addr = request.zaddr->text().trimmed();
QString getrequest = addr;
QString newLabel = request.labelRequest->text().trimmed();
QString myAddr = request.myzaddr->text().trimmed();
contactRequest.setSenderAddress(myAddr);
contactRequest.setReceiverAddress(addr);
contactRequest.setMemo(newLabel);
contactRequest.setCid(cid);
QString avatar = QString(":/icons/res/") + request.comboBoxAvatar->currentText() + QString(".png");
if (addr.isEmpty() || newLabel.isEmpty())
{
QMessageBox::critical(
QMessageBox::critical(
this,
QObject::tr("Address or Label Error"),
QObject::tr("Address or Label cannot be empty"),
@ -505,7 +500,7 @@ void::MainWindow::addContact() {
// Test if address is valid.
if (!Settings::isValidAddress(addr))
{
QMessageBox::critical(
QMessageBox::critical(
this,
QObject::tr("Address Format Error"),
QObject::tr("%1 doesn't seem to be a valid hush address.").arg(addr),
@ -517,80 +512,53 @@ void::MainWindow::addContact() {
///////Todo: Test if label allready exist!
////// Success, so show it
AddressBook::getInstance()->addAddressLabel(newLabel, addr, myAddr, cid, avatar);
QMessageBox::information(
this,
QObject::tr("Added Contact"),
QObject::tr("successfully added your new contact").arg(newLabel),
QMessageBox::Ok
);
return;
});
// QObject::connect(request.sendRequestButton, &QPushButton::clicked, this, &MainWindow::ContactRequest);
dialog.exec();
rpc->refreshContacts(
ui->listContactWidget
AddressBook::getInstance()->addAddressLabel(newLabel, addr, myAddr, cid, avatar);
QMessageBox::information(
this,
QObject::tr("Added Contact"),
QObject::tr("successfully added your new contact").arg(newLabel),
QMessageBox::Ok
);
return;
});
dialog.exec();
rpc->refreshContacts(ui->listContactWidget);
}
// Create a Tx for a contact Request
Tx MainWindow::createTxForSafeContactRequest() {
Tx tx;
Tx MainWindow::createTxForSafeContactRequest()
{
{
CAmount totalAmt;
QString amtStr = "0";
CAmount amt;
amt = CAmount::fromDecimalString("0");
totalAmt = totalAmt + amt;
for(auto &c : AddressBook::getInstance()->getAllAddressLabels())
if (ui->contactNameMemo->text().trimmed() == c.getName()) {
Tx tx;
CAmount totalAmt;
QString amtStr = "0";
CAmount amt;
amt = CAmount::fromDecimalString("0");
totalAmt = totalAmt + amt;
for(auto &c : AddressBook::getInstance()->getAllAddressLabels())
{
if (ui->contactNameMemo->text().trimmed() == c.getName())
{
QString cid = c.getCid();
QString myAddr = c.getMyAddress();
QString type = "Cont";
QString addr = c.getPartnerAddress();
QString hmemo= createHeaderMemo(type,cid,myAddr);
QString memo = ui->memoTxtChat->toPlainText().trimmed();
// ui->memoSizeChat->setLenDisplayLabel();// Todo -> activate lendisplay for chat
qDebug() << contactRequest.toString();
QString hmemo= createHeaderMemo(type,cid,myAddr);
QString memo = ui->memoTxtChat->toPlainText().trimmed();
// ui->memoSizeChat->setLenDisplayLabel();// Todo -> activate lendisplay for chat
tx.toAddrs.push_back(ToFields{addr, amt, hmemo});
tx.toAddrs.push_back(ToFields{addr, amt, memo});
qDebug() << "pushback chattx";
tx.fee = Settings::getMinerFee();
tx.toAddrs.push_back(ToFields{addr, amt, hmemo});
tx.toAddrs.push_back(ToFields{addr, amt, memo});
qDebug() << "pushback chattx";
tx.fee = Settings::getMinerFee();
}
}
return tx;
qDebug() << "RequestTx created";
}
}
return tx;
qDebug() << "RequestTx created";
}
void MainWindow::ContactRequest() {

1
src/chatmodel.h

@ -16,6 +16,7 @@
#include "settings.h"
#include "camount.h"
#include "Model/ChatItem.h"
#include "Model/ContactRequest.h"
#include "Chat/Helper/ChatDelegator.h"
#include "Chat/Helper/ChatIDGenerator.h"

Loading…
Cancel
Save