2014-02-24 16:00:27 +05:30
|
|
|
#include "ImgurAlbumCreation.h"
|
|
|
|
|
|
|
|
#include <QNetworkRequest>
|
|
|
|
#include <QJsonDocument>
|
|
|
|
#include <QJsonObject>
|
|
|
|
#include <QUrl>
|
2014-06-28 20:45:53 +05:30
|
|
|
#include <QStringList>
|
2021-11-22 03:51:12 +05:30
|
|
|
#include <QDebug>
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2020-07-18 19:48:02 +05:30
|
|
|
#include "BuildConfig.h"
|
2021-11-22 03:51:12 +05:30
|
|
|
#include "Application.h"
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2021-11-22 03:51:12 +05:30
|
|
|
ImgurAlbumCreation::ImgurAlbumCreation(QList<ScreenShot::Ptr> screenshots) : NetAction(), m_screenshots(screenshots)
|
2014-02-24 16:00:27 +05:30
|
|
|
{
|
2020-07-18 19:48:02 +05:30
|
|
|
m_url = BuildConfig.IMGUR_BASE_URL + "album.json";
|
2018-07-15 18:21:05 +05:30
|
|
|
m_status = Job_NotStarted;
|
2014-02-24 16:00:27 +05:30
|
|
|
}
|
|
|
|
|
2021-11-22 03:51:12 +05:30
|
|
|
void ImgurAlbumCreation::startImpl()
|
2014-02-24 16:00:27 +05:30
|
|
|
{
|
2018-07-15 18:21:05 +05:30
|
|
|
m_status = Job_InProgress;
|
|
|
|
QNetworkRequest request(m_url);
|
2021-07-01 23:54:29 +05:30
|
|
|
request.setHeader(QNetworkRequest::UserAgentHeader, BuildConfig.USER_AGENT_UNCACHED);
|
2018-07-15 18:21:05 +05:30
|
|
|
request.setHeader(QNetworkRequest::ContentTypeHeader, "application/x-www-form-urlencoded");
|
2021-07-02 00:19:38 +05:30
|
|
|
request.setRawHeader("Authorization", QString("Client-ID %1").arg(BuildConfig.IMGUR_CLIENT_ID).toStdString().c_str());
|
2018-07-15 18:21:05 +05:30
|
|
|
request.setRawHeader("Accept", "application/json");
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2018-07-15 18:21:05 +05:30
|
|
|
QStringList hashes;
|
|
|
|
for (auto shot : m_screenshots)
|
|
|
|
{
|
|
|
|
hashes.append(shot->m_imgurDeleteHash);
|
|
|
|
}
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2018-07-15 18:21:05 +05:30
|
|
|
const QByteArray data = "deletehashes=" + hashes.join(',').toUtf8() + "&title=Minecraft%20Screenshots&privacy=hidden";
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2021-11-22 03:51:12 +05:30
|
|
|
QNetworkReply *rep = APPLICATION->network()->post(request, data);
|
2014-02-24 16:00:27 +05:30
|
|
|
|
2018-07-15 18:21:05 +05:30
|
|
|
m_reply.reset(rep);
|
|
|
|
connect(rep, &QNetworkReply::uploadProgress, this, &ImgurAlbumCreation::downloadProgress);
|
|
|
|
connect(rep, &QNetworkReply::finished, this, &ImgurAlbumCreation::downloadFinished);
|
|
|
|
connect(rep, SIGNAL(error(QNetworkReply::NetworkError)), SLOT(downloadError(QNetworkReply::NetworkError)));
|
2014-02-24 16:00:27 +05:30
|
|
|
}
|
|
|
|
void ImgurAlbumCreation::downloadError(QNetworkReply::NetworkError error)
|
|
|
|
{
|
2018-07-15 18:21:05 +05:30
|
|
|
qDebug() << m_reply->errorString();
|
|
|
|
m_status = Job_Failed;
|
2014-02-24 16:00:27 +05:30
|
|
|
}
|
|
|
|
void ImgurAlbumCreation::downloadFinished()
|
|
|
|
{
|
2018-07-15 18:21:05 +05:30
|
|
|
if (m_status != Job_Failed)
|
|
|
|
{
|
|
|
|
QByteArray data = m_reply->readAll();
|
|
|
|
m_reply.reset();
|
|
|
|
QJsonParseError jsonError;
|
|
|
|
QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
|
|
|
|
if (jsonError.error != QJsonParseError::NoError)
|
|
|
|
{
|
|
|
|
qDebug() << jsonError.errorString();
|
|
|
|
emit failed(m_index_within_job);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
auto object = doc.object();
|
|
|
|
if (!object.value("success").toBool())
|
|
|
|
{
|
|
|
|
qDebug() << doc.toJson();
|
|
|
|
emit failed(m_index_within_job);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
m_deleteHash = object.value("data").toObject().value("deletehash").toString();
|
|
|
|
m_id = object.value("data").toObject().value("id").toString();
|
|
|
|
m_status = Job_Finished;
|
|
|
|
emit succeeded(m_index_within_job);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qDebug() << m_reply->readAll();
|
|
|
|
m_reply.reset();
|
|
|
|
emit failed(m_index_within_job);
|
|
|
|
return;
|
|
|
|
}
|
2014-02-24 16:00:27 +05:30
|
|
|
}
|
|
|
|
void ImgurAlbumCreation::downloadProgress(qint64 bytesReceived, qint64 bytesTotal)
|
|
|
|
{
|
2018-07-15 18:21:05 +05:30
|
|
|
m_total_progress = bytesTotal;
|
|
|
|
m_progress = bytesReceived;
|
|
|
|
emit netActionProgress(m_index_within_job, bytesReceived, bytesTotal);
|
2014-02-24 16:00:27 +05:30
|
|
|
}
|