2013-12-06 21:24:55 +00:00
|
|
|
#include "PasteUpload.h"
|
2021-11-21 22:21:12 +00:00
|
|
|
#include "BuildConfig.h"
|
|
|
|
#include "Application.h"
|
|
|
|
|
2015-02-02 01:14:14 +00:00
|
|
|
#include <QDebug>
|
2013-12-06 21:24:55 +00:00
|
|
|
#include <QJsonObject>
|
2017-10-09 20:50:15 +00:00
|
|
|
#include <QJsonArray>
|
2013-12-06 21:24:55 +00:00
|
|
|
#include <QJsonDocument>
|
2017-10-09 20:50:15 +00:00
|
|
|
#include <QFile>
|
2022-02-20 02:55:58 +00:00
|
|
|
#include <QHttpMultiPart>
|
2013-12-06 21:24:55 +00:00
|
|
|
|
2022-01-19 07:44:29 +00:00
|
|
|
PasteUpload::PasteUpload(QWidget *window, QString text, QString url) : m_window(window), m_uploadUrl(url), m_text(text.toUtf8())
|
2013-12-06 21:24:55 +00:00
|
|
|
{
|
2015-10-01 22:12:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
PasteUpload::~PasteUpload()
|
|
|
|
{
|
2015-01-11 02:08:41 +00:00
|
|
|
}
|
|
|
|
|
2013-12-06 21:24:55 +00:00
|
|
|
void PasteUpload::executeTask()
|
|
|
|
{
|
2022-01-19 07:44:29 +00:00
|
|
|
QNetworkRequest request{QUrl(m_uploadUrl)};
|
2021-07-01 18:24:29 +00:00
|
|
|
request.setHeader(QNetworkRequest::UserAgentHeader, BuildConfig.USER_AGENT_UNCACHED);
|
2015-10-01 22:12:53 +00:00
|
|
|
|
2022-01-19 07:44:29 +00:00
|
|
|
QHttpMultiPart *multiPart = new QHttpMultiPart{QHttpMultiPart::FormDataType};
|
|
|
|
|
|
|
|
QHttpPart filePart;
|
|
|
|
filePart.setBody(m_text);
|
|
|
|
filePart.setHeader(QNetworkRequest::ContentTypeHeader, "text/plain");
|
|
|
|
filePart.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"file\"; filename=\"log.txt\"");
|
2013-12-06 21:24:55 +00:00
|
|
|
|
2022-01-19 07:44:29 +00:00
|
|
|
multiPart->append(filePart);
|
|
|
|
|
|
|
|
QNetworkReply *rep = APPLICATION->network()->post(request, multiPart);
|
|
|
|
multiPart->setParent(rep);
|
2013-12-06 21:24:55 +00:00
|
|
|
|
2018-07-15 12:51:05 +00:00
|
|
|
m_reply = std::shared_ptr<QNetworkReply>(rep);
|
2022-01-19 07:44:29 +00:00
|
|
|
setStatus(tr("Uploading to %1").arg(m_uploadUrl));
|
|
|
|
|
2018-07-15 12:51:05 +00:00
|
|
|
connect(rep, &QNetworkReply::uploadProgress, this, &Task::setProgress);
|
|
|
|
connect(rep, SIGNAL(error(QNetworkReply::NetworkError)), this, SLOT(downloadError(QNetworkReply::NetworkError)));
|
|
|
|
connect(rep, SIGNAL(finished()), this, SLOT(downloadFinished()));
|
2013-12-06 21:24:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void PasteUpload::downloadError(QNetworkReply::NetworkError error)
|
|
|
|
{
|
2018-07-15 12:51:05 +00:00
|
|
|
// error happened during download.
|
|
|
|
qCritical() << "Network error: " << error;
|
|
|
|
emitFailed(m_reply->errorString());
|
2013-12-06 21:24:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void PasteUpload::downloadFinished()
|
|
|
|
{
|
2018-07-15 12:51:05 +00:00
|
|
|
QByteArray data = m_reply->readAll();
|
2022-01-19 07:44:29 +00:00
|
|
|
int statusCode = m_reply->attribute(QNetworkRequest::HttpStatusCodeAttribute).toInt();
|
|
|
|
|
|
|
|
if (m_reply->error() != QNetworkReply::NetworkError::NoError)
|
2018-07-15 12:51:05 +00:00
|
|
|
{
|
2022-01-19 07:44:29 +00:00
|
|
|
emitFailed(tr("Network error: %1").arg(m_reply->errorString()));
|
2018-07-15 12:51:05 +00:00
|
|
|
m_reply.reset();
|
2022-01-19 07:44:29 +00:00
|
|
|
return;
|
2018-07-15 12:51:05 +00:00
|
|
|
}
|
2022-01-23 17:54:58 +00:00
|
|
|
else if (statusCode != 200 && statusCode != 201)
|
2018-07-15 12:51:05 +00:00
|
|
|
{
|
2022-01-19 07:44:29 +00:00
|
|
|
QString reasonPhrase = m_reply->attribute(QNetworkRequest::HttpReasonPhraseAttribute).toString();
|
|
|
|
emitFailed(tr("Error: %1 returned unexpected status code %2 %3").arg(m_uploadUrl).arg(statusCode).arg(reasonPhrase));
|
|
|
|
qCritical() << m_uploadUrl << " returned unexpected status code " << statusCode << " with body: " << data;
|
2018-07-15 12:51:05 +00:00
|
|
|
m_reply.reset();
|
|
|
|
return;
|
|
|
|
}
|
2013-12-06 21:24:55 +00:00
|
|
|
|
2022-01-19 14:59:09 +00:00
|
|
|
m_pasteLink = QString::fromUtf8(data).trimmed();
|
2022-01-19 07:44:29 +00:00
|
|
|
emitSucceeded();
|
2013-12-06 21:24:55 +00:00
|
|
|
}
|