2022-05-02 18:33:21 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-only
|
|
|
|
/*
|
|
|
|
* PolyMC - Minecraft Launcher
|
|
|
|
* Copyright (c) 2022 flowln <flowlnlnln@gmail.com>
|
|
|
|
*
|
|
|
|
* 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 10:30:27 +00:00
|
|
|
#include "ImgurUpload.h"
|
2021-11-21 22:21:12 +00:00
|
|
|
#include "BuildConfig.h"
|
2014-02-24 08:34:21 +00:00
|
|
|
|
2014-02-23 21:14:24 +00:00
|
|
|
#include <QNetworkRequest>
|
2014-02-24 00:45:59 +00:00
|
|
|
#include <QHttpMultiPart>
|
2014-02-23 21:14:24 +00:00
|
|
|
#include <QJsonDocument>
|
2014-02-24 00:45:59 +00:00
|
|
|
#include <QJsonObject>
|
|
|
|
#include <QHttpPart>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QUrl>
|
2015-02-02 01:14:14 +00:00
|
|
|
#include <QDebug>
|
2014-02-23 21:14:24 +00:00
|
|
|
|
2021-11-21 22:21:12 +00:00
|
|
|
ImgurUpload::ImgurUpload(ScreenShot::Ptr shot) : NetAction(), m_shot(shot)
|
2014-02-23 21:14:24 +00:00
|
|
|
{
|
2020-07-18 15:18:02 +01:00
|
|
|
m_url = BuildConfig.IMGUR_BASE_URL + "upload.json";
|
2022-04-22 02:12:14 +01:00
|
|
|
m_state = State::Inactive;
|
2014-02-23 21:14:24 +00:00
|
|
|
}
|
|
|
|
|
2022-04-22 02:12:14 +01:00
|
|
|
void ImgurUpload::executeTask()
|
2014-02-23 21:14:24 +00:00
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
finished = false;
|
2022-04-22 02:12:14 +01:00
|
|
|
m_state = Task::State::Running;
|
2018-07-15 13:51:05 +01:00
|
|
|
QNetworkRequest request(m_url);
|
2021-07-01 19:24:29 +01:00
|
|
|
request.setHeader(QNetworkRequest::UserAgentHeader, BuildConfig.USER_AGENT_UNCACHED);
|
2021-07-01 19:49:38 +01:00
|
|
|
request.setRawHeader("Authorization", QString("Client-ID %1").arg(BuildConfig.IMGUR_CLIENT_ID).toStdString().c_str());
|
2018-07-15 13:51:05 +01:00
|
|
|
request.setRawHeader("Accept", "application/json");
|
2014-02-23 21:14:24 +00:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
QFile f(m_shot->m_file.absoluteFilePath());
|
|
|
|
if (!f.open(QFile::ReadOnly))
|
|
|
|
{
|
2022-04-27 01:25:42 +01:00
|
|
|
emitFailed();
|
2018-07-15 13:51:05 +01:00
|
|
|
return;
|
|
|
|
}
|
2014-02-24 08:34:21 +00:00
|
|
|
|
2018-07-15 13:51:05 +01: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 21:14:24 +00:00
|
|
|
|
2021-11-21 22:21:12 +00:00
|
|
|
QNetworkReply *rep = m_network->post(request, multipart);
|
2014-02-23 21:14:24 +00:00
|
|
|
|
2018-07-15 13:51:05 +01:00
|
|
|
m_reply.reset(rep);
|
|
|
|
connect(rep, &QNetworkReply::uploadProgress, this, &ImgurUpload::downloadProgress);
|
|
|
|
connect(rep, &QNetworkReply::finished, this, &ImgurUpload::downloadFinished);
|
|
|
|
connect(rep, SIGNAL(error(QNetworkReply::NetworkError)),
|
|
|
|
SLOT(downloadError(QNetworkReply::NetworkError)));
|
2014-02-23 21:14:24 +00:00
|
|
|
}
|
2014-02-24 10:30:27 +00:00
|
|
|
void ImgurUpload::downloadError(QNetworkReply::NetworkError error)
|
2014-02-23 21:14:24 +00:00
|
|
|
{
|
2018-07-15 13:51:05 +01:00
|
|
|
qCritical() << "ImgurUpload failed with error" << m_reply->errorString() << "Server reply:\n" << m_reply->readAll();
|
|
|
|
if(finished)
|
|
|
|
{
|
|
|
|
qCritical() << "Double finished ImgurUpload!";
|
|
|
|
return;
|
|
|
|
}
|
2022-04-22 02:12:14 +01:00
|
|
|
m_state = Task::State::Failed;
|
2018-07-15 13:51:05 +01:00
|
|
|
finished = true;
|
|
|
|
m_reply.reset();
|
2022-04-27 01:25:42 +01:00
|
|
|
emitFailed();
|
2014-02-23 21:14:24 +00:00
|
|
|
}
|
2014-02-24 10:30:27 +00:00
|
|
|
void ImgurUpload::downloadFinished()
|
2014-02-23 21:14:24 +00:00
|
|
|
{
|
2018-07-15 13:51:05 +01: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();
|
2022-04-27 01:25:42 +01:00
|
|
|
emitFailed();
|
2018-07-15 13:51:05 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
auto object = doc.object();
|
|
|
|
if (!object.value("success").toBool())
|
|
|
|
{
|
|
|
|
qDebug() << "Screenshot upload not successful:" << doc.toJson();
|
|
|
|
finished = true;
|
|
|
|
m_reply.reset();
|
2022-04-27 01:25:42 +01:00
|
|
|
emitFailed();
|
2018-07-15 13:51:05 +01: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();
|
2022-04-22 02:12:14 +01:00
|
|
|
m_state = Task::State::Succeeded;
|
2018-07-15 13:51:05 +01:00
|
|
|
finished = true;
|
2022-04-27 01:25:42 +01:00
|
|
|
emit succeeded();
|
2018-07-15 13:51:05 +01:00
|
|
|
return;
|
2014-02-23 21:14:24 +00:00
|
|
|
}
|
2014-02-24 10:30:27 +00:00
|
|
|
void ImgurUpload::downloadProgress(qint64 bytesReceived, qint64 bytesTotal)
|
2014-02-23 21:14:24 +00:00
|
|
|
{
|
2022-04-22 02:12:14 +01:00
|
|
|
setProgress(bytesReceived, bytesTotal);
|
2022-04-27 01:25:42 +01:00
|
|
|
emit progress(bytesReceived, bytesTotal);
|
2014-02-23 21:14:24 +00:00
|
|
|
}
|