diff --git a/gui/MainWindow.cpp b/gui/MainWindow.cpp index edc007622..842014d3e 100644 --- a/gui/MainWindow.cpp +++ b/gui/MainWindow.cpp @@ -589,7 +589,7 @@ void MainWindow::doAutoLogin() void MainWindow::doLogin(QString username, QString password) { - UserInfo uInfo{username, password}; + PasswordLogin uInfo{username, password}; ProgressDialog *tDialog = new ProgressDialog(this); LoginTask *loginTask = new LoginTask(uInfo, tDialog); diff --git a/logic/InstanceLauncher.cpp b/logic/InstanceLauncher.cpp index 9f78e55bd..f587e583f 100644 --- a/logic/InstanceLauncher.cpp +++ b/logic/InstanceLauncher.cpp @@ -63,7 +63,7 @@ void InstanceLauncher::doLogin(const QString &errorMsg) loginDlg->exec(); if (loginDlg->result() == QDialog::Accepted) { - UserInfo uInfo{loginDlg->getUsername(), loginDlg->getPassword()}; + PasswordLogin uInfo{loginDlg->getUsername(), loginDlg->getPassword()}; ProgressDialog *tDialog = new ProgressDialog(nullptr); LoginTask *loginTask = new LoginTask(uInfo, tDialog); diff --git a/logic/OneSixInstance.cpp b/logic/OneSixInstance.cpp index 5c93236b5..7e0d48fd5 100644 --- a/logic/OneSixInstance.cpp +++ b/logic/OneSixInstance.cpp @@ -93,6 +93,8 @@ QStringList OneSixInstance::processMinecraftArgs(LoginResponse response) token_mapping["game_directory"] = absRootDir; QString absAssetsDir = QDir("assets/").absolutePath(); token_mapping["game_assets"] = absAssetsDir; + //TODO: this is something new and not even fully implemented in the vanilla launcher. + token_mapping["user_properties"] = "{ }"; QStringList parts = args_pattern.split(' ', QString::SkipEmptyParts); for (int i = 0; i < parts.length(); i++) diff --git a/logic/OneSixRule.h b/logic/OneSixRule.h index 9cd1a2267..5a13cbd9d 100644 --- a/logic/OneSixRule.h +++ b/logic/OneSixRule.h @@ -16,7 +16,6 @@ #pragma once #include -#include #include "logic/OneSixLibrary.h" diff --git a/logic/OneSixVersion.cpp b/logic/OneSixVersion.cpp index 01bf41f4d..4e2bbda58 100644 --- a/logic/OneSixVersion.cpp +++ b/logic/OneSixVersion.cpp @@ -151,7 +151,7 @@ std::shared_ptr OneSixVersion::fromJson(QJsonObject root) root.value("minimumLauncherVersion").toDouble(); // ADD MORE HERE :D - if (launcher_ver > 0 && launcher_ver <= 9) + if (launcher_ver > 0 && launcher_ver <= 10) return fromJsonV4(root, readVersion); else { diff --git a/logic/lists/BaseVersionList.h b/logic/lists/BaseVersionList.h index 5ac9369b4..21b44e8dd 100644 --- a/logic/lists/BaseVersionList.h +++ b/logic/lists/BaseVersionList.h @@ -18,7 +18,6 @@ #include #include #include -#include #include "logic/BaseVersion.h" diff --git a/logic/lists/ForgeVersionList.h b/logic/lists/ForgeVersionList.h index 0d10e1f31..bf9e87b2e 100644 --- a/logic/lists/ForgeVersionList.h +++ b/logic/lists/ForgeVersionList.h @@ -17,7 +17,6 @@ #include #include -#include #include #include diff --git a/logic/lists/InstanceList.h b/logic/lists/InstanceList.h index c3e3561d1..d08501ebb 100644 --- a/logic/lists/InstanceList.h +++ b/logic/lists/InstanceList.h @@ -16,7 +16,6 @@ #pragma once #include -#include #include #include "categorizedsortfilterproxymodel.h" #include diff --git a/logic/lists/JavaVersionList.h b/logic/lists/JavaVersionList.h index 4826ca0c2..f816c9322 100644 --- a/logic/lists/JavaVersionList.h +++ b/logic/lists/JavaVersionList.h @@ -17,7 +17,6 @@ #include #include -#include #include "BaseVersionList.h" #include "logic/tasks/Task.h" diff --git a/logic/lists/MinecraftVersionList.h b/logic/lists/MinecraftVersionList.h index 90b1ae864..82af10094 100644 --- a/logic/lists/MinecraftVersionList.h +++ b/logic/lists/MinecraftVersionList.h @@ -18,7 +18,6 @@ #include #include #include -#include #include "BaseVersionList.h" #include "logic/tasks/Task.h" diff --git a/logic/net/HttpMetaCache.h b/logic/net/HttpMetaCache.h index e91d26842..08b39fe2f 100644 --- a/logic/net/HttpMetaCache.h +++ b/logic/net/HttpMetaCache.h @@ -15,7 +15,6 @@ #pragma once #include -#include #include #include diff --git a/logic/net/LoginTask.cpp b/logic/net/LoginTask.cpp index 4a789bb4c..5607447e4 100644 --- a/logic/net/LoginTask.cpp +++ b/logic/net/LoginTask.cpp @@ -27,7 +27,8 @@ #include #include -LoginTask::LoginTask(const UserInfo &uInfo, QObject *parent) : Task(parent), uInfo(uInfo) +LoginTask::LoginTask(const PasswordLogin &loginInfo, QObject *parent) + : Task(parent), loginInfo(loginInfo) { } @@ -49,8 +50,8 @@ void LoginTask::legacyLogin() "application/x-www-form-urlencoded"); QUrlQuery params; - params.addQueryItem("user", uInfo.username); - params.addQueryItem("password", uInfo.password); + params.addQueryItem("user", loginInfo.username); + params.addQueryItem("password", loginInfo.password); params.addQueryItem("version", "13"); netReply = worker->post(netRequest, params.query(QUrl::EncodeSpaces).toUtf8()); @@ -221,8 +222,8 @@ void LoginTask::yggdrasilLogin() agent.insert("name", QString("Minecraft")); agent.insert("version", QJsonValue(1)); root.insert("agent", agent); - root.insert("username", uInfo.username); - root.insert("password", uInfo.password); + root.insert("username", loginInfo.username); + root.insert("password", loginInfo.password); root.insert("clientToken", clientToken); QJsonDocument requestDoc(root); netReply = worker->post(netRequest, requestDoc.toJson()); @@ -247,6 +248,7 @@ void LoginTask::yggdrasilLogin() void LoginTask::parseYggdrasilReply(QByteArray data) { QJsonParseError jsonError; + QLOG_DEBUG() << data; QJsonDocument jsonDoc = QJsonDocument::fromJson(data, &jsonError); if (jsonError.error != QJsonParseError::NoError) { @@ -273,6 +275,7 @@ void LoginTask::parseYggdrasilReply(QByteArray data) playerID = selectedProfileO.value("id").toString(); playerName = selectedProfileO.value("name").toString(); } + QString sessionID = "token:" + accessToken + ":" + playerID; /* struct LoginResponse @@ -285,6 +288,6 @@ void LoginTask::parseYggdrasilReply(QByteArray data) }; */ - result = {uInfo.username, sessionID, playerName, playerID, accessToken}; + result = {loginInfo.username, sessionID, playerName, playerID, accessToken}; emitSucceeded(); } diff --git a/logic/net/LoginTask.h b/logic/net/LoginTask.h index 26ac08084..fe4e6d2fc 100644 --- a/logic/net/LoginTask.h +++ b/logic/net/LoginTask.h @@ -16,14 +16,20 @@ #pragma once #include "logic/tasks/Task.h" -#include +#include -struct UserInfo +struct PasswordLogin { QString username; QString password; }; +struct User +{ + QString id; + QMap properties; +}; + struct LoginResponse { QString username; @@ -31,6 +37,7 @@ struct LoginResponse QString player_name; QString player_id; QString access_token; + User user; // FIXME: no idea what this really is yet. anything relevant? }; class QNetworkReply; @@ -39,7 +46,7 @@ class LoginTask : public Task { Q_OBJECT public: - explicit LoginTask(const UserInfo &uInfo, QObject *parent = 0); + explicit LoginTask(const PasswordLogin &loginInfo, QObject *parent = 0); LoginResponse getResult() { return result; @@ -65,5 +72,5 @@ protected: LoginResponse result; QNetworkReply *netReply; - UserInfo uInfo; + PasswordLogin loginInfo; };