Show warning on corrupted keys

This commit is contained in:
tobtoht 2022-03-12 13:53:46 +01:00
parent 3e2de76f7d
commit 28c1973405
No known key found for this signature in database
GPG key ID: 1CADD27F41F45C3C
8 changed files with 37 additions and 8 deletions

View file

@ -377,6 +377,7 @@ void MainWindow::initWalletContext() {
connect(m_ctx.get(), &AppContext::initiateTransaction, this, &MainWindow::onInitiateTransaction); connect(m_ctx.get(), &AppContext::initiateTransaction, this, &MainWindow::onInitiateTransaction);
connect(m_ctx.get(), &AppContext::endTransaction, this, &MainWindow::onEndTransaction); connect(m_ctx.get(), &AppContext::endTransaction, this, &MainWindow::onEndTransaction);
connect(m_ctx.get(), &AppContext::customRestoreHeightSet, this, &MainWindow::onCustomRestoreHeightSet); connect(m_ctx.get(), &AppContext::customRestoreHeightSet, this, &MainWindow::onCustomRestoreHeightSet);
connect(m_ctx.get(), &AppContext::keysCorrupted, this, &MainWindow::onKeysCorrupted);
// Nodes // Nodes
connect(m_ctx->nodes, &Nodes::updateStatus, this, &MainWindow::onSetStatusText); connect(m_ctx->nodes, &Nodes::updateStatus, this, &MainWindow::onSetStatusText);
@ -1439,6 +1440,14 @@ void MainWindow::onCustomRestoreHeightSet(int height) {
this->menuQuitClicked(); this->menuQuitClicked();
} }
void MainWindow::onKeysCorrupted() {
if (!m_criticalWarningShown) {
m_criticalWarningShown = true;
QMessageBox::warning(this, "Critical error", "WARNING!\n\nThe wallet keys are corrupted.\n\nTo prevent LOSS OF FUNDS do NOT continue to use this wallet file.\n\nRestore your wallet from seed.\n\nPlease report this incident to the Feather developers.\n\nWARNING!");
m_sendWidget->disableSendButton();
}
}
void MainWindow::onExportHistoryCSV(bool checked) { void MainWindow::onExportHistoryCSV(bool checked) {
if (m_ctx->wallet == nullptr) if (m_ctx->wallet == nullptr)
return; return;

View file

@ -139,6 +139,7 @@ private slots:
void onInitiateTransaction(); void onInitiateTransaction();
void onEndTransaction(); void onEndTransaction();
void onCustomRestoreHeightSet(int height); void onCustomRestoreHeightSet(int height);
void onKeysCorrupted();
// libwalletqt // libwalletqt
void onBalanceUpdated(quint64 balance, quint64 spendable); void onBalanceUpdated(quint64 balance, quint64 spendable);
@ -274,6 +275,7 @@ private:
QTimer m_txTimer; QTimer m_txTimer;
bool cleanedUp = false; bool cleanedUp = false;
bool m_criticalWarningShown = false;
EventFilter *m_eventFilter = nullptr; EventFilter *m_eventFilter = nullptr;
qint64 m_userLastActive = QDateTime::currentSecsSinceEpoch(); qint64 m_userLastActive = QDateTime::currentSecsSinceEpoch();

View file

@ -305,7 +305,14 @@ void SendWidget::onInitiateTransaction() {
} }
void SendWidget::onEndTransaction() { void SendWidget::onEndTransaction() {
ui->btnSend->setEnabled(true); if (!m_sendDisabled) {
ui->btnSend->setEnabled(true);
}
}
void SendWidget::disableSendButton() {
m_sendDisabled = true;
ui->btnSend->setEnabled(false);
} }
void SendWidget::onDataPasted(const QString &data) { void SendWidget::onDataPasted(const QString &data) {

View file

@ -40,6 +40,7 @@ public slots:
void onOpenAliasResolveError(const QString &err); void onOpenAliasResolveError(const QString &err);
void onOpenAliasResolved(const QString &openAlias, const QString &address, bool dnssecValid); void onOpenAliasResolved(const QString &openAlias, const QString &address, bool dnssecValid);
void onPreferredFiatCurrencyChanged(); void onPreferredFiatCurrencyChanged();
void disableSendButton();
void onInitiateTransaction(); void onInitiateTransaction();
void onEndTransaction(); void onEndTransaction();
@ -51,10 +52,12 @@ private:
void setupComboBox(); void setupComboBox();
double amountDouble(); double amountDouble();
QScopedPointer<Ui::SendWidget> ui;
QSharedPointer<AppContext> m_ctx;
quint64 amount(); quint64 amount();
double conversionAmount(); double conversionAmount();
QScopedPointer<Ui::SendWidget> ui;
QSharedPointer<AppContext> m_ctx;
bool m_sendDisabled = false;
}; };
#endif // FEATHER_SENDWIDGET_H #endif // FEATHER_SENDWIDGET_H

View file

@ -345,7 +345,13 @@ void AppContext::syncStatusUpdated(quint64 height, quint64 target) {
void AppContext::refreshModels() { void AppContext::refreshModels() {
this->wallet->history()->refresh(this->wallet->currentSubaddressAccount()); this->wallet->history()->refresh(this->wallet->currentSubaddressAccount());
this->wallet->subaddress()->refresh(this->wallet->currentSubaddressAccount());
this->wallet->coins()->refresh(this->wallet->currentSubaddressAccount()); this->wallet->coins()->refresh(this->wallet->currentSubaddressAccount());
// Todo: set timer for refreshes bool r = this->wallet->subaddress()->refresh(this->wallet->currentSubaddressAccount());
if (!r) {
// This should only happen if wallet keys got corrupted or were tampered with
// The list of subaddresses is wiped to prevent loss of funds
// Notify MainWindow to display an error message
emit keysCorrupted();
}
} }

View file

@ -92,6 +92,7 @@ signals:
void deviceButtonRequest(quint64 code); void deviceButtonRequest(quint64 code);
void deviceButtonPressed(); void deviceButtonPressed();
void deviceError(const QString &message); void deviceError(const QString &message);
void keysCorrupted();
private: private:
DaemonRpc *m_rpc; DaemonRpc *m_rpc;

View file

@ -73,10 +73,11 @@ bool Subaddress::setLabel(quint32 accountIndex, quint32 addressIndex, const QStr
return r; return r;
} }
void Subaddress::refresh(quint32 accountIndex) const bool Subaddress::refresh(quint32 accountIndex) const
{ {
m_subaddressImpl->refresh(accountIndex); bool r = m_subaddressImpl->refresh(accountIndex);
getAll(); getAll();
return r;
} }
quint64 Subaddress::unusedLookahead() const quint64 Subaddress::unusedLookahead() const

View file

@ -20,7 +20,7 @@ public:
bool getRow(int index, std::function<void (Monero::SubaddressRow &row)> callback) const; bool getRow(int index, std::function<void (Monero::SubaddressRow &row)> callback) const;
bool addRow(quint32 accountIndex, const QString &label) const; bool addRow(quint32 accountIndex, const QString &label) const;
bool setLabel(quint32 accountIndex, quint32 addressIndex, const QString &label) const; bool setLabel(quint32 accountIndex, quint32 addressIndex, const QString &label) const;
void refresh(quint32 accountIndex) const; bool refresh(quint32 accountIndex) const;
quint64 unusedLookahead() const; quint64 unusedLookahead() const;
quint64 count() const; quint64 count() const;
QString errorString() const; QString errorString() const;