diff options
author | Joona <joonatoona@digitalfishfun.com> | 2017-08-22 12:49:47 -0700 |
---|---|---|
committer | Petr Mrázek <peterix@users.noreply.github.com> | 2017-08-22 22:38:01 +0200 |
commit | 4d54d2662aba3059a5c941e93b82e285fa181cff (patch) | |
tree | d3da0ee8ca70cc80505f226e2be0e33ed77f8d18 /api | |
parent | 140c31293cf21c8704f774d56aa4c45db992a557 (diff) | |
download | MultiMC-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')
-rw-r--r-- | api/logic/net/PasteUpload.cpp | 25 | ||||
-rw-r--r-- | api/logic/net/PasteUpload.h | 1 |
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: |