2021-08-20 05:04:32 +05:30
|
|
|
#include "CapeChange.h"
|
2021-11-22 03:51:12 +05:30
|
|
|
|
2021-08-20 05:04:32 +05:30
|
|
|
#include <QNetworkRequest>
|
|
|
|
#include <QHttpMultiPart>
|
2021-11-22 03:51:12 +05:30
|
|
|
|
|
|
|
#include "Application.h"
|
2021-08-20 05:04:32 +05:30
|
|
|
|
|
|
|
CapeChange::CapeChange(QObject *parent, AuthSessionPtr session, QString cape)
|
|
|
|
: Task(parent), m_capeId(cape), m_session(session)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void CapeChange::setCape(QString& cape) {
|
|
|
|
QNetworkRequest request(QUrl("https://api.minecraftservices.com/minecraft/profile/capes/active"));
|
|
|
|
auto requestString = QString("{\"capeId\":\"%1\"}").arg(m_capeId);
|
|
|
|
request.setRawHeader("Authorization", QString("Bearer %1").arg(m_session->access_token).toLocal8Bit());
|
2021-11-22 03:51:12 +05:30
|
|
|
QNetworkReply *rep = APPLICATION->network()->put(request, requestString.toUtf8());
|
2021-08-20 05:04:32 +05:30
|
|
|
|
|
|
|
setStatus(tr("Equipping cape"));
|
|
|
|
|
2021-11-23 05:55:24 +05:30
|
|
|
m_reply = shared_qobject_ptr<QNetworkReply>(rep);
|
2021-08-20 05:04:32 +05:30
|
|
|
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()));
|
|
|
|
}
|
|
|
|
|
|
|
|
void CapeChange::clearCape() {
|
|
|
|
QNetworkRequest request(QUrl("https://api.minecraftservices.com/minecraft/profile/capes/active"));
|
|
|
|
auto requestString = QString("{\"capeId\":\"%1\"}").arg(m_capeId);
|
|
|
|
request.setRawHeader("Authorization", QString("Bearer %1").arg(m_session->access_token).toLocal8Bit());
|
2021-11-22 03:51:12 +05:30
|
|
|
QNetworkReply *rep = APPLICATION->network()->deleteResource(request);
|
2021-08-20 05:04:32 +05:30
|
|
|
|
|
|
|
setStatus(tr("Removing cape"));
|
|
|
|
|
2021-11-23 05:55:24 +05:30
|
|
|
m_reply = shared_qobject_ptr<QNetworkReply>(rep);
|
2021-08-20 05:04:32 +05:30
|
|
|
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()));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CapeChange::executeTask()
|
|
|
|
{
|
|
|
|
if(m_capeId.isEmpty()) {
|
|
|
|
clearCape();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
setCape(m_capeId);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CapeChange::downloadError(QNetworkReply::NetworkError error)
|
|
|
|
{
|
|
|
|
// error happened during download.
|
|
|
|
qCritical() << "Network error: " << error;
|
|
|
|
emitFailed(m_reply->errorString());
|
|
|
|
}
|
|
|
|
|
|
|
|
void CapeChange::downloadFinished()
|
|
|
|
{
|
|
|
|
// if the download failed
|
|
|
|
if (m_reply->error() != QNetworkReply::NetworkError::NoError)
|
|
|
|
{
|
|
|
|
emitFailed(QString("Network error: %1").arg(m_reply->errorString()));
|
|
|
|
m_reply.reset();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
emitSucceeded();
|
|
|
|
}
|