mirror of
https://github.com/dashpay/dash.git
synced 2024-12-30 22:35:51 +01:00
315e92d645
48439b3c10391e5f5555c7d98e1a99706b77eaf7 Don't link SSL_LIBS with GUI unless BIP70 is enabled (James Hilliard) fbb643d2a55ade3c06593a7490601acd2e36dce8 Add BIP70 deprecation warning (James Hilliard) 38b98507cdda02ff02a524d41bcc3427ca9e4fd9 qt: cleanup: Move BIP70 functions together in paymentserver (Wladimir J. van der Laan) 9dcf6c0dfec51f2a49edef537f377422d6dbdceb build: Add --disable-bip70 configure option (Wladimir J. van der Laan) Pull request description: This is based off of #11622 and adds a deprecation warning when a BIP70 URL is used. Rational: - BIP70 increases attack surface in multiple ways and is difficult for third party wallets to implement in a secure manner - Very few merchants use the standard BIP70 variant supported by Bitcoin Core - The one major payment processor that doesn't support BIP21 and currently uses a customized non-standard version of BIP70 has indicated that "Unfortunately the original BIP70 is not useful for us." Tree-SHA512: 1e16ee8d2cdac9499f751ee7b50d058278150f9e38a87a47ddb5105dd0353cdedabe462903f54ead6209b249b249fe5e6a10d29631531be27400f2f69c25b9b9
229 lines
9.1 KiB
C++
229 lines
9.1 KiB
C++
// Copyright (c) 2011-2015 The Bitcoin Core developers
|
|
// Copyright (c) 2014-2021 The Dash Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#if defined(HAVE_CONFIG_H)
|
|
#include <config/dash-config.h>
|
|
#endif
|
|
|
|
#include <qt/utilitydialog.h>
|
|
|
|
#include <qt/forms/ui_helpmessagedialog.h>
|
|
|
|
#include <qt/bitcoingui.h>
|
|
#include <qt/clientmodel.h>
|
|
#include <qt/guiconstants.h>
|
|
#include <qt/guiutil.h>
|
|
#include <qt/intro.h>
|
|
#ifdef ENABLE_BIP70
|
|
#include <qt/paymentrequestplus.h>
|
|
#endif
|
|
|
|
#include <clientversion.h>
|
|
#include <init.h>
|
|
#include <interfaces/node.h>
|
|
#include <util/system.h>
|
|
#include <util/strencodings.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <QCloseEvent>
|
|
#include <QLabel>
|
|
#include <QRegExp>
|
|
#include <QTextTable>
|
|
#include <QTextCursor>
|
|
#include <QVBoxLayout>
|
|
|
|
/** "Help message" or "About" dialog box */
|
|
HelpMessageDialog::HelpMessageDialog(interfaces::Node& node, QWidget *parent, HelpMode helpMode) :
|
|
QDialog(parent),
|
|
ui(new Ui::HelpMessageDialog)
|
|
{
|
|
ui->setupUi(this);
|
|
|
|
GUIUtil::updateFonts();
|
|
|
|
QString version = tr(PACKAGE_NAME) + " " + tr("version") + " " + QString::fromStdString(FormatFullVersion());
|
|
/* On x86 add a bit specifier to the version so that users can distinguish between
|
|
* 32 and 64 bit builds. On other architectures, 32/64 bit may be more ambiguous.
|
|
*/
|
|
#if defined(__x86_64__)
|
|
version += " " + tr("(%1-bit)").arg(64);
|
|
#elif defined(__i386__ )
|
|
version += " " + tr("(%1-bit)").arg(32);
|
|
#endif
|
|
|
|
if (helpMode == about)
|
|
{
|
|
setWindowTitle(tr("About %1").arg(tr(PACKAGE_NAME)));
|
|
|
|
std::string licenseInfo = LicenseInfo();
|
|
/// HTML-format the license message from the core
|
|
QString licenseInfoHTML = QString::fromStdString(licenseInfo);
|
|
|
|
// Make URLs clickable
|
|
QRegExp uri("<(.*)>", Qt::CaseSensitive, QRegExp::RegExp2);
|
|
uri.setMinimal(true); // use non-greedy matching
|
|
licenseInfoHTML.replace(uri, QString("<a style=\"%1\"href=\"\\1\">\\1</a>").arg(GUIUtil::getThemedStyleQString(GUIUtil::ThemedStyle::TS_COMMAND)));
|
|
// Replace newlines with HTML breaks
|
|
licenseInfoHTML.replace("\n", "<br>");
|
|
|
|
ui->aboutMessage->setTextFormat(Qt::RichText);
|
|
ui->scrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
|
|
text = version + "\n" + QString::fromStdString(FormatParagraph(licenseInfo));
|
|
ui->aboutMessage->setText(version + "<br><br>" + licenseInfoHTML);
|
|
ui->aboutMessage->setWordWrap(true);
|
|
ui->helpMessage->setVisible(false);
|
|
} else if (helpMode == cmdline) {
|
|
setWindowTitle(tr("Command-line options"));
|
|
QString header = "Usage: dash-qt [command-line options] \n";
|
|
QTextCursor cursor(ui->helpMessage->document());
|
|
cursor.insertText(version);
|
|
cursor.insertBlock();
|
|
cursor.insertText(header);
|
|
cursor.insertBlock();
|
|
|
|
std::string strUsage = gArgs.GetHelpMessage();
|
|
QString coreOptions = QString::fromStdString(strUsage);
|
|
text = version + "\n\n" + header + "\n" + coreOptions;
|
|
|
|
QTextTableFormat tf;
|
|
tf.setBorderStyle(QTextFrameFormat::BorderStyle_None);
|
|
tf.setCellPadding(2);
|
|
QVector<QTextLength> widths;
|
|
widths << QTextLength(QTextLength::PercentageLength, 35);
|
|
widths << QTextLength(QTextLength::PercentageLength, 65);
|
|
tf.setColumnWidthConstraints(widths);
|
|
|
|
QTextCharFormat bold;
|
|
bold.setFontWeight(QFont::Bold);
|
|
|
|
for (const QString &line : coreOptions.split("\n")) {
|
|
if (line.startsWith(" -"))
|
|
{
|
|
cursor.currentTable()->appendRows(1);
|
|
cursor.movePosition(QTextCursor::PreviousCell);
|
|
cursor.movePosition(QTextCursor::NextRow);
|
|
cursor.insertText(line.trimmed());
|
|
cursor.movePosition(QTextCursor::NextCell);
|
|
} else if (line.startsWith(" ")) {
|
|
cursor.insertText(line.trimmed()+' ');
|
|
} else if (line.size() > 0) {
|
|
//Title of a group
|
|
if (cursor.currentTable())
|
|
cursor.currentTable()->appendRows(1);
|
|
cursor.movePosition(QTextCursor::Down);
|
|
cursor.insertText(line.trimmed(), bold);
|
|
cursor.insertTable(1, 2, tf);
|
|
}
|
|
}
|
|
|
|
ui->helpMessage->moveCursor(QTextCursor::Start);
|
|
ui->scrollArea->setVisible(false);
|
|
} else if (helpMode == pshelp) {
|
|
QString strCoinJoinName = QString::fromStdString(gCoinJoinName);
|
|
setWindowTitle(tr("%1 information").arg(strCoinJoinName));
|
|
|
|
ui->aboutMessage->setTextFormat(Qt::RichText);
|
|
ui->scrollArea->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
|
|
ui->aboutMessage->setText(tr("\
|
|
<h3>%1 Basics</h3> \
|
|
%1 gives you true financial privacy by obscuring the origins of your funds. \
|
|
All the Dash in your wallet is comprised of different \"inputs\" which you can think of as separate, discrete coins.<br> \
|
|
%1 uses an innovative process to mix your inputs with the inputs of two or more other people, without having your coins ever leave your wallet. \
|
|
You retain control of your money at all times.<hr> \
|
|
<b>The %1 process works like this:</b>\
|
|
<ol type=\"1\"> \
|
|
<li>%1 begins by breaking your transaction inputs down into standard denominations. \
|
|
These denominations are 0.001 DASH, 0.01 DASH, 0.1 DASH, 1 DASH and 10 DASH -- sort of like the paper money you use every day.</li> \
|
|
<li>Your wallet then sends requests to specially configured software nodes on the network, called \"masternodes.\" \
|
|
These masternodes are informed then that you are interested in mixing a certain denomination. \
|
|
No identifiable information is sent to the masternodes, so they never know \"who\" you are.</li> \
|
|
<li>When two or more other people send similar messages, indicating that they wish to mix the same denomination, a mixing session begins. \
|
|
The masternode mixes up the inputs and instructs all three users' wallets to pay the now-transformed input back to themselves. \
|
|
Your wallet pays that denomination directly to itself, but in a different address (called a change address).</li> \
|
|
<li>In order to fully obscure your funds, your wallet must repeat this process a number of times with each denomination. \
|
|
Each time the process is completed, it's called a \"round.\" Each round of %1 makes it exponentially more difficult to determine where your funds originated.</li> \
|
|
<li>This mixing process happens in the background without any intervention on your part. When you wish to make a transaction, \
|
|
your funds will already be mixed. No additional waiting is required.</li> \
|
|
</ol> <hr>\
|
|
<b>IMPORTANT:</b> Your wallet only contains 1000 of these \"change addresses.\" Every time a mixing event happens, up to 9 of your addresses are used up. \
|
|
This means those 1000 addresses last for about 100 mixing events. When 900 of them are used, your wallet must create more addresses. \
|
|
It can only do this, however, if you have automatic backups enabled.<br> \
|
|
Consequently, users who have backups disabled will also have %1 disabled. <hr>\
|
|
For more information, see the <a style=\"%2\" href=\"%3\">%1 documentation</a>."
|
|
)
|
|
.arg(strCoinJoinName)
|
|
.arg(GUIUtil::getThemedStyleQString(GUIUtil::ThemedStyle::TS_COMMAND))
|
|
.arg("https://docs.dash.org/en/stable/wallets/dashcore/coinjoin-instantsend.html")
|
|
);
|
|
ui->aboutMessage->setWordWrap(true);
|
|
ui->helpMessage->setVisible(false);
|
|
}
|
|
}
|
|
|
|
HelpMessageDialog::~HelpMessageDialog()
|
|
{
|
|
delete ui;
|
|
}
|
|
|
|
void HelpMessageDialog::printToConsole()
|
|
{
|
|
// On other operating systems, the expected action is to print the message to the console.
|
|
fprintf(stdout, "%s\n", qPrintable(text));
|
|
}
|
|
|
|
void HelpMessageDialog::showOrPrint()
|
|
{
|
|
#if defined(WIN32)
|
|
// On Windows, show a message box, as there is no stderr/stdout in windowed applications
|
|
exec();
|
|
#else
|
|
// On other operating systems, print help text to console
|
|
printToConsole();
|
|
#endif
|
|
}
|
|
|
|
void HelpMessageDialog::on_okButton_accepted()
|
|
{
|
|
close();
|
|
}
|
|
|
|
|
|
/** "Shutdown" window */
|
|
ShutdownWindow::ShutdownWindow(interfaces::Node& node, QWidget *parent, Qt::WindowFlags f):
|
|
QWidget(parent, f)
|
|
{
|
|
setObjectName("ShutdownWindow");
|
|
|
|
QVBoxLayout *layout = new QVBoxLayout();
|
|
layout->addWidget(new QLabel(
|
|
tr("%1 is shutting down...").arg(tr(PACKAGE_NAME)) + "<br /><br />" +
|
|
tr("Do not shut down the computer until this window disappears.")));
|
|
setLayout(layout);
|
|
|
|
GUIUtil::updateFonts();
|
|
}
|
|
|
|
QWidget *ShutdownWindow::showShutdownWindow(interfaces::Node& node, BitcoinGUI *window)
|
|
{
|
|
if (!window)
|
|
return nullptr;
|
|
|
|
// Show a simple window indicating shutdown status
|
|
QWidget *shutdownWindow = new ShutdownWindow(node);
|
|
shutdownWindow->setWindowTitle(window->windowTitle());
|
|
|
|
// Center shutdown window at where main window was
|
|
const QPoint global = window->mapToGlobal(window->rect().center());
|
|
shutdownWindow->move(global.x() - shutdownWindow->width() / 2, global.y() - shutdownWindow->height() / 2);
|
|
shutdownWindow->show();
|
|
return shutdownWindow;
|
|
}
|
|
|
|
void ShutdownWindow::closeEvent(QCloseEvent *event)
|
|
{
|
|
event->ignore();
|
|
}
|