mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2025-03-21 11:38:34 -04:00
126 lines
4.6 KiB
C++
126 lines
4.6 KiB
C++
#include "FoxVerifier.hpp"
|
|
#include "Logger.hpp"
|
|
|
|
FoxVerifier::FoxVerifier(QString user_agent, QNetworkAccessManager *manager,QString base_url, QString callsign, QDateTime timestamp, QString code, unsigned int hz=750) : QObject(nullptr)
|
|
{
|
|
manager_ = manager;
|
|
finished_ = false;
|
|
errored_ = false;
|
|
callsign_ = callsign;
|
|
code_ = code;
|
|
ts_ = timestamp;
|
|
hz_ = hz;
|
|
|
|
// make sure we URLencode the callsign, for things like E51D/MM
|
|
QString encodedCall = QString::fromUtf8(QUrl::toPercentEncoding(callsign));
|
|
QString url = QString("%1/check/").arg(base_url) + encodedCall + QString("/%1/%2.text").arg(timestamp.toString(Qt::ISODate)).arg(code);
|
|
LOG_INFO(QString("FoxVerifier: url %1").arg(url).toStdString());
|
|
q_url_ = QUrl(url);
|
|
if (manager_ == nullptr) {
|
|
LOG_INFO("FoxVerifier: manager is null, creating new one");
|
|
manager_ = new QNetworkAccessManager(this);
|
|
manager_->deleteLater();
|
|
}
|
|
if (q_url_.isValid()) {
|
|
request_ = QNetworkRequest(q_url_);
|
|
request_.setRawHeader( "User-Agent" , user_agent.toUtf8());
|
|
request_.setRawHeader( "Accept" , "*/*" );
|
|
request_.setAttribute(QNetworkRequest::FollowRedirectsAttribute, true);
|
|
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)
|
|
request_.setTransferTimeout(FOXVERIFIER_DEFAULT_TIMEOUT_MSEC);
|
|
#endif
|
|
|
|
reply_ = manager_->get(request_);
|
|
connect(reply_, &QNetworkReply::finished, this, &FoxVerifier::httpFinished);
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)
|
|
connect(reply_, &QNetworkReply::errorOccurred, this, &FoxVerifier::errorOccurred);
|
|
#endif
|
|
connect(reply_, &QNetworkReply::redirected, this, &FoxVerifier::httpRedirected);
|
|
connect(reply_, &QNetworkReply::encrypted, this, &FoxVerifier::httpEncrypted);
|
|
#if QT_CONFIG(ssl)
|
|
connect(reply_, &QNetworkReply::sslErrors, this, &FoxVerifier::sslErrors);
|
|
#else
|
|
LOG_INFO("FoxVerifier: ssl not supported");
|
|
#endif
|
|
|
|
} else {
|
|
LOG_INFO(QString("FoxVerifier: url invalid ! %1").arg(url).toStdString());
|
|
}
|
|
}
|
|
|
|
FoxVerifier::~FoxVerifier() {
|
|
}
|
|
|
|
bool FoxVerifier::finished() {
|
|
return finished_;
|
|
}
|
|
|
|
#if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0)
|
|
void FoxVerifier::errorOccurred(QNetworkReply::NetworkError code)
|
|
{
|
|
int status = reply_->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
|
|
QString reason = reply_->attribute(QNetworkRequest::HttpReasonPhraseAttribute).toString();
|
|
errored_ = true;
|
|
error_reason_ = reply_->errorString();
|
|
if (reply_->error() != QNetworkReply::NoError) {
|
|
|
|
LOG_INFO(QString("FoxVerifier: errorOccurred status %1 error [%2][%3] isFinished %4 isrunning %5 code %6").arg(status).arg(
|
|
reason).arg(error_reason_).arg(reply_->isFinished()).arg(reply_->isRunning()).arg(code).toStdString());
|
|
return;
|
|
}
|
|
// TODO emit
|
|
}
|
|
#endif
|
|
|
|
void FoxVerifier::httpFinished()
|
|
{
|
|
int status = reply_->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
|
|
QString reason = reply_->attribute(QNetworkRequest::HttpReasonPhraseAttribute).toString();
|
|
if (reply_->error() != QNetworkReply::NoError) {
|
|
LOG_INFO(QString("FoxVerifier: httpFinished error:[%1 - %2] msg:[%3]").arg(status).arg(reason).arg(reply_->errorString()).toStdString());
|
|
reply_->abort();
|
|
emit verifyError(status, ts_, callsign_, code_, hz_, reply_->errorString());
|
|
}
|
|
return_value = reply_->read(1024); // limit amount we get
|
|
LOG_INFO(QString("FoxVerifier: httpFinished status:[%1 - %2] body:[%3] ").arg(status).arg(reason).arg(return_value).toStdString());
|
|
finished_ = true;
|
|
reply_->deleteLater();
|
|
if (status >= 200 && status <= 299) {
|
|
emit verifyComplete(status, ts_, callsign_, code_, hz_, return_value);
|
|
}
|
|
}
|
|
|
|
void FoxVerifier::sslErrors(const QList<QSslError> &)
|
|
{
|
|
LOG_INFO(QString("FoxVerifier: sslErrors").toStdString());
|
|
reply_->ignoreSslErrors();
|
|
}
|
|
|
|
void FoxVerifier::httpRedirected(const QUrl &url) {
|
|
LOG_INFO(QString("FoxVerifier: redirected to %1").arg(url.toString()).toStdString());
|
|
}
|
|
|
|
void FoxVerifier::httpEncrypted() {
|
|
LOG_INFO("FoxVerifier: httpEncrypted");
|
|
}
|
|
|
|
QString FoxVerifier::formatDecodeMessage(QDateTime ts, QString callsign, unsigned int hz_, QString const& verify_message) {
|
|
//"172100 -00 0.0 750 ~ K8R VERIFIED"
|
|
QTime rx_time = ts.time();
|
|
QString hz=QString("%1").arg(hz_, 4, 10 ); // insert Hz
|
|
if (verify_message.endsWith(" VERIFIED")) {
|
|
return QString("%1 0 0.0 %2 ~ %3 verified").arg(rx_time.toString("hhmmss")).arg(hz).arg(callsign);
|
|
} else
|
|
if (verify_message.endsWith(" INVALID"))
|
|
{
|
|
return QString("%1 0 0.0 %2 ~ %3 invalid").arg(rx_time.toString("hhmmss")).arg(hz).arg(callsign);
|
|
}
|
|
else
|
|
return QString{};
|
|
}
|
|
|
|
QString FoxVerifier::default_url() {
|
|
return QString(FOXVERIFIER_DEFAULT_BASE_URL);
|
|
}
|