pollymc/launcher/screenshots/ImgurUpload.cpp

156 lines
5.5 KiB
C++
Raw Normal View History

// SPDX-License-Identifier: GPL-3.0-only
/*
* PolyMC - Minecraft Launcher
* Copyright (c) 2022 flowln <flowlnlnln@gmail.com>
* Copyright (C) 2022 Sefa Eyeoglu <contact@scrumplex.net>
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*
* This file incorporates work covered by the following copyright and
* permission notice:
*
* Copyright 2013-2021 MultiMC Contributors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
2014-02-24 11:30:27 +01:00
#include "ImgurUpload.h"
#include "BuildConfig.h"
2022-06-04 15:33:17 +08:00
#include "Application.h"
2014-02-23 16:14:24 -05:00
#include <QNetworkRequest>
#include <QHttpMultiPart>
2014-02-23 16:14:24 -05:00
#include <QJsonDocument>
#include <QJsonObject>
#include <QHttpPart>
#include <QFile>
#include <QUrl>
#include <QDebug>
2014-02-23 16:14:24 -05:00
ImgurUpload::ImgurUpload(ScreenShot::Ptr shot) : NetAction(), m_shot(shot)
2014-02-23 16:14:24 -05:00
{
m_url = BuildConfig.IMGUR_BASE_URL + "upload.json";
m_state = State::Inactive;
2014-02-23 16:14:24 -05:00
}
void ImgurUpload::executeTask()
2014-02-23 16:14:24 -05:00
{
2018-07-15 14:51:05 +02:00
finished = false;
m_state = Task::State::Running;
2018-07-15 14:51:05 +02:00
QNetworkRequest request(m_url);
2022-06-04 15:33:17 +08:00
request.setHeader(QNetworkRequest::UserAgentHeader, APPLICATION->getUserAgentUncached().toUtf8());
request.setRawHeader("Authorization", QString("Client-ID %1").arg(BuildConfig.IMGUR_CLIENT_ID).toStdString().c_str());
2018-07-15 14:51:05 +02:00
request.setRawHeader("Accept", "application/json");
2014-02-23 16:14:24 -05:00
2018-07-15 14:51:05 +02:00
QFile f(m_shot->m_file.absoluteFilePath());
if (!f.open(QFile::ReadOnly))
{
emitFailed();
2018-07-15 14:51:05 +02:00
return;
}
2018-07-15 14:51:05 +02:00
QHttpMultiPart *multipart = new QHttpMultiPart(QHttpMultiPart::FormDataType);
QHttpPart filePart;
filePart.setBody(f.readAll().toBase64());
filePart.setHeader(QNetworkRequest::ContentTypeHeader, "image/png");
filePart.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"image\"");
multipart->append(filePart);
QHttpPart typePart;
typePart.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"type\"");
typePart.setBody("base64");
multipart->append(typePart);
QHttpPart namePart;
namePart.setHeader(QNetworkRequest::ContentDispositionHeader, "form-data; name=\"name\"");
namePart.setBody(m_shot->m_file.baseName().toUtf8());
multipart->append(namePart);
2014-02-23 16:14:24 -05:00
QNetworkReply *rep = m_network->post(request, multipart);
2014-02-23 16:14:24 -05:00
2018-07-15 14:51:05 +02:00
m_reply.reset(rep);
connect(rep, &QNetworkReply::uploadProgress, this, &ImgurUpload::downloadProgress);
connect(rep, &QNetworkReply::finished, this, &ImgurUpload::downloadFinished);
#if QT_VERSION >= QT_VERSION_CHECK(5, 15, 0) // QNetworkReply::errorOccurred added in 5.15
connect(rep, &QNetworkReply::errorOccurred, this, &ImgurUpload::downloadError);
#else
connect(rep, QOverload<QNetworkReply::NetworkError>::of(&QNetworkReply::error), this, &ImgurUpload::downloadError);
#endif
connect(rep, &QNetworkReply::sslErrors, this, &ImgurUpload::sslErrors);
2014-02-23 16:14:24 -05:00
}
2014-02-24 11:30:27 +01:00
void ImgurUpload::downloadError(QNetworkReply::NetworkError error)
2014-02-23 16:14:24 -05:00
{
2018-07-15 14:51:05 +02:00
qCritical() << "ImgurUpload failed with error" << m_reply->errorString() << "Server reply:\n" << m_reply->readAll();
if(finished)
{
qCritical() << "Double finished ImgurUpload!";
return;
}
m_state = Task::State::Failed;
2018-07-15 14:51:05 +02:00
finished = true;
m_reply.reset();
emitFailed();
2014-02-23 16:14:24 -05:00
}
2014-02-24 11:30:27 +01:00
void ImgurUpload::downloadFinished()
2014-02-23 16:14:24 -05:00
{
2018-07-15 14:51:05 +02:00
if(finished)
{
qCritical() << "Double finished ImgurUpload!";
return;
}
QByteArray data = m_reply->readAll();
m_reply.reset();
QJsonParseError jsonError;
QJsonDocument doc = QJsonDocument::fromJson(data, &jsonError);
if (jsonError.error != QJsonParseError::NoError)
{
qDebug() << "imgur server did not reply with JSON" << jsonError.errorString();
finished = true;
m_reply.reset();
emitFailed();
2018-07-15 14:51:05 +02:00
return;
}
auto object = doc.object();
if (!object.value("success").toBool())
{
qDebug() << "Screenshot upload not successful:" << doc.toJson();
finished = true;
m_reply.reset();
emitFailed();
2018-07-15 14:51:05 +02:00
return;
}
m_shot->m_imgurId = object.value("data").toObject().value("id").toString();
m_shot->m_url = object.value("data").toObject().value("link").toString();
m_shot->m_imgurDeleteHash = object.value("data").toObject().value("deletehash").toString();
m_state = Task::State::Succeeded;
2018-07-15 14:51:05 +02:00
finished = true;
emit succeeded();
2018-07-15 14:51:05 +02:00
return;
2014-02-23 16:14:24 -05:00
}
2014-02-24 11:30:27 +01:00
void ImgurUpload::downloadProgress(qint64 bytesReceived, qint64 bytesTotal)
2014-02-23 16:14:24 -05:00
{
setProgress(bytesReceived, bytesTotal);
emit progress(bytesReceived, bytesTotal);
2014-02-23 16:14:24 -05:00
}