summaryrefslogtreecommitdiffstats
path: root/api/logic/net
diff options
context:
space:
mode:
authorJoona <joonatoona@digitalfishfun.com>2017-08-22 12:49:47 -0700
committerPetr Mrázek <peterix@users.noreply.github.com>2017-08-22 22:38:01 +0200
commit4d54d2662aba3059a5c941e93b82e285fa181cff (patch)
treed3da0ee8ca70cc80505f226e2be0e33ed77f8d18 /api/logic/net
parent140c31293cf21c8704f774d56aa4c45db992a557 (diff)
downloadMultiMC-4d54d2662aba3059a5c941e93b82e285fa181cff.tar
MultiMC-4d54d2662aba3059a5c941e93b82e285fa181cff.tar.gz
MultiMC-4d54d2662aba3059a5c941e93b82e285fa181cff.tar.lz
MultiMC-4d54d2662aba3059a5c941e93b82e285fa181cff.tar.xz
MultiMC-4d54d2662aba3059a5c941e93b82e285fa181cff.zip
switch to new paste.ee API
Diffstat (limited to 'api/logic/net')
-rw-r--r--api/logic/net/PasteUpload.cpp25
-rw-r--r--api/logic/net/PasteUpload.h1
2 files changed, 16 insertions, 10 deletions
diff --git a/api/logic/net/PasteUpload.cpp b/api/logic/net/PasteUpload.cpp
index 59779b2c..ed12da61 100644
--- a/api/logic/net/PasteUpload.cpp
+++ b/api/logic/net/PasteUpload.cpp
@@ -9,10 +9,12 @@ PasteUpload::PasteUpload(QWidget *window, QString text, QString key) : m_window(
m_key = key;
QByteArray temp;
temp = text.toUtf8();
- temp.replace('\n', "\r\n");
+ temp.replace("\n", "\\n");
m_textSize = temp.size();
- m_text = "key=" + m_key.toLatin1() + "&description=MultiMC5+Log+File&language=plain&format=json&expire=2592000&paste=" + temp.toPercentEncoding();
- buf = new QBuffer(&m_text);
+ m_text = "{\"description\": \"MultiMC Log Upload\", \"sections\": [{\"contents\": \"" + temp + "\"}]}";
+ QByteArray jsonDocument(m_text);
+ m_json = jsonDocument;
+ qDebug() << m_json;
}
PasteUpload::~PasteUpload()
@@ -30,13 +32,15 @@ bool PasteUpload::validateText()
void PasteUpload::executeTask()
{
- QNetworkRequest request(QUrl("https://paste.ee/api"));
+ QNetworkRequest request(QUrl("https://api.paste.ee/v1/pastes"));
request.setHeader(QNetworkRequest::UserAgentHeader, "MultiMC/5.0 (Uncached)");
- request.setRawHeader("Content-Type", "application/x-www-form-urlencoded");
+ request.setRawHeader("Content-Type", "application/json");
request.setRawHeader("Content-Length", QByteArray::number(m_text.size()));
+ request.setRawHeader("X-Auth-Token", m_key.toStdString().c_str());
+ qDebug() << m_key.toStdString().c_str();
- QNetworkReply *rep = ENV.qnam().post(request, buf);
+ QNetworkReply *rep = ENV.qnam().post(request, m_json);
m_reply = std::shared_ptr<QNetworkReply>(rep);
setStatus(tr("Uploading to paste.ee"));
@@ -85,14 +89,15 @@ void PasteUpload::downloadFinished()
bool PasteUpload::parseResult(QJsonDocument doc)
{
auto object = doc.object();
- auto status = object.value("status").toString("error");
- if (status == "error")
+ auto status = object.value("success").toBool();
+ if (!status)
{
qCritical() << "paste.ee reported error:" << QString(object.value("error").toString());
return false;
}
- m_pasteLink = object.value("paste").toObject().value("link").toString();
- m_pasteID = object.value("paste").toObject().value("id").toString();
+ m_pasteLink = object.value("link").toString();
+ m_pasteID = object.value("id").toString();
+ qDebug() << m_pasteLink;
return true;
}
diff --git a/api/logic/net/PasteUpload.h b/api/logic/net/PasteUpload.h
index 78d1da8e..d3a4e2e2 100644
--- a/api/logic/net/PasteUpload.h
+++ b/api/logic/net/PasteUpload.h
@@ -42,6 +42,7 @@ private:
QString m_key;
int m_textSize = 0;
QBuffer * buf = nullptr;
+ QByteArray m_json;
std::shared_ptr<QNetworkReply> m_reply;
public
slots: