[Qt] add messages when handling local payment request files
- important for the open URI dialog to give users feedback when a file is invalid etc.
This commit is contained in:
parent
fb96e28b29
commit
bd70562f66
2 changed files with 37 additions and 17 deletions
|
@ -373,40 +373,52 @@ void PaymentServer::handleURIOrFile(const QString& s)
|
|||
#else
|
||||
QUrlQuery uri((QUrl(s)));
|
||||
#endif
|
||||
if (uri.hasQueryItem("r"))
|
||||
if (uri.hasQueryItem("r")) // payment request URI
|
||||
{
|
||||
QByteArray temp;
|
||||
temp.append(uri.queryItemValue("r"));
|
||||
QString decoded = QUrl::fromPercentEncoding(temp);
|
||||
QUrl fetchUrl(decoded, QUrl::StrictMode);
|
||||
|
||||
qDebug() << "PaymentServer::handleURIOrFile : fetchRequest(" << fetchUrl << ")";
|
||||
|
||||
if (fetchUrl.isValid())
|
||||
{
|
||||
qDebug() << "PaymentServer::handleURIOrFile : fetchRequest(" << fetchUrl << ")";
|
||||
fetchRequest(fetchUrl);
|
||||
}
|
||||
else
|
||||
{
|
||||
qDebug() << "PaymentServer::handleURIOrFile : Invalid URL: " << fetchUrl;
|
||||
emit message(tr("URI handling"),
|
||||
tr("Payment request fetch URL is invalid: %1").arg(fetchUrl.toString()),
|
||||
CClientUIInterface::ICON_WARNING);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
else // normal URI
|
||||
{
|
||||
SendCoinsRecipient recipient;
|
||||
if (GUIUtil::parseBitcoinURI(s, &recipient))
|
||||
emit receivedPaymentRequest(recipient);
|
||||
else
|
||||
emit message(tr("URI handling"),
|
||||
tr("URI can not be parsed! This can be caused by an invalid Bitcoin address or malformed URI parameters."),
|
||||
CClientUIInterface::ICON_WARNING);
|
||||
|
||||
SendCoinsRecipient recipient;
|
||||
if (GUIUtil::parseBitcoinURI(s, &recipient))
|
||||
emit receivedPaymentRequest(recipient);
|
||||
else
|
||||
emit message(tr("URI handling"),
|
||||
tr("URI can not be parsed! This can be caused by an invalid Bitcoin address or malformed URI parameters."),
|
||||
CClientUIInterface::ICON_WARNING);
|
||||
|
||||
return;
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (QFile::exists(s))
|
||||
if (QFile::exists(s)) // payment request file
|
||||
{
|
||||
PaymentRequestPlus request;
|
||||
SendCoinsRecipient recipient;
|
||||
if (readPaymentRequest(s, request) && processPaymentRequest(request, recipient))
|
||||
emit receivedPaymentRequest(recipient);
|
||||
else
|
||||
emit message(tr("Payment request file handling"),
|
||||
tr("Payment request file can not be read or processed! This can be caused by an invalid payment request file."),
|
||||
CClientUIInterface::ICON_WARNING);
|
||||
|
||||
return;
|
||||
}
|
||||
|
@ -584,7 +596,7 @@ void PaymentServer::netRequestFinished(QNetworkReply* reply)
|
|||
.arg(reply->errorString());
|
||||
|
||||
qDebug() << "PaymentServer::netRequestFinished : " << msg;
|
||||
emit message(tr("Network request error"), msg, CClientUIInterface::MSG_ERROR);
|
||||
emit message(tr("Payment request error"), msg, CClientUIInterface::MSG_ERROR);
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -596,9 +608,16 @@ void PaymentServer::netRequestFinished(QNetworkReply* reply)
|
|||
PaymentRequestPlus request;
|
||||
SendCoinsRecipient recipient;
|
||||
if (request.parse(data) && processPaymentRequest(request, recipient))
|
||||
{
|
||||
emit receivedPaymentRequest(recipient);
|
||||
}
|
||||
else
|
||||
{
|
||||
qDebug() << "PaymentServer::netRequestFinished : Error processing payment request";
|
||||
emit message(tr("Payment request error"),
|
||||
tr("Payment request can not be parsed or processed!"),
|
||||
CClientUIInterface::MSG_ERROR);
|
||||
}
|
||||
|
||||
return;
|
||||
}
|
||||
|
@ -611,9 +630,10 @@ void PaymentServer::netRequestFinished(QNetworkReply* reply)
|
|||
.arg(reply->request().url().toString());
|
||||
|
||||
qDebug() << "PaymentServer::netRequestFinished : " << msg;
|
||||
emit message(tr("Network request error"), msg, CClientUIInterface::MSG_ERROR);
|
||||
emit message(tr("Payment request error"), msg, CClientUIInterface::MSG_ERROR);
|
||||
}
|
||||
else {
|
||||
else
|
||||
{
|
||||
emit receivedPaymentACK(GUIUtil::HtmlEscape(paymentACK.memo()));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -98,7 +98,7 @@ public slots:
|
|||
// Submit Payment message to a merchant, get back PaymentACK:
|
||||
void fetchPaymentACK(CWallet* wallet, SendCoinsRecipient recipient, QByteArray transaction);
|
||||
|
||||
// Handle an incoming URI or file
|
||||
// Handle an incoming URI, URI with local file scheme or file
|
||||
void handleURIOrFile(const QString& s);
|
||||
|
||||
private slots:
|
||||
|
|
Loading…
Reference in a new issue